// TestAPIFailureSet validates the failure of the api using a nil session. func TestAPIFailureSet(t *testing.T) { const fixture = "basic.json" set1, db := setup(t, fixture) defer teardown(t, db) qsName := prefix + "_unknown" t.Log("Given the need to validate failure of API with bad session.") { t.Log("When giving a nil session") { err := query.EnsureIndexes(tests.Context, nil, set1) 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 = query.Upsert(tests.Context, nil, set1) 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 = query.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 = query.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 = query.GetByName(tests.Context, nil, qsName) 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 = query.GetLastHistoryByName(tests.Context, nil, qsName) 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 = query.Delete(tests.Context, nil, qsName) 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) } } }
// TestGetSetNames validates retrieval of query Set record names. func TestGetSetNames(t *testing.T) { const fixture = "basic.json" set1, db := setup(t, fixture) defer teardown(t, db) t.Log("Given the need to retrieve a list of query sets.") { t.Log("\tWhen using fixture", fixture) { if err := query.Upsert(tests.Context, db, set1); err != nil { t.Fatalf("\t%s\tShould be able to create a query set : %s", tests.Failed, err) } t.Logf("\t%s\tShould be able to create a query set.", tests.Success) set2 := *set1 set2.Name += "2" if err := query.Upsert(tests.Context, db, &set2); err != nil { t.Fatalf("\t%s\tShould be able to create a second query set : %s", tests.Failed, err) } t.Logf("\t%s\tShould be able to create a second query set.", tests.Success) names, err := query.GetNames(tests.Context, db) if err != nil { t.Fatalf("\t%s\tShould be able to retrieve the query set names : %v", tests.Failed, err) } t.Logf("\t%s\tShould be able to retrieve the query set names", tests.Success) var count int for _, name := range names { if len(name) > len(prefix) && name[0:len(prefix)] == prefix { count++ } } if count != 2 { t.Fatalf("\t%s\tShould have two query sets : %d", tests.Failed, count) } t.Logf("\t%s\tShould have two query sets.", tests.Success) } } }