2022-07-06 23:19:05 +02:00
package search
import (
"context"
"database/sql"
"encoding/json"
"errors"
"fmt"
"testing"
"time"
"github.com/pocketbase/dbx"
"github.com/pocketbase/pocketbase/tools/list"
_ "modernc.org/sqlite"
)
func TestNewProvider ( t * testing . T ) {
r := & testFieldResolver { }
p := NewProvider ( r )
if p . page != 1 {
t . Fatalf ( "Expected page %d, got %d" , 1 , p . page )
}
if p . perPage != DefaultPerPage {
t . Fatalf ( "Expected perPage %d, got %d" , DefaultPerPage , p . perPage )
}
}
func TestProviderQuery ( t * testing . T ) {
db := dbx . NewFromDB ( nil , "" )
query := db . Select ( "id" ) . From ( "test" )
querySql := query . Build ( ) . SQL ( )
r := & testFieldResolver { }
p := NewProvider ( r ) . Query ( query )
expected := p . query . Build ( ) . SQL ( )
if querySql != expected {
t . Fatalf ( "Expected %v, got %v" , expected , querySql )
}
}
2023-07-21 22:24:36 +02:00
func TestProviderSkipTotal ( t * testing . T ) {
p := NewProvider ( & testFieldResolver { } )
if p . skipTotal {
t . Fatalf ( "Expected the default skipTotal to be %v, got %v" , false , p . skipTotal )
}
p . SkipTotal ( true )
if ! p . skipTotal {
t . Fatalf ( "Expected skipTotal to change to %v, got %v" , true , p . skipTotal )
}
}
2023-07-03 16:57:13 +02:00
func TestProviderCountCol ( t * testing . T ) {
p := NewProvider ( & testFieldResolver { } )
2023-07-21 22:24:36 +02:00
if p . countCol != "id" {
t . Fatalf ( "Expected the default countCol to be %s, got %s" , "id" , p . countCol )
2023-07-03 16:57:13 +02:00
}
p . CountCol ( "test" )
if p . countCol != "test" {
t . Fatalf ( "Expected colCount to change to %s, got %s" , "test" , p . countCol )
}
}
2022-07-06 23:19:05 +02:00
func TestProviderPage ( t * testing . T ) {
r := & testFieldResolver { }
p := NewProvider ( r ) . Page ( 10 )
if p . page != 10 {
t . Fatalf ( "Expected page %v, got %v" , 10 , p . page )
}
}
func TestProviderPerPage ( t * testing . T ) {
r := & testFieldResolver { }
p := NewProvider ( r ) . PerPage ( 456 )
if p . perPage != 456 {
t . Fatalf ( "Expected perPage %v, got %v" , 456 , p . perPage )
}
}
func TestProviderSort ( t * testing . T ) {
initialSort := [ ] SortField { { "test1" , SortAsc } , { "test2" , SortAsc } }
r := & testFieldResolver { }
p := NewProvider ( r ) .
Sort ( initialSort ) .
AddSort ( SortField { "test3" , SortDesc } )
encoded , _ := json . Marshal ( p . sort )
expected := ` [ { "name":"test1","direction":"ASC"}, { "name":"test2","direction":"ASC"}, { "name":"test3","direction":"DESC"}] `
if string ( encoded ) != expected {
t . Fatalf ( "Expected sort %v, got \n%v" , expected , string ( encoded ) )
}
}
func TestProviderFilter ( t * testing . T ) {
initialFilter := [ ] FilterData { "test1" , "test2" }
r := & testFieldResolver { }
p := NewProvider ( r ) .
Filter ( initialFilter ) .
AddFilter ( "test3" )
encoded , _ := json . Marshal ( p . filter )
expected := ` ["test1","test2","test3"] `
if string ( encoded ) != expected {
t . Fatalf ( "Expected filter %v, got \n%v" , expected , string ( encoded ) )
}
}
func TestProviderParse ( t * testing . T ) {
initialPage := 2
initialPerPage := 123
initialSort := [ ] SortField { { "test1" , SortAsc } , { "test2" , SortAsc } }
initialFilter := [ ] FilterData { "test1" , "test2" }
scenarios := [ ] struct {
query string
expectError bool
expectPage int
expectPerPage int
expectSort string
expectFilter string
} {
// empty
{
"" ,
false ,
initialPage ,
initialPerPage ,
` [ { "name":"test1","direction":"ASC"}, { "name":"test2","direction":"ASC"}] ` ,
` ["test1","test2"] ` ,
} ,
// invalid query
{
"invalid;" ,
true ,
initialPage ,
initialPerPage ,
` [ { "name":"test1","direction":"ASC"}, { "name":"test2","direction":"ASC"}] ` ,
` ["test1","test2"] ` ,
} ,
// invalid page
{
"page=a" ,
true ,
initialPage ,
initialPerPage ,
` [ { "name":"test1","direction":"ASC"}, { "name":"test2","direction":"ASC"}] ` ,
` ["test1","test2"] ` ,
} ,
// invalid perPage
{
"perPage=a" ,
true ,
initialPage ,
initialPerPage ,
` [ { "name":"test1","direction":"ASC"}, { "name":"test2","direction":"ASC"}] ` ,
` ["test1","test2"] ` ,
} ,
// valid query parameters
{
"page=3&perPage=456&filter=test3&sort=-a,b,+c&other=123" ,
false ,
3 ,
456 ,
` [ { "name":"test1","direction":"ASC"}, { "name":"test2","direction":"ASC"}, { "name":"a","direction":"DESC"}, { "name":"b","direction":"ASC"}, { "name":"c","direction":"ASC"}] ` ,
` ["test1","test2","test3"] ` ,
} ,
}
for i , s := range scenarios {
r := & testFieldResolver { }
p := NewProvider ( r ) .
Page ( initialPage ) .
PerPage ( initialPerPage ) .
Sort ( initialSort ) .
Filter ( initialFilter )
err := p . Parse ( s . query )
hasErr := err != nil
if hasErr != s . expectError {
t . Errorf ( "(%d) Expected hasErr %v, got %v (%v)" , i , s . expectError , hasErr , err )
continue
}
if p . page != s . expectPage {
t . Errorf ( "(%d) Expected page %v, got %v" , i , s . expectPage , p . page )
}
if p . perPage != s . expectPerPage {
t . Errorf ( "(%d) Expected perPage %v, got %v" , i , s . expectPerPage , p . perPage )
}
encodedSort , _ := json . Marshal ( p . sort )
if string ( encodedSort ) != s . expectSort {
t . Errorf ( "(%d) Expected sort %v, got \n%v" , i , s . expectSort , string ( encodedSort ) )
}
encodedFilter , _ := json . Marshal ( p . filter )
if string ( encodedFilter ) != s . expectFilter {
t . Errorf ( "(%d) Expected filter %v, got \n%v" , i , s . expectFilter , string ( encodedFilter ) )
}
}
}
func TestProviderExecEmptyQuery ( t * testing . T ) {
p := NewProvider ( & testFieldResolver { } ) .
Query ( nil )
_ , err := p . Exec ( & [ ] testTableStruct { } )
if err == nil {
t . Fatalf ( "Expected error with empty query, got nil" )
}
}
func TestProviderExecNonEmptyQuery ( t * testing . T ) {
testDB , err := createTestDB ( )
if err != nil {
t . Fatal ( err )
}
defer testDB . Close ( )
query := testDB . Select ( "*" ) .
From ( "test" ) .
Where ( dbx . Not ( dbx . HashExp { "test1" : nil } ) ) .
OrderBy ( "test1 ASC" )
scenarios := [ ] struct {
2022-12-14 12:29:43 +02:00
name string
2022-07-06 23:19:05 +02:00
page int
perPage int
sort [ ] SortField
filter [ ] FilterData
2023-07-21 22:24:36 +02:00
skipTotal bool
2022-07-06 23:19:05 +02:00
expectError bool
expectResult string
expectQueries [ ] string
} {
{
2022-12-14 12:29:43 +02:00
"page normalization" ,
2022-07-06 23:19:05 +02:00
- 1 ,
10 ,
[ ] SortField { } ,
[ ] FilterData { } ,
false ,
2023-07-21 22:24:36 +02:00
false ,
2022-08-09 15:20:39 +02:00
` { "page":1,"perPage":10,"totalItems":2,"totalPages":1,"items":[ { "test1":1,"test2":"test2.1","test3":""}, { "test1":2,"test2":"test2.2","test3":""}]} ` ,
2022-07-06 23:19:05 +02:00
[ ] string {
2023-07-21 22:24:36 +02:00
"SELECT COUNT(DISTINCT [[test.id]]) FROM `test` WHERE NOT (`test1` IS NULL)" ,
2022-07-06 23:19:05 +02:00
"SELECT * FROM `test` WHERE NOT (`test1` IS NULL) ORDER BY `test1` ASC LIMIT 10" ,
} ,
} ,
{
2022-12-14 12:29:43 +02:00
"perPage normalization" ,
2023-07-21 22:24:36 +02:00
10 ,
0 , // fallback to default
2022-07-06 23:19:05 +02:00
[ ] SortField { } ,
[ ] FilterData { } ,
false ,
2023-07-21 22:24:36 +02:00
false ,
` { "page":10,"perPage":30,"totalItems":2,"totalPages":1,"items":[]} ` ,
2022-07-06 23:19:05 +02:00
[ ] string {
2023-07-21 22:24:36 +02:00
"SELECT COUNT(DISTINCT [[test.id]]) FROM `test` WHERE NOT (`test1` IS NULL)" ,
"SELECT * FROM `test` WHERE NOT (`test1` IS NULL) ORDER BY `test1` ASC LIMIT 30 OFFSET 270" ,
2022-07-06 23:19:05 +02:00
} ,
} ,
{
2022-12-14 12:29:43 +02:00
"invalid sort field" ,
2022-07-06 23:19:05 +02:00
1 ,
10 ,
[ ] SortField { { "unknown" , SortAsc } } ,
[ ] FilterData { } ,
2023-07-21 22:24:36 +02:00
false ,
2022-07-06 23:19:05 +02:00
true ,
"" ,
nil ,
} ,
{
2022-12-14 12:29:43 +02:00
"invalid filter" ,
2022-07-06 23:19:05 +02:00
1 ,
10 ,
[ ] SortField { } ,
[ ] FilterData { "test2 = 'test2.1'" , "invalid" } ,
2023-07-21 22:24:36 +02:00
false ,
2022-07-06 23:19:05 +02:00
true ,
"" ,
nil ,
} ,
{
2022-12-14 12:29:43 +02:00
"valid sort and filter fields" ,
2022-07-06 23:19:05 +02:00
1 ,
5555 , // will be limited by MaxPerPage
[ ] SortField { { "test2" , SortDesc } } ,
[ ] FilterData { "test2 != null" , "test1 >= 2" } ,
false ,
2023-07-21 22:24:36 +02:00
false ,
2022-08-09 15:20:39 +02:00
` { "page":1,"perPage": ` + fmt . Sprint ( MaxPerPage ) + ` ,"totalItems":1,"totalPages":1,"items":[ { "test1":2,"test2":"test2.2","test3":""}]} ` ,
2022-07-06 23:19:05 +02:00
[ ] string {
2023-12-08 13:50:12 +02:00
"SELECT COUNT(DISTINCT [[test.id]]) FROM `test` WHERE ((NOT (`test1` IS NULL)) AND (((test2 IS NOT '' AND test2 IS NOT NULL)))) AND (test1 >= 2)" ,
"SELECT * FROM `test` WHERE ((NOT (`test1` IS NULL)) AND (((test2 IS NOT '' AND test2 IS NOT NULL)))) AND (test1 >= 2) ORDER BY `test1` ASC, `test2` DESC LIMIT " + fmt . Sprint ( MaxPerPage ) ,
2023-07-21 22:24:36 +02:00
} ,
} ,
{
"valid sort and filter fields (skipTotal=1)" ,
1 ,
5555 , // will be limited by MaxPerPage
[ ] SortField { { "test2" , SortDesc } } ,
[ ] FilterData { "test2 != null" , "test1 >= 2" } ,
true ,
false ,
` { "page":1,"perPage": ` + fmt . Sprint ( MaxPerPage ) + ` ,"totalItems":-1,"totalPages":-1,"items":[ { "test1":2,"test2":"test2.2","test3":""}]} ` ,
[ ] string {
2023-12-08 13:50:12 +02:00
"SELECT * FROM `test` WHERE ((NOT (`test1` IS NULL)) AND (((test2 IS NOT '' AND test2 IS NOT NULL)))) AND (test1 >= 2) ORDER BY `test1` ASC, `test2` DESC LIMIT " + fmt . Sprint ( MaxPerPage ) ,
2022-07-06 23:19:05 +02:00
} ,
} ,
{
2022-12-14 12:29:43 +02:00
"valid sort and filter fields (zero results)" ,
2022-07-06 23:19:05 +02:00
1 ,
10 ,
[ ] SortField { { "test3" , SortAsc } } ,
[ ] FilterData { "test3 != ''" } ,
false ,
2023-07-21 22:24:36 +02:00
false ,
2022-08-09 15:20:39 +02:00
` { "page":1,"perPage":10,"totalItems":0,"totalPages":0,"items":[]} ` ,
2022-07-06 23:19:05 +02:00
[ ] string {
2023-12-08 13:50:12 +02:00
"SELECT COUNT(DISTINCT [[test.id]]) FROM `test` WHERE (NOT (`test1` IS NULL)) AND (((test3 IS NOT '' AND test3 IS NOT NULL)))" ,
"SELECT * FROM `test` WHERE (NOT (`test1` IS NULL)) AND (((test3 IS NOT '' AND test3 IS NOT NULL))) ORDER BY `test1` ASC, `test3` ASC LIMIT 10" ,
2023-07-21 22:24:36 +02:00
} ,
} ,
{
"valid sort and filter fields (zero results; skipTotal=1)" ,
1 ,
10 ,
[ ] SortField { { "test3" , SortAsc } } ,
[ ] FilterData { "test3 != ''" } ,
true ,
false ,
` { "page":1,"perPage":10,"totalItems":-1,"totalPages":-1,"items":[]} ` ,
[ ] string {
2023-12-08 13:50:12 +02:00
"SELECT * FROM `test` WHERE (NOT (`test1` IS NULL)) AND (((test3 IS NOT '' AND test3 IS NOT NULL))) ORDER BY `test1` ASC, `test3` ASC LIMIT 10" ,
2022-07-06 23:19:05 +02:00
} ,
} ,
{
2022-12-14 12:29:43 +02:00
"pagination test" ,
2023-07-21 22:24:36 +02:00
2 ,
2022-07-06 23:19:05 +02:00
1 ,
[ ] SortField { } ,
[ ] FilterData { } ,
false ,
2023-07-21 22:24:36 +02:00
false ,
2022-08-09 15:20:39 +02:00
` { "page":2,"perPage":1,"totalItems":2,"totalPages":2,"items":[ { "test1":2,"test2":"test2.2","test3":""}]} ` ,
2022-07-06 23:19:05 +02:00
[ ] string {
2023-07-21 22:24:36 +02:00
"SELECT COUNT(DISTINCT [[test.id]]) FROM `test` WHERE NOT (`test1` IS NULL)" ,
"SELECT * FROM `test` WHERE NOT (`test1` IS NULL) ORDER BY `test1` ASC LIMIT 1 OFFSET 1" ,
} ,
} ,
{
"pagination test (skipTotal=1)" ,
2 ,
1 ,
[ ] SortField { } ,
[ ] FilterData { } ,
true ,
false ,
` { "page":2,"perPage":1,"totalItems":-1,"totalPages":-1,"items":[ { "test1":2,"test2":"test2.2","test3":""}]} ` ,
[ ] string {
2022-07-06 23:19:05 +02:00
"SELECT * FROM `test` WHERE NOT (`test1` IS NULL) ORDER BY `test1` ASC LIMIT 1 OFFSET 1" ,
} ,
} ,
}
2022-12-14 12:29:43 +02:00
for _ , s := range scenarios {
2023-12-08 13:50:12 +02:00
t . Run ( s . name , func ( t * testing . T ) {
testDB . CalledQueries = [ ] string { } // reset
testResolver := & testFieldResolver { }
p := NewProvider ( testResolver ) .
Query ( query ) .
Page ( s . page ) .
PerPage ( s . perPage ) .
Sort ( s . sort ) .
SkipTotal ( s . skipTotal ) .
Filter ( s . filter )
result , err := p . Exec ( & [ ] testTableStruct { } )
hasErr := err != nil
if hasErr != s . expectError {
t . Fatalf ( "Expected hasErr %v, got %v (%v)" , s . expectError , hasErr , err )
}
2022-07-06 23:19:05 +02:00
2023-12-08 13:50:12 +02:00
if hasErr {
return
}
2022-07-06 23:19:05 +02:00
2023-12-08 13:50:12 +02:00
if testResolver . UpdateQueryCalls != 1 {
t . Fatalf ( "Expected resolver.Update to be called %d, got %d" , 1 , testResolver . UpdateQueryCalls )
}
2022-07-06 23:19:05 +02:00
2023-12-08 13:50:12 +02:00
encoded , _ := json . Marshal ( result )
if string ( encoded ) != s . expectResult {
t . Fatalf ( "Expected result %v, got \n%v" , s . expectResult , string ( encoded ) )
}
2022-07-06 23:19:05 +02:00
2023-12-08 13:50:12 +02:00
if len ( s . expectQueries ) != len ( testDB . CalledQueries ) {
t . Fatalf ( "Expected %d queries, got %d: \n%v" , len ( s . expectQueries ) , len ( testDB . CalledQueries ) , testDB . CalledQueries )
}
2022-07-06 23:19:05 +02:00
2023-12-08 13:50:12 +02:00
for _ , q := range testDB . CalledQueries {
if ! list . ExistInSliceWithRegex ( q , s . expectQueries ) {
t . Fatalf ( "Didn't expect query \n%v \nin \n%v" , q , s . expectQueries )
}
2022-07-06 23:19:05 +02:00
}
2023-12-08 13:50:12 +02:00
} )
2022-07-06 23:19:05 +02:00
}
}
func TestProviderParseAndExec ( t * testing . T ) {
testDB , err := createTestDB ( )
if err != nil {
t . Fatal ( err )
}
defer testDB . Close ( )
query := testDB . Select ( "*" ) .
From ( "test" ) .
Where ( dbx . Not ( dbx . HashExp { "test1" : nil } ) ) .
OrderBy ( "test1 ASC" )
scenarios := [ ] struct {
2023-07-21 22:24:36 +02:00
name string
2022-07-06 23:19:05 +02:00
queryString string
expectError bool
expectResult string
} {
{
2023-07-21 22:24:36 +02:00
"no extra query params (aka. use the provider presets)" ,
2022-07-06 23:19:05 +02:00
"" ,
false ,
2023-07-21 22:24:36 +02:00
` { "page":2,"perPage":123,"totalItems":2,"totalPages":1,"items":[]} ` ,
2022-07-06 23:19:05 +02:00
} ,
{
2023-07-21 22:24:36 +02:00
"invalid query" ,
2022-07-06 23:19:05 +02:00
"invalid;" ,
true ,
"" ,
} ,
{
2023-07-21 22:24:36 +02:00
"invalid page" ,
2022-07-06 23:19:05 +02:00
"page=a" ,
true ,
"" ,
} ,
{
2023-07-21 22:24:36 +02:00
"invalid perPage" ,
2022-07-06 23:19:05 +02:00
"perPage=a" ,
true ,
"" ,
} ,
{
2023-07-21 22:24:36 +02:00
"invalid skipTotal" ,
"skipTotal=a" ,
true ,
"" ,
} ,
{
"invalid sorting field" ,
2022-07-06 23:19:05 +02:00
"sort=-unknown" ,
true ,
"" ,
} ,
{
2023-07-21 22:24:36 +02:00
"invalid filter field" ,
2022-07-06 23:19:05 +02:00
"filter=unknown>1" ,
true ,
"" ,
} ,
{
2023-07-21 22:24:36 +02:00
"page > existing" ,
"page=3&perPage=9999" ,
false ,
2023-07-30 09:02:44 +02:00
` { "page":3,"perPage":500,"totalItems":2,"totalPages":1,"items":[]} ` ,
2023-07-21 22:24:36 +02:00
} ,
{
"valid query params" ,
"page=1&perPage=9999&filter=test1>1&sort=-test2,test3" ,
false ,
2023-07-30 09:02:44 +02:00
` { "page":1,"perPage":500,"totalItems":1,"totalPages":1,"items":[ { "test1":2,"test2":"test2.2","test3":""}]} ` ,
2023-07-21 22:24:36 +02:00
} ,
{
"valid query params with skipTotal=1" ,
"page=1&perPage=9999&filter=test1>1&sort=-test2,test3&skipTotal=1" ,
2022-07-06 23:19:05 +02:00
false ,
2023-07-30 09:02:44 +02:00
` { "page":1,"perPage":500,"totalItems":-1,"totalPages":-1,"items":[ { "test1":2,"test2":"test2.2","test3":""}]} ` ,
2022-07-06 23:19:05 +02:00
} ,
}
2023-07-21 22:24:36 +02:00
for _ , s := range scenarios {
2022-07-06 23:19:05 +02:00
testDB . CalledQueries = [ ] string { } // reset
testResolver := & testFieldResolver { }
provider := NewProvider ( testResolver ) .
Query ( query ) .
Page ( 2 ) .
PerPage ( 123 ) .
Sort ( [ ] SortField { { "test2" , SortAsc } } ) .
Filter ( [ ] FilterData { "test1 > 0" } )
result , err := provider . ParseAndExec ( s . queryString , & [ ] testTableStruct { } )
hasErr := err != nil
if hasErr != s . expectError {
2023-07-21 22:24:36 +02:00
t . Errorf ( "[%s] Expected hasErr %v, got %v (%v)" , s . name , s . expectError , hasErr , err )
2022-07-06 23:19:05 +02:00
continue
}
if hasErr {
continue
}
if testResolver . UpdateQueryCalls != 1 {
2023-07-21 22:24:36 +02:00
t . Errorf ( "[%s] Expected resolver.Update to be called %d, got %d" , s . name , 1 , testResolver . UpdateQueryCalls )
}
expectedQueries := 2
if provider . skipTotal {
expectedQueries = 1
2022-07-06 23:19:05 +02:00
}
2023-07-21 22:24:36 +02:00
if len ( testDB . CalledQueries ) != expectedQueries {
t . Errorf ( "[%s] Expected %d db queries, got %d: \n%v" , s . name , expectedQueries , len ( testDB . CalledQueries ) , testDB . CalledQueries )
2022-07-06 23:19:05 +02:00
}
encoded , _ := json . Marshal ( result )
if string ( encoded ) != s . expectResult {
2023-07-21 22:24:36 +02:00
t . Errorf ( "[%s] Expected result %v, got \n%v" , s . name , s . expectResult , string ( encoded ) )
2022-07-06 23:19:05 +02:00
}
}
}
// -------------------------------------------------------------------
// Helpers
// -------------------------------------------------------------------
type testTableStruct struct {
Test1 int ` db:"test1" json:"test1" `
Test2 string ` db:"test2" json:"test2" `
Test3 string ` db:"test3" json:"test3" `
}
type testDB struct {
* dbx . DB
CalledQueries [ ] string
}
// NB! Don't forget to call `db.Close()` at the end of the test.
func createTestDB ( ) ( * testDB , error ) {
2023-07-21 22:24:36 +02:00
// using a shared cache to allow multiple connections access to
// the same in memory database https://www.sqlite.org/inmemorydb.html
sqlDB , err := sql . Open ( "sqlite" , "file::memory:?cache=shared" )
2022-07-06 23:19:05 +02:00
if err != nil {
return nil , err
}
db := testDB { DB : dbx . NewFromDB ( sqlDB , "sqlite" ) }
2022-10-30 10:28:14 +02:00
db . CreateTable ( "test" , map [ string ] string { "id" : "int default 0" , "test1" : "int default 0" , "test2" : "text default ''" , "test3" : "text default ''" } ) . Execute ( )
db . Insert ( "test" , dbx . Params { "id" : 1 , "test1" : 1 , "test2" : "test2.1" } ) . Execute ( )
db . Insert ( "test" , dbx . Params { "id" : 2 , "test1" : 2 , "test2" : "test2.2" } ) . Execute ( )
2022-07-06 23:19:05 +02:00
db . QueryLogFunc = func ( ctx context . Context , t time . Duration , sql string , rows * sql . Rows , err error ) {
db . CalledQueries = append ( db . CalledQueries , sql )
}
return & db , nil
}
// ---
type testFieldResolver struct {
UpdateQueryCalls int
ResolveCalls int
}
func ( t * testFieldResolver ) UpdateQuery ( query * dbx . SelectQuery ) error {
t . UpdateQueryCalls ++
return nil
}
2023-01-07 22:25:56 +02:00
func ( t * testFieldResolver ) Resolve ( field string ) ( * ResolverResult , error ) {
2022-07-06 23:19:05 +02:00
t . ResolveCalls ++
if field == "unknown" {
2023-01-07 22:25:56 +02:00
return nil , errors . New ( "test error" )
2022-07-06 23:19:05 +02:00
}
2023-01-07 22:25:56 +02:00
return & ResolverResult { Identifier : field } , nil
2022-07-06 23:19:05 +02:00
}