// TestAPIFailureRegexs validates the failure of the api using a nil session. func TestAPIFailureRegexs(t *testing.T) { const fixture = "basic.json" rgx1, db := setup(t, fixture) defer teardown(t, db) rgxName := prefix + "_unknown" t.Log("Given the need to validate failure of API with bad session.") { t.Log("When giving a nil session") { err := regex.Upsert(tests.Context, nil, rgx1) if err == nil { t.Fatalf("\t%s\tShould be refused create by api with bad session", tests.Failed) } t.Logf("\t%s\tShould be refused create by api with bad session: %s", tests.Success, err) _, err = regex.GetNames(tests.Context, nil) if err == nil { t.Fatalf("\t%s\tShould be refused get request by api with bad session", tests.Failed) } t.Logf("\t%s\tShould be refused get request by api with bad session: %s", tests.Success, err) _, err = regex.GetAll(tests.Context, nil, nil) if err == nil { t.Fatalf("\t%s\tShould be refused get request by api with bad session", tests.Failed) } t.Logf("\t%s\tShould be refused get request by api with bad session: %s", tests.Success, err) _, err = regex.GetByName(tests.Context, nil, rgxName) if err == nil { t.Fatalf("\t%s\tShould be refused get request by api with bad session", tests.Failed) } t.Logf("\t%s\tShould be refused get request by api with bad session: %s", tests.Success, err) _, err = regex.GetByNames(tests.Context, nil, nil) if err == nil { t.Fatalf("\t%s\tShould be refused get request by api with bad session", tests.Failed) } t.Logf("\t%s\tShould be refused get request by api with bad session: %s", tests.Success, err) _, err = regex.GetLastHistoryByName(tests.Context, nil, rgxName) if err == nil { t.Fatalf("\t%s\tShould be refused get request by api with bad session", tests.Failed) } t.Logf("\t%s\tShould be refused get request by api with bad session: %s", tests.Success, err) err = regex.Delete(tests.Context, nil, rgxName) if err == nil { t.Fatalf("\t%s\tShould be refused delete by api with bad session", tests.Failed) } t.Logf("\t%s\tShould be refused delete by api with bad session: %s", tests.Success, err) } } }
// TestGetRegexByNames validates retrieval of Regex records by a set of names. func TestGetRegexByNames(t *testing.T) { const fixture = "basic.json" rgx1, db := setup(t, fixture) defer teardown(t, db) t.Log("Given the need to retrieve a list of regex values.") { t.Log("\tWhen using two regexs") { if err := regex.Upsert(tests.Context, db, rgx1); err != nil { t.Fatalf("\t%s\tShould be able to create a regex : %s", tests.Failed, err) } t.Logf("\t%s\tShould be able to create a regex.", tests.Success) rgx2 := rgx1 rgx2.Name += "2" if err := regex.Upsert(tests.Context, db, rgx2); err != nil { t.Fatalf("\t%s\tShould be able to create a second regex : %s", tests.Failed, err) } t.Logf("\t%s\tShould be able to create a second regex.", tests.Success) regexs, err := regex.GetByNames(tests.Context, db, []string{rgx1.Name, rgx2.Name}) if err != nil { t.Fatalf("\t%s\tShould be able to retrieve the regexs by names : %v", tests.Failed, err) } t.Logf("\t%s\tShould be able to retrieve the regexs by names", tests.Success) var count int for _, rgx := range regexs { if len(rgx.Name) > len(prefix) && rgx.Name[0:len(prefix)] == prefix { count++ } } if count != 2 { t.Fatalf("\t%s\tShould have two regexs : %d", tests.Failed, len(regexs)) } t.Logf("\t%s\tShould have two regexs.", tests.Success) if regexs[0].Name != rgx1.Name || regexs[1].Name != rgx2.Name { t.Errorf("\t%s\tShould have retrieve the correct regexs.", tests.Failed) } else { t.Logf("\t%s\tShould have retrieve the correct regexs.", tests.Success) } } } }