diff --git a/_examples/chat/chat_test.go b/_examples/chat/chat_test.go index 969160cabe..28f152cc8b 100644 --- a/_examples/chat/chat_test.go +++ b/_examples/chat/chat_test.go @@ -5,7 +5,9 @@ import ( "runtime" "sync" "testing" + "time" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" @@ -14,7 +16,12 @@ import ( ) func TestChatSubscriptions(t *testing.T) { - c := client.New(handler.NewDefaultServer(NewExecutableSchema(New()))) + srv := handler.New(NewExecutableSchema(New())) + srv.AddTransport(transport.Websocket{ + KeepAlivePingInterval: time.Second, + }) + srv.AddTransport(transport.POST{}) + c := client.New(srv) const batchSize = 128 var wg sync.WaitGroup diff --git a/_examples/config/server/server.go b/_examples/config/server/server.go index de8e18cf73..88f74efc60 100644 --- a/_examples/config/server/server.go +++ b/_examples/config/server/server.go @@ -6,13 +6,18 @@ import ( todo "github.com/99designs/gqlgen/_examples/config" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) func main() { - http.Handle("/", playground.Handler("Todo", "/query")) - http.Handle("/query", handler.NewDefaultServer( + srv := handler.New( todo.NewExecutableSchema(todo.New()), - )) + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + + http.Handle("/", playground.Handler("Todo", "/query")) + http.Handle("/query", srv) log.Fatal(http.ListenAndServe(":8081", nil)) } diff --git a/_examples/dataloader/dataloader_test.go b/_examples/dataloader/dataloader_test.go index 3ae2d92eac..9235901479 100644 --- a/_examples/dataloader/dataloader_test.go +++ b/_examples/dataloader/dataloader_test.go @@ -3,6 +3,8 @@ package dataloader import ( "testing" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -11,7 +13,10 @@ import ( ) func TestTodo(t *testing.T) { - c := client.New(LoaderMiddleware(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: &Resolver{}})))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: &Resolver{}})) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) + c := client.New(LoaderMiddleware(srv)) t.Run("create a new todo", func(t *testing.T) { var resp any diff --git a/_examples/dataloader/server/server.go b/_examples/dataloader/server/server.go index c1ee0def4c..6a1cef41f1 100644 --- a/_examples/dataloader/server/server.go +++ b/_examples/dataloader/server/server.go @@ -6,16 +6,21 @@ import ( "github.com/99designs/gqlgen/_examples/dataloader" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) func main() { router := http.NewServeMux() - router.Handle("/", playground.Handler("Dataloader", "/query")) - router.Handle("/query", handler.NewDefaultServer( + srv := handler.New( dataloader.NewExecutableSchema(dataloader.Config{Resolvers: &dataloader.Resolver{}}), - )) + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + + router.Handle("/", playground.Handler("Dataloader", "/query")) + router.Handle("/query", srv) log.Println("connect to http://localhost:8082/ for graphql playground") log.Fatal(http.ListenAndServe(":8082", dataloader.LoaderMiddleware(router))) diff --git a/_examples/embedding/subdir/embedding_test.go b/_examples/embedding/subdir/embedding_test.go index 3f2e97d24c..3925d54412 100644 --- a/_examples/embedding/subdir/embedding_test.go +++ b/_examples/embedding/subdir/embedding_test.go @@ -3,6 +3,7 @@ package subdir import ( "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/_examples/embedding/subdir/gendir" @@ -11,7 +12,9 @@ import ( ) func TestEmbeddingWorks(t *testing.T) { - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: &Resolver{}}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: &Resolver{}})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { InSchemadir string Parentdir string @@ -30,7 +33,9 @@ func TestEmbeddingWorks(t *testing.T) { } func TestEmbeddingWorksInGendir(t *testing.T) { - c := client.New(handler.NewDefaultServer(gendir.NewExecutableSchema(gendir.Config{Resolvers: &GendirResolver{}}))) + srv := handler.New(gendir.NewExecutableSchema(gendir.Config{Resolvers: &GendirResolver{}})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { InSchemadir string Parentdir string diff --git a/_examples/enum/cmd/main.go b/_examples/enum/cmd/main.go index 8d5e1a99cc..ae0be45f33 100644 --- a/_examples/enum/cmd/main.go +++ b/_examples/enum/cmd/main.go @@ -6,11 +6,20 @@ import ( "github.com/99designs/gqlgen/_examples/enum/api" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) func main() { + srv := handler.New( + api.NewExecutableSchema(api.Config{Resolvers: &api.Resolver{}}), + ) + + srv.AddTransport(transport.Options{}) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + http.Handle("/", playground.Handler("Enum", "/query")) - http.Handle("/query", handler.NewDefaultServer(api.NewExecutableSchema(api.Config{Resolvers: &api.Resolver{}}))) + http.Handle("/query", srv) log.Fatal(http.ListenAndServe(":8081", nil)) } diff --git a/_examples/federation/accounts/server.go b/_examples/federation/accounts/server.go index 68ced60c09..848544feac 100644 --- a/_examples/federation/accounts/server.go +++ b/_examples/federation/accounts/server.go @@ -9,6 +9,8 @@ import ( "github.com/99designs/gqlgen/_examples/federation/accounts/graph" "github.com/99designs/gqlgen/graphql/handler" "github.com/99designs/gqlgen/graphql/handler/debug" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) @@ -20,7 +22,12 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer(graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}})) + srv := handler.New( + graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}}), + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) srv.Use(&debug.Tracer{}) http.Handle("/", playground.Handler("GraphQL playground", "/query")) diff --git a/_examples/federation/products/server.go b/_examples/federation/products/server.go index 202aea9f79..3ef1d45093 100644 --- a/_examples/federation/products/server.go +++ b/_examples/federation/products/server.go @@ -9,6 +9,8 @@ import ( "github.com/99designs/gqlgen/_examples/federation/products/graph" "github.com/99designs/gqlgen/graphql/handler" "github.com/99designs/gqlgen/graphql/handler/debug" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) @@ -20,7 +22,12 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer(graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}})) + srv := handler.New( + graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}}), + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) srv.Use(&debug.Tracer{}) http.Handle("/", playground.Handler("GraphQL playground", "/query")) diff --git a/_examples/federation/reviews/server.go b/_examples/federation/reviews/server.go index 2d506e9e26..0c37eeb5f9 100644 --- a/_examples/federation/reviews/server.go +++ b/_examples/federation/reviews/server.go @@ -9,6 +9,8 @@ import ( "github.com/99designs/gqlgen/_examples/federation/reviews/graph" "github.com/99designs/gqlgen/graphql/handler" "github.com/99designs/gqlgen/graphql/handler/debug" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) @@ -20,7 +22,12 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer(graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}})) + srv := handler.New( + graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}}), + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) srv.Use(&debug.Tracer{}) http.Handle("/", playground.Handler("GraphQL playground", "/query")) diff --git a/_examples/federation/subgraphs/subgraphs.go b/_examples/federation/subgraphs/subgraphs.go index 7d09b2a50e..90952a389a 100644 --- a/_examples/federation/subgraphs/subgraphs.go +++ b/_examples/federation/subgraphs/subgraphs.go @@ -12,6 +12,8 @@ import ( "github.com/99designs/gqlgen/graphql" "github.com/99designs/gqlgen/graphql/handler" "github.com/99designs/gqlgen/graphql/handler/debug" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) @@ -57,7 +59,10 @@ func newServer(name, port string, schema graphql.ExecutableSchema) *http.Server if port == "" { panic(fmt.Errorf("port for %s is empty", name)) } - srv := handler.NewDefaultServer(schema) + srv := handler.New(schema) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) srv.Use(&debug.Tracer{}) mux := http.NewServeMux() mux.Handle("/", playground.Handler("GraphQL playground", "/query")) diff --git a/_examples/fileupload/fileupload_test.go b/_examples/fileupload/fileupload_test.go index f611078b74..78420ff38a 100644 --- a/_examples/fileupload/fileupload_test.go +++ b/_examples/fileupload/fileupload_test.go @@ -19,7 +19,9 @@ import ( func TestFileUpload(t *testing.T) { resolver := &Stub{} - srv := httptest.NewServer(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolver}))) + h := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + h.AddTransport(transport.MultipartForm{}) + srv := httptest.NewServer(h) defer srv.Close() gql := gqlclient.New(srv.Config.Handler, gqlclient.Path("/graphql")) diff --git a/_examples/fileupload/server/server.go b/_examples/fileupload/server/server.go index 55dc08d883..e72c00d914 100644 --- a/_examples/fileupload/server/server.go +++ b/_examples/fileupload/server/server.go @@ -22,7 +22,7 @@ func main() { var mb int64 = 1 << 20 - srv := handler.NewDefaultServer(fileupload.NewExecutableSchema(fileupload.Config{Resolvers: resolver})) + srv := handler.New(fileupload.NewExecutableSchema(fileupload.Config{Resolvers: resolver})) srv.AddTransport(transport.POST{}) srv.AddTransport(transport.MultipartForm{ MaxMemory: 32 * mb, diff --git a/_examples/scalars/scalar_test.go b/_examples/scalars/scalar_test.go index 13ac2457ff..4366d8063d 100644 --- a/_examples/scalars/scalar_test.go +++ b/_examples/scalars/scalar_test.go @@ -4,6 +4,8 @@ import ( "testing" "time" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -22,7 +24,10 @@ type RawUser struct { } func TestScalars(t *testing.T) { - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: &Resolver{}}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: &Resolver{}})) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) + c := client.New(srv) t.Run("marshaling", func(t *testing.T) { var resp struct { diff --git a/_examples/scalars/server/server.go b/_examples/scalars/server/server.go index 4c2cf7c12a..e500977543 100644 --- a/_examples/scalars/server/server.go +++ b/_examples/scalars/server/server.go @@ -6,12 +6,19 @@ import ( "github.com/99designs/gqlgen/_examples/scalars" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) func main() { + srv := handler.New( + scalars.NewExecutableSchema(scalars.Config{Resolvers: &scalars.Resolver{}}), + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + http.Handle("/", playground.Handler("Starwars", "/query")) - http.Handle("/query", handler.NewDefaultServer(scalars.NewExecutableSchema(scalars.Config{Resolvers: &scalars.Resolver{}}))) + http.Handle("/query", srv) log.Fatal(http.ListenAndServe(":8084", nil)) } diff --git a/_examples/selection/selection_test.go b/_examples/selection/selection_test.go index 72495e927b..7212bbded1 100644 --- a/_examples/selection/selection_test.go +++ b/_examples/selection/selection_test.go @@ -3,6 +3,7 @@ package selection import ( "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -10,7 +11,9 @@ import ( ) func TestSelection(t *testing.T) { - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: &Resolver{}}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: &Resolver{}})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) query := `{ events { diff --git a/_examples/selection/server/server.go b/_examples/selection/server/server.go index 3cf77711e3..730c7c1a64 100644 --- a/_examples/selection/server/server.go +++ b/_examples/selection/server/server.go @@ -6,11 +6,18 @@ import ( "github.com/99designs/gqlgen/_examples/selection" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) func main() { + srv := handler.New( + selection.NewExecutableSchema(selection.Config{Resolvers: &selection.Resolver{}}), + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + http.Handle("/", playground.Handler("Selection Demo", "/query")) - http.Handle("/query", handler.NewDefaultServer(selection.NewExecutableSchema(selection.Config{Resolvers: &selection.Resolver{}}))) + http.Handle("/query", srv) log.Fatal(http.ListenAndServe(":8086", nil)) } diff --git a/_examples/starwars/benchmarks_test.go b/_examples/starwars/benchmarks_test.go index a9bebfb4f9..4f29476d72 100644 --- a/_examples/starwars/benchmarks_test.go +++ b/_examples/starwars/benchmarks_test.go @@ -7,10 +7,12 @@ import ( "github.com/99designs/gqlgen/_examples/starwars/generated" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" ) func BenchmarkSimpleQueryNoArgs(b *testing.B) { - server := handler.NewDefaultServer(generated.NewExecutableSchema(NewResolver())) + server := handler.New(generated.NewExecutableSchema(NewResolver())) + server.AddTransport(transport.POST{}) q := `{"query":"{ search(text:\"Luke\") { ... on Human { starships { name } } } }"}` diff --git a/_examples/starwars/server/server.go b/_examples/starwars/server/server.go index 990718a586..1d3131a09f 100644 --- a/_examples/starwars/server/server.go +++ b/_examples/starwars/server/server.go @@ -10,11 +10,15 @@ import ( "github.com/99designs/gqlgen/_examples/starwars/generated" "github.com/99designs/gqlgen/graphql" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) func main() { - srv := handler.NewDefaultServer(generated.NewExecutableSchema(starwars.NewResolver())) + srv := handler.New(generated.NewExecutableSchema(starwars.NewResolver())) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + srv.AroundFields(func(ctx context.Context, next graphql.Resolver) (res any, err error) { rc := graphql.GetFieldContext(ctx) fmt.Println("Entered", rc.Object, rc.Field.Name) diff --git a/_examples/starwars/starwars_test.go b/_examples/starwars/starwars_test.go index 8ffc818271..01c707fc3b 100644 --- a/_examples/starwars/starwars_test.go +++ b/_examples/starwars/starwars_test.go @@ -3,6 +3,8 @@ package starwars import ( "testing" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/_examples/starwars/generated" @@ -12,7 +14,10 @@ import ( ) func TestStarwars(t *testing.T) { - c := client.New(handler.NewDefaultServer(generated.NewExecutableSchema(NewResolver()))) + srv := handler.New(generated.NewExecutableSchema(NewResolver())) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) + c := client.New(srv) t.Run("Lukes starships", func(t *testing.T) { var resp struct { diff --git a/_examples/todo/server/server.go b/_examples/todo/server/server.go index f629e7cd95..41ff396fc9 100644 --- a/_examples/todo/server/server.go +++ b/_examples/todo/server/server.go @@ -9,11 +9,15 @@ import ( "github.com/99designs/gqlgen/_examples/todo" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) func main() { - srv := handler.NewDefaultServer(todo.NewExecutableSchema(todo.New())) + srv := handler.New(todo.NewExecutableSchema(todo.New())) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + srv.SetRecoverFunc(func(ctx context.Context, err any) (userMessage error) { // send this panic somewhere log.Print(err) diff --git a/_examples/todo/todo_test.go b/_examples/todo/todo_test.go index 808ac0680a..a0096bc419 100644 --- a/_examples/todo/todo_test.go +++ b/_examples/todo/todo_test.go @@ -3,6 +3,8 @@ package todo import ( "testing" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -11,7 +13,10 @@ import ( ) func TestTodo(t *testing.T) { - c := client.New(handler.NewDefaultServer(NewExecutableSchema(New()))) + srv := handler.New(NewExecutableSchema(New())) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) + c := client.New(srv) var resp struct { CreateTodo struct{ ID string } @@ -181,7 +186,9 @@ func TestTodo(t *testing.T) { } func TestSkipAndIncludeDirectives(t *testing.T) { - c := client.New(handler.NewDefaultServer(NewExecutableSchema(New()))) + srv := handler.New(NewExecutableSchema(New())) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("skip on field", func(t *testing.T) { var resp map[string]any diff --git a/_examples/type-system-extension/server/server.go b/_examples/type-system-extension/server/server.go index 6fec1d2403..b6bc499972 100644 --- a/_examples/type-system-extension/server/server.go +++ b/_examples/type-system-extension/server/server.go @@ -7,6 +7,7 @@ import ( extension "github.com/99designs/gqlgen/_examples/type-system-extension" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) @@ -18,8 +19,7 @@ func main() { port = defaultPort } - http.Handle("/", playground.Handler("GraphQL playground", "/query")) - http.Handle("/query", handler.NewDefaultServer( + srv := handler.New( extension.NewExecutableSchema( extension.Config{ Resolvers: extension.NewRootResolver(), @@ -33,7 +33,12 @@ func main() { }, }, ), - )) + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + + http.Handle("/", playground.Handler("GraphQL playground", "/query")) + http.Handle("/query", srv) log.Printf("connect to http://localhost:%s/ for GraphQL playground", port) log.Fatal(http.ListenAndServe(":"+port, nil)) diff --git a/_examples/uuid/server.go b/_examples/uuid/server.go index cb10a9dfa8..a14578bb71 100644 --- a/_examples/uuid/server.go +++ b/_examples/uuid/server.go @@ -7,6 +7,7 @@ import ( "github.com/99designs/gqlgen/_examples/uuid/graph" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) @@ -18,7 +19,11 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer(graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}})) + srv := handler.New( + graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}}), + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) http.Handle("/", playground.Handler("GraphQL playground", "/query")) http.Handle("/query", srv) diff --git a/codegen/testserver/followschema/complexity_test.go b/codegen/testserver/followschema/complexity_test.go index 245c1e9d8c..160c31489a 100644 --- a/codegen/testserver/followschema/complexity_test.go +++ b/codegen/testserver/followschema/complexity_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -14,8 +15,8 @@ import ( func TestComplexityCollisions(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) - + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) resolvers.QueryResolver.Overlapping = func(ctx context.Context) (fields *OverlappingFields, e error) { @@ -52,7 +53,8 @@ func TestComplexityFuncs(t *testing.T) { cfg.Complexity.OverlappingFields.Foo = func(childComplexity int) int { return 1000 } cfg.Complexity.OverlappingFields.NewFoo = func(childComplexity int) int { return 5 } - srv := handler.NewDefaultServer(NewExecutableSchema(cfg)) + srv := handler.New(NewExecutableSchema(cfg)) + srv.AddTransport(transport.POST{}) srv.Use(extension.FixedComplexityLimit(10)) c := client.New(srv) diff --git a/codegen/testserver/followschema/defaults_test.go b/codegen/testserver/followschema/defaults_test.go index 336b9e3d2a..72135199bd 100644 --- a/codegen/testserver/followschema/defaults_test.go +++ b/codegen/testserver/followschema/defaults_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -20,7 +21,8 @@ func assertDefaults(t *testing.T, ret *DefaultParametersMirror) { func TestDefaults(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("default field parameters", func(t *testing.T) { diff --git a/codegen/testserver/followschema/directive_test.go b/codegen/testserver/followschema/directive_test.go index 9ac526d986..a723ccb611 100644 --- a/codegen/testserver/followschema/directive_test.go +++ b/codegen/testserver/followschema/directive_test.go @@ -6,7 +6,9 @@ import ( "fmt" "reflect" "testing" + "time" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -109,7 +111,7 @@ func TestDirectives(t *testing.T) { resolvers.SubscriptionResolver.DirectiveUnimplemented = func(ctx context.Context) (<-chan *string, error) { return okchan() } - srv := handler.NewDefaultServer(NewExecutableSchema(Config{ + srv := handler.New(NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ //nolint:revive // can't rename min, max because it's generated code @@ -221,7 +223,10 @@ func TestDirectives(t *testing.T) { Unimplemented: nil, }, })) - + srv.AddTransport(transport.Websocket{ + KeepAlivePingInterval: time.Second, + }) + srv.AddTransport(transport.POST{}) srv.AroundFields(func(ctx context.Context, next graphql.Resolver) (res any, err error) { path, _ := ctx.Value(ckey("path")).([]int) return next(context.WithValue(ctx, ckey("path"), append(path, 1))) diff --git a/codegen/testserver/followschema/embedded_test.go b/codegen/testserver/followschema/embedded_test.go index 27e13d1f95..1e89d2bb5b 100644 --- a/codegen/testserver/followschema/embedded_test.go +++ b/codegen/testserver/followschema/embedded_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -28,9 +29,9 @@ func TestEmbedded(t *testing.T) { return &EmbeddedCase3{&fakeUnexportedEmbeddedInterface{}}, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("embedded case 1", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/followschema/enums_test.go b/codegen/testserver/followschema/enums_test.go index 1e2c480f62..da1d60ee7d 100644 --- a/codegen/testserver/followschema/enums_test.go +++ b/codegen/testserver/followschema/enums_test.go @@ -4,10 +4,11 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" - "github.com/99designs/gqlgen/graphql/handler" ) func TestEnumsResolver(t *testing.T) { @@ -16,7 +17,9 @@ func TestEnumsResolver(t *testing.T) { return input.Enum, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("input with valid enum value", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/followschema/fields_order_test.go b/codegen/testserver/followschema/fields_order_test.go index 2be70d9da5..d0e20e2c0f 100644 --- a/codegen/testserver/followschema/fields_order_test.go +++ b/codegen/testserver/followschema/fields_order_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) type FieldsOrderPayloadResults struct { @@ -19,7 +19,9 @@ type FieldsOrderPayloadResults struct { func TestFieldsOrder(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.FieldsOrderInputResolver.OverrideFirstField = func(ctx context.Context, in *FieldsOrderInput, data *string) error { if data != nil { in.FirstField = data diff --git a/codegen/testserver/followschema/generated_test.go b/codegen/testserver/followschema/generated_test.go index 1792b0b4e4..1b5011d147 100644 --- a/codegen/testserver/followschema/generated_test.go +++ b/codegen/testserver/followschema/generated_test.go @@ -8,6 +8,7 @@ import ( "reflect" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -38,7 +39,8 @@ func TestUnionFragments(t *testing.T) { return &Circle{Radius: 32}, nil } - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("inline fragment on union", func(t *testing.T) { diff --git a/codegen/testserver/followschema/input_test.go b/codegen/testserver/followschema/input_test.go index 27f6ada77a..01b6d6ecc7 100644 --- a/codegen/testserver/followschema/input_test.go +++ b/codegen/testserver/followschema/input_test.go @@ -6,6 +6,7 @@ import ( "testing" "time" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -14,7 +15,8 @@ import ( func TestInput(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("when function errors on directives", func(t *testing.T) { @@ -73,7 +75,8 @@ func TestInput(t *testing.T) { func TestInputOmittable(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("id field", func(t *testing.T) { diff --git a/codegen/testserver/followschema/interfaces_test.go b/codegen/testserver/followschema/interfaces_test.go index 6111b8a051..a00c6ab87d 100644 --- a/codegen/testserver/followschema/interfaces_test.go +++ b/codegen/testserver/followschema/interfaces_test.go @@ -6,6 +6,7 @@ import ( "reflect" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -34,12 +35,8 @@ func TestInterfaces(t *testing.T) { }, nil } - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{ - Resolvers: resolvers, - }), - ) - + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp struct { @@ -61,7 +58,7 @@ func TestInterfaces(t *testing.T) { return nil, nil } - srv := handler.NewDefaultServer( + srv := handler.New( NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ @@ -71,7 +68,7 @@ func TestInterfaces(t *testing.T) { }, }), ) - + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp any @@ -85,7 +82,7 @@ func TestInterfaces(t *testing.T) { return } - srv := handler.NewDefaultServer( + srv := handler.New( NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ @@ -96,7 +93,7 @@ func TestInterfaces(t *testing.T) { }, }), ) - + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp any @@ -110,7 +107,7 @@ func TestInterfaces(t *testing.T) { return } - srv := handler.NewDefaultServer( + srv := handler.New( NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ @@ -121,7 +118,7 @@ func TestInterfaces(t *testing.T) { }, }), ) - + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp any @@ -140,7 +137,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { NotAnInterface struct { @@ -167,7 +166,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { NotAnInterface struct { @@ -186,7 +187,9 @@ func TestInterfaces(t *testing.T) { return ConcreteNodeInterfaceImplementor{}, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { Node struct { @@ -220,7 +223,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { Shapes []struct { Coordinates struct { @@ -268,7 +273,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { Dog struct { Size struct { diff --git a/codegen/testserver/followschema/introspection_test.go b/codegen/testserver/followschema/introspection_test.go index 955451fc27..a45f6b798b 100644 --- a/codegen/testserver/followschema/introspection_test.go +++ b/codegen/testserver/followschema/introspection_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/extension" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -26,12 +27,13 @@ func TestIntrospection(t *testing.T) { require.EqualError(t, err, "[{\"message\":\"introspection disabled\",\"path\":[\"__schema\"]}]") }) - t.Run("enabled by default", func(t *testing.T) { + t.Run("enabled by adding extension", func(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) + c := client.New(srv) var resp any err := c.Post(introspection.Query, &resp) @@ -66,7 +68,9 @@ func TestIntrospection(t *testing.T) { t.Run("disabled by middleware", func(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) srv.AroundOperations(func(ctx context.Context, next graphql.OperationHandler) graphql.ResponseHandler { graphql.GetOperationContext(ctx).DisableIntrospection = true return next(ctx) diff --git a/codegen/testserver/followschema/maps_test.go b/codegen/testserver/followschema/maps_test.go index c71c9a8f5a..aa6f02b866 100644 --- a/codegen/testserver/followschema/maps_test.go +++ b/codegen/testserver/followschema/maps_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -24,9 +25,9 @@ func TestMaps(t *testing.T) { return in.Map, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("unset", func(t *testing.T) { var resp struct { MapStringInterface map[string]any diff --git a/codegen/testserver/followschema/middleware_test.go b/codegen/testserver/followschema/middleware_test.go index 2e427e38ac..89e5344a9b 100644 --- a/codegen/testserver/followschema/middleware_test.go +++ b/codegen/testserver/followschema/middleware_test.go @@ -5,6 +5,7 @@ import ( "sync" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" @@ -34,9 +35,8 @@ func TestMiddleware(t *testing.T) { var mu sync.Mutex areMethods := map[string]bool{} areResolvers := map[string]bool{} - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - ) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) srv.AroundFields(func(ctx context.Context, next graphql.Resolver) (res any, err error) { path, _ := ctx.Value(ckey("path")).([]int) return next(context.WithValue(ctx, ckey("path"), append(path, 1))) diff --git a/codegen/testserver/followschema/modelmethod_test.go b/codegen/testserver/followschema/modelmethod_test.go index 3fda4b2a39..aa366d933e 100644 --- a/codegen/testserver/followschema/modelmethod_test.go +++ b/codegen/testserver/followschema/modelmethod_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -19,9 +20,10 @@ func TestModelMethods(t *testing.T) { return true, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) + t.Run("without context", func(t *testing.T) { var resp struct { ModelMethods struct { diff --git a/codegen/testserver/followschema/mutation_with_custom_scalar_test.go b/codegen/testserver/followschema/mutation_with_custom_scalar_test.go index 05aaad02fc..557182c3f7 100644 --- a/codegen/testserver/followschema/mutation_with_custom_scalar_test.go +++ b/codegen/testserver/followschema/mutation_with_custom_scalar_test.go @@ -4,10 +4,11 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" - "github.com/99designs/gqlgen/graphql/handler" ) func TestErrorInsideMutationArgument(t *testing.T) { @@ -16,7 +17,9 @@ func TestErrorInsideMutationArgument(t *testing.T) { return "Hello world", nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("mutation with correct input doesn't return error", func(t *testing.T) { var resp map[string]any diff --git a/codegen/testserver/followschema/nulls_test.go b/codegen/testserver/followschema/nulls_test.go index 209d12b6c5..2f3fb24579 100644 --- a/codegen/testserver/followschema/nulls_test.go +++ b/codegen/testserver/followschema/nulls_test.go @@ -5,10 +5,10 @@ import ( "errors" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestNullBubbling(t *testing.T) { @@ -32,7 +32,9 @@ func TestNullBubbling(t *testing.T) { return []*Error{nil}, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("when function errors on non required field", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/followschema/panics_test.go b/codegen/testserver/followschema/panics_test.go index 4de0ef2e07..5740fb0b46 100644 --- a/codegen/testserver/followschema/panics_test.go +++ b/codegen/testserver/followschema/panics_test.go @@ -5,6 +5,7 @@ import ( "fmt" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/vektah/gqlparser/v2/gqlerror" @@ -25,7 +26,8 @@ func TestPanics(t *testing.T) { return []MarshalPanic{MarshalPanic("aa"), MarshalPanic("bb")}, nil } - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) srv.SetRecoverFunc(func(ctx context.Context, err any) (userMessage error) { return fmt.Errorf("panic: %v", err) }) diff --git a/codegen/testserver/followschema/primitive_objects_test.go b/codegen/testserver/followschema/primitive_objects_test.go index 106518cacc..de2c3eb841 100644 --- a/codegen/testserver/followschema/primitive_objects_test.go +++ b/codegen/testserver/followschema/primitive_objects_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/assert" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/assert" ) func TestPrimitiveObjects(t *testing.T) { @@ -20,7 +20,9 @@ func TestPrimitiveObjects(t *testing.T) { return int(*obj), nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("can fetch value", func(t *testing.T) { var resp struct { @@ -52,7 +54,9 @@ func TestPrimitiveStringObjects(t *testing.T) { return len(string(*obj)), nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("can fetch value", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/followschema/ptr_to_any_test.go b/codegen/testserver/followschema/ptr_to_any_test.go index 3af48a89ed..6904a51dc1 100644 --- a/codegen/testserver/followschema/ptr_to_any_test.go +++ b/codegen/testserver/followschema/ptr_to_any_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestPtrToAny(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var a any = `{"some":"thing"}` resolvers.QueryResolver.PtrToAnyContainer = func(ctx context.Context) (wrappedStruct *PtrToAnyContainer, e error) { diff --git a/codegen/testserver/followschema/ptr_to_ptr_input_test.go b/codegen/testserver/followschema/ptr_to_ptr_input_test.go index 5fcc2d1027..b9b162318b 100644 --- a/codegen/testserver/followschema/ptr_to_ptr_input_test.go +++ b/codegen/testserver/followschema/ptr_to_ptr_input_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) type UpdatePtrToPtrResults struct { @@ -17,7 +17,9 @@ type UpdatePtrToPtrResults struct { func TestPtrToPtr(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.MutationResolver.UpdatePtrToPtr = func(ctx context.Context, in UpdatePtrToPtrOuter) (ret *PtrToPtrOuter, err error) { ret = &PtrToPtrOuter{ diff --git a/codegen/testserver/followschema/ptr_to_slice_test.go b/codegen/testserver/followschema/ptr_to_slice_test.go index a95b6b46c9..0db4dc8696 100644 --- a/codegen/testserver/followschema/ptr_to_slice_test.go +++ b/codegen/testserver/followschema/ptr_to_slice_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestPtrToSlice(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.PtrToSliceContainer = func(ctx context.Context) (wrappedStruct *PtrToSliceContainer, e error) { ptrToSliceContainer := PtrToSliceContainer{ diff --git a/codegen/testserver/followschema/response_extension_test.go b/codegen/testserver/followschema/response_extension_test.go index 8df49d2300..c0e0c7b2c5 100644 --- a/codegen/testserver/followschema/response_extension_test.go +++ b/codegen/testserver/followschema/response_extension_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -17,10 +18,8 @@ func TestResponseExtension(t *testing.T) { return "Ok", nil } - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - ) - + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) srv.AroundResponses(func(ctx context.Context, next graphql.ResponseHandler) *graphql.Response { graphql.RegisterExtension(ctx, "example", "value") diff --git a/codegen/testserver/followschema/scalar_context_test.go b/codegen/testserver/followschema/scalar_context_test.go index 2d4bf1c8ba..7c93be3365 100644 --- a/codegen/testserver/followschema/scalar_context_test.go +++ b/codegen/testserver/followschema/scalar_context_test.go @@ -5,16 +5,18 @@ import ( "math" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestFloatInfAndNaN(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.Infinity = func(ctx context.Context) (float64, error) { return math.Inf(-1), nil @@ -29,7 +31,9 @@ func TestFloatInfAndNaN(t *testing.T) { func TestContextPassedToMarshal(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.StringFromContextInterface = func(ctx context.Context) (*StringFromContextInterface, error) { return &StringFromContextInterface{}, nil diff --git a/codegen/testserver/followschema/scalar_default_test.go b/codegen/testserver/followschema/scalar_default_test.go index f0faa0139e..c9b2289c69 100644 --- a/codegen/testserver/followschema/scalar_default_test.go +++ b/codegen/testserver/followschema/scalar_default_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestDefaultScalarImplementation(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.DefaultScalar = func(ctx context.Context, arg string) (i string, e error) { return arg, nil diff --git a/codegen/testserver/followschema/slices_test.go b/codegen/testserver/followschema/slices_test.go index de29686186..9fc9a0252b 100644 --- a/codegen/testserver/followschema/slices_test.go +++ b/codegen/testserver/followschema/slices_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestSlices(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("nulls vs empty slices", func(t *testing.T) { resolvers.QueryResolver.Slices = func(ctx context.Context) (slices *Slices, e error) { diff --git a/codegen/testserver/followschema/subscription_test.go b/codegen/testserver/followschema/subscription_test.go index 14b7819551..e4d5b04dc5 100644 --- a/codegen/testserver/followschema/subscription_test.go +++ b/codegen/testserver/followschema/subscription_test.go @@ -86,9 +86,10 @@ func TestSubscriptions(t *testing.T) { return res, nil } - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - ) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.Websocket{ + KeepAlivePingInterval: time.Second, + }) srv.AroundFields(func(ctx context.Context, next graphql.Resolver) (res any, err error) { path, _ := ctx.Value(ckey("path")).([]int) return next(context.WithValue(ctx, ckey("path"), append(path, 1))) diff --git a/codegen/testserver/followschema/time_test.go b/codegen/testserver/followschema/time_test.go index 947c1cc293..f934c9aafe 100644 --- a/codegen/testserver/followschema/time_test.go +++ b/codegen/testserver/followschema/time_test.go @@ -5,16 +5,18 @@ import ( "testing" "time" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestTime(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.User = func(ctx context.Context, id int) (user *User, e error) { return &User{}, nil diff --git a/codegen/testserver/followschema/typefallback_test.go b/codegen/testserver/followschema/typefallback_test.go index 013ac1b7f8..0740cb12fe 100644 --- a/codegen/testserver/followschema/typefallback_test.go +++ b/codegen/testserver/followschema/typefallback_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestTypeFallback(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.Fallback = func(ctx context.Context, arg FallbackToStringEncoding) (FallbackToStringEncoding, error) { return arg, nil diff --git a/codegen/testserver/followschema/v-ok_test.go b/codegen/testserver/followschema/v-ok_test.go index 6a12ca1a7f..424a78d324 100644 --- a/codegen/testserver/followschema/v-ok_test.go +++ b/codegen/testserver/followschema/v-ok_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -19,9 +20,9 @@ func TestOk(t *testing.T) { return &VOkCaseNil{}, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("v ok case value", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/followschema/validtypes_test.go b/codegen/testserver/followschema/validtypes_test.go index 026ebe029c..339b2dbfb0 100644 --- a/codegen/testserver/followschema/validtypes_test.go +++ b/codegen/testserver/followschema/validtypes_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestValidType(t *testing.T) { @@ -19,7 +19,9 @@ func TestValidType(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("fields with differing cases can be distinguished", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/followschema/wrapped_type_test.go b/codegen/testserver/followschema/wrapped_type_test.go index d28db51c3d..a77d73e69f 100644 --- a/codegen/testserver/followschema/wrapped_type_test.go +++ b/codegen/testserver/followschema/wrapped_type_test.go @@ -4,17 +4,20 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/client" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/codegen/testserver/followschema/otherpkg" - "github.com/99designs/gqlgen/graphql/handler" ) func TestWrappedTypes(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.WrappedScalar = func(ctx context.Context) (scalar WrappedScalar, e error) { return "hello", nil diff --git a/codegen/testserver/nullabledirectives/directive_test.go b/codegen/testserver/nullabledirectives/directive_test.go index 9e5f6fb937..b7063955fe 100644 --- a/codegen/testserver/nullabledirectives/directive_test.go +++ b/codegen/testserver/nullabledirectives/directive_test.go @@ -7,6 +7,7 @@ import ( "reflect" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -37,7 +38,7 @@ func TestDirectives(t *testing.T) { return &ok, nil } - srv := handler.NewDefaultServer(generated.NewExecutableSchema(generated.Config{ + srv := handler.New(generated.NewExecutableSchema(generated.Config{ Resolvers: resolvers, Directives: generated.DirectiveRoot{ Populate: func(ctx context.Context, obj any, next graphql.Resolver, value string) (any, error) { @@ -57,7 +58,7 @@ func TestDirectives(t *testing.T) { }, }, })) - + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("arg directives", func(t *testing.T) { diff --git a/codegen/testserver/singlefile/complexity_test.go b/codegen/testserver/singlefile/complexity_test.go index f5fcf7c10a..de4b6ebac3 100644 --- a/codegen/testserver/singlefile/complexity_test.go +++ b/codegen/testserver/singlefile/complexity_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -14,8 +15,8 @@ import ( func TestComplexityCollisions(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) - + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) resolvers.QueryResolver.Overlapping = func(ctx context.Context) (fields *OverlappingFields, e error) { @@ -52,7 +53,8 @@ func TestComplexityFuncs(t *testing.T) { cfg.Complexity.OverlappingFields.Foo = func(childComplexity int) int { return 1000 } cfg.Complexity.OverlappingFields.NewFoo = func(childComplexity int) int { return 5 } - srv := handler.NewDefaultServer(NewExecutableSchema(cfg)) + srv := handler.New(NewExecutableSchema(cfg)) + srv.AddTransport(transport.POST{}) srv.Use(extension.FixedComplexityLimit(10)) c := client.New(srv) diff --git a/codegen/testserver/singlefile/defaults_test.go b/codegen/testserver/singlefile/defaults_test.go index 58e3c2bb95..60b4cecb8c 100644 --- a/codegen/testserver/singlefile/defaults_test.go +++ b/codegen/testserver/singlefile/defaults_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -20,7 +21,8 @@ func assertDefaults(t *testing.T, ret *DefaultParametersMirror) { func TestDefaults(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("default field parameters", func(t *testing.T) { diff --git a/codegen/testserver/singlefile/directive_test.go b/codegen/testserver/singlefile/directive_test.go index 1ffb9cde9b..cf2a003ef5 100644 --- a/codegen/testserver/singlefile/directive_test.go +++ b/codegen/testserver/singlefile/directive_test.go @@ -6,7 +6,9 @@ import ( "fmt" "reflect" "testing" + "time" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -109,7 +111,7 @@ func TestDirectives(t *testing.T) { resolvers.SubscriptionResolver.DirectiveUnimplemented = func(ctx context.Context) (<-chan *string, error) { return okchan() } - srv := handler.NewDefaultServer(NewExecutableSchema(Config{ + srv := handler.New(NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ //nolint:revive // can't rename min, max because it's generated code @@ -221,7 +223,8 @@ func TestDirectives(t *testing.T) { Unimplemented: nil, }, })) - + srv.AddTransport(transport.Websocket{KeepAlivePingInterval: time.Second}) + srv.AddTransport(transport.POST{}) srv.AroundFields(func(ctx context.Context, next graphql.Resolver) (res any, err error) { path, _ := ctx.Value(ckey("path")).([]int) return next(context.WithValue(ctx, ckey("path"), append(path, 1))) diff --git a/codegen/testserver/singlefile/embedded_test.go b/codegen/testserver/singlefile/embedded_test.go index 71114adc0f..b053435807 100644 --- a/codegen/testserver/singlefile/embedded_test.go +++ b/codegen/testserver/singlefile/embedded_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) type fakeUnexportedEmbeddedInterface struct{} @@ -28,9 +28,9 @@ func TestEmbedded(t *testing.T) { return &EmbeddedCase3{&fakeUnexportedEmbeddedInterface{}}, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("embedded case 1", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/singlefile/enums_test.go b/codegen/testserver/singlefile/enums_test.go index ccbd43f543..031bfb312a 100644 --- a/codegen/testserver/singlefile/enums_test.go +++ b/codegen/testserver/singlefile/enums_test.go @@ -4,10 +4,11 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" - "github.com/99designs/gqlgen/graphql/handler" ) func TestEnumsResolver(t *testing.T) { @@ -16,7 +17,9 @@ func TestEnumsResolver(t *testing.T) { return input.Enum, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("input with valid enum value", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/singlefile/fields_order_test.go b/codegen/testserver/singlefile/fields_order_test.go index daff5b6a38..0554087496 100644 --- a/codegen/testserver/singlefile/fields_order_test.go +++ b/codegen/testserver/singlefile/fields_order_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) type FieldsOrderPayloadResults struct { @@ -19,7 +19,9 @@ type FieldsOrderPayloadResults struct { func TestFieldsOrder(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.FieldsOrderInputResolver.OverrideFirstField = func(ctx context.Context, in *FieldsOrderInput, data *string) error { if data != nil { in.FirstField = data diff --git a/codegen/testserver/singlefile/generated_test.go b/codegen/testserver/singlefile/generated_test.go index 63a6a4f2a1..153af1806f 100644 --- a/codegen/testserver/singlefile/generated_test.go +++ b/codegen/testserver/singlefile/generated_test.go @@ -8,6 +8,7 @@ import ( "reflect" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -38,7 +39,8 @@ func TestUnionFragments(t *testing.T) { return &Circle{Radius: 32}, nil } - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("inline fragment on union", func(t *testing.T) { diff --git a/codegen/testserver/singlefile/input_test.go b/codegen/testserver/singlefile/input_test.go index ea05b2edfb..76595275ad 100644 --- a/codegen/testserver/singlefile/input_test.go +++ b/codegen/testserver/singlefile/input_test.go @@ -6,6 +6,7 @@ import ( "testing" "time" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -14,7 +15,8 @@ import ( func TestInput(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("when function errors on directives", func(t *testing.T) { @@ -73,7 +75,8 @@ func TestInput(t *testing.T) { func TestInputOmittable(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) t.Run("id field", func(t *testing.T) { diff --git a/codegen/testserver/singlefile/interfaces_test.go b/codegen/testserver/singlefile/interfaces_test.go index e14b100468..65b9a61a5f 100644 --- a/codegen/testserver/singlefile/interfaces_test.go +++ b/codegen/testserver/singlefile/interfaces_test.go @@ -6,6 +6,7 @@ import ( "reflect" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -34,12 +35,8 @@ func TestInterfaces(t *testing.T) { }, nil } - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{ - Resolvers: resolvers, - }), - ) - + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp struct { @@ -61,7 +58,7 @@ func TestInterfaces(t *testing.T) { return nil, nil } - srv := handler.NewDefaultServer( + srv := handler.New( NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ @@ -71,7 +68,7 @@ func TestInterfaces(t *testing.T) { }, }), ) - + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp any @@ -85,7 +82,7 @@ func TestInterfaces(t *testing.T) { return } - srv := handler.NewDefaultServer( + srv := handler.New( NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ @@ -96,7 +93,7 @@ func TestInterfaces(t *testing.T) { }, }), ) - + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp any @@ -110,7 +107,7 @@ func TestInterfaces(t *testing.T) { return } - srv := handler.NewDefaultServer( + srv := handler.New( NewExecutableSchema(Config{ Resolvers: resolvers, Directives: DirectiveRoot{ @@ -121,7 +118,7 @@ func TestInterfaces(t *testing.T) { }, }), ) - + srv.AddTransport(transport.POST{}) c := client.New(srv) var resp any @@ -140,8 +137,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) - + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { NotAnInterface struct { ID string @@ -167,7 +165,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { NotAnInterface struct { @@ -186,7 +186,9 @@ func TestInterfaces(t *testing.T) { return ConcreteNodeInterfaceImplementor{}, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { Node struct { @@ -220,7 +222,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { Shapes []struct { Coordinates struct { @@ -268,7 +272,9 @@ func TestInterfaces(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { Dog struct { Size struct { diff --git a/codegen/testserver/singlefile/introspection_test.go b/codegen/testserver/singlefile/introspection_test.go index 48a3be0a07..a4d768e71d 100644 --- a/codegen/testserver/singlefile/introspection_test.go +++ b/codegen/testserver/singlefile/introspection_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/extension" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -29,9 +30,11 @@ func TestIntrospection(t *testing.T) { t.Run("enabled by default", func(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + srv.Use(extension.Introspection{}) + + c := client.New(srv) var resp any err := c.Post(introspection.Query, &resp) @@ -66,7 +69,8 @@ func TestIntrospection(t *testing.T) { t.Run("disabled by middleware", func(t *testing.T) { resolvers := &Stub{} - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) srv.AroundOperations(func(ctx context.Context, next graphql.OperationHandler) graphql.ResponseHandler { graphql.GetOperationContext(ctx).DisableIntrospection = true return next(ctx) diff --git a/codegen/testserver/singlefile/maps_test.go b/codegen/testserver/singlefile/maps_test.go index 8c64055b3d..c9543aed3c 100644 --- a/codegen/testserver/singlefile/maps_test.go +++ b/codegen/testserver/singlefile/maps_test.go @@ -4,10 +4,11 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" - "github.com/99designs/gqlgen/graphql/handler" ) func TestMaps(t *testing.T) { @@ -24,9 +25,9 @@ func TestMaps(t *testing.T) { return in.Map, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("unset", func(t *testing.T) { var resp struct { MapStringInterface map[string]any diff --git a/codegen/testserver/singlefile/middleware_test.go b/codegen/testserver/singlefile/middleware_test.go index ec4e1020fc..c9a0bdfb94 100644 --- a/codegen/testserver/singlefile/middleware_test.go +++ b/codegen/testserver/singlefile/middleware_test.go @@ -5,6 +5,7 @@ import ( "sync" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" @@ -42,9 +43,8 @@ func TestMiddleware(t *testing.T) { var mu sync.Mutex areMethods := map[string]bool{} areResolvers := map[string]bool{} - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - ) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) srv.AroundFields(func(ctx context.Context, next graphql.Resolver) (res any, err error) { path, _ := ctx.Value(ckey("path")).([]int) return next(context.WithValue(ctx, ckey("path"), append(path, 1))) diff --git a/codegen/testserver/singlefile/modelmethod_test.go b/codegen/testserver/singlefile/modelmethod_test.go index a584b35b78..3a4076a9d6 100644 --- a/codegen/testserver/singlefile/modelmethod_test.go +++ b/codegen/testserver/singlefile/modelmethod_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestModelMethods(t *testing.T) { @@ -19,9 +19,9 @@ func TestModelMethods(t *testing.T) { return true, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("without context", func(t *testing.T) { var resp struct { ModelMethods struct { diff --git a/codegen/testserver/singlefile/mutation_with_custom_scalar_test.go b/codegen/testserver/singlefile/mutation_with_custom_scalar_test.go index ef09ad4e88..296734406a 100644 --- a/codegen/testserver/singlefile/mutation_with_custom_scalar_test.go +++ b/codegen/testserver/singlefile/mutation_with_custom_scalar_test.go @@ -4,10 +4,11 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" - "github.com/99designs/gqlgen/graphql/handler" ) func TestErrorInsideMutationArgument(t *testing.T) { @@ -16,7 +17,9 @@ func TestErrorInsideMutationArgument(t *testing.T) { return "Hello world", nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("mutation with correct input doesn't return error", func(t *testing.T) { var resp map[string]any diff --git a/codegen/testserver/singlefile/nulls_test.go b/codegen/testserver/singlefile/nulls_test.go index dc95048999..9588d36a5c 100644 --- a/codegen/testserver/singlefile/nulls_test.go +++ b/codegen/testserver/singlefile/nulls_test.go @@ -5,10 +5,10 @@ import ( "errors" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestNullBubbling(t *testing.T) { @@ -32,7 +32,9 @@ func TestNullBubbling(t *testing.T) { return []*Error{nil}, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("when function errors on non required field", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/singlefile/panics_test.go b/codegen/testserver/singlefile/panics_test.go index 60189e9ae3..987e0fc3c5 100644 --- a/codegen/testserver/singlefile/panics_test.go +++ b/codegen/testserver/singlefile/panics_test.go @@ -5,6 +5,7 @@ import ( "fmt" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/vektah/gqlparser/v2/gqlerror" @@ -25,7 +26,8 @@ func TestPanics(t *testing.T) { return []MarshalPanic{MarshalPanic("aa"), MarshalPanic("bb")}, nil } - srv := handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers})) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) srv.SetRecoverFunc(func(ctx context.Context, err any) (userMessage error) { return fmt.Errorf("panic: %v", err) }) diff --git a/codegen/testserver/singlefile/primitive_objects_test.go b/codegen/testserver/singlefile/primitive_objects_test.go index c16e305565..8d0a1bf124 100644 --- a/codegen/testserver/singlefile/primitive_objects_test.go +++ b/codegen/testserver/singlefile/primitive_objects_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/assert" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/assert" ) func TestPrimitiveObjects(t *testing.T) { @@ -20,7 +20,9 @@ func TestPrimitiveObjects(t *testing.T) { return int(*obj), nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("can fetch value", func(t *testing.T) { var resp struct { @@ -52,7 +54,9 @@ func TestPrimitiveStringObjects(t *testing.T) { return len(string(*obj)), nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("can fetch value", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/singlefile/ptr_to_any_test.go b/codegen/testserver/singlefile/ptr_to_any_test.go index 7ad1dcb408..fad68fe9f4 100644 --- a/codegen/testserver/singlefile/ptr_to_any_test.go +++ b/codegen/testserver/singlefile/ptr_to_any_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestPtrToAny(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var a any = `{"some":"thing"}` resolvers.QueryResolver.PtrToAnyContainer = func(ctx context.Context) (wrappedStruct *PtrToAnyContainer, e error) { diff --git a/codegen/testserver/singlefile/ptr_to_ptr_input_test.go b/codegen/testserver/singlefile/ptr_to_ptr_input_test.go index bb5aef64dc..60c52a0c33 100644 --- a/codegen/testserver/singlefile/ptr_to_ptr_input_test.go +++ b/codegen/testserver/singlefile/ptr_to_ptr_input_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) type UpdatePtrToPtrResults struct { @@ -17,7 +17,9 @@ type UpdatePtrToPtrResults struct { func TestPtrToPtr(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.MutationResolver.UpdatePtrToPtr = func(ctx context.Context, in UpdatePtrToPtrOuter) (ret *PtrToPtrOuter, err error) { ret = &PtrToPtrOuter{ diff --git a/codegen/testserver/singlefile/ptr_to_slice_test.go b/codegen/testserver/singlefile/ptr_to_slice_test.go index 5549ec68ab..91446b9f79 100644 --- a/codegen/testserver/singlefile/ptr_to_slice_test.go +++ b/codegen/testserver/singlefile/ptr_to_slice_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestPtrToSlice(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.PtrToSliceContainer = func(ctx context.Context) (wrappedStruct *PtrToSliceContainer, e error) { ptrToSliceContainer := PtrToSliceContainer{ diff --git a/codegen/testserver/singlefile/response_extension_test.go b/codegen/testserver/singlefile/response_extension_test.go index f0c03329ae..0bda22b9cf 100644 --- a/codegen/testserver/singlefile/response_extension_test.go +++ b/codegen/testserver/singlefile/response_extension_test.go @@ -4,6 +4,7 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -17,10 +18,8 @@ func TestResponseExtension(t *testing.T) { return "Ok", nil } - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - ) - + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) srv.AroundResponses(func(ctx context.Context, next graphql.ResponseHandler) *graphql.Response { graphql.RegisterExtension(ctx, "example", "value") diff --git a/codegen/testserver/singlefile/scalar_context_test.go b/codegen/testserver/singlefile/scalar_context_test.go index 63d2ad32fb..c46b2d1118 100644 --- a/codegen/testserver/singlefile/scalar_context_test.go +++ b/codegen/testserver/singlefile/scalar_context_test.go @@ -5,16 +5,18 @@ import ( "math" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestFloatInfAndNaN(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.Infinity = func(ctx context.Context) (float64, error) { return math.Inf(-1), nil @@ -29,7 +31,9 @@ func TestFloatInfAndNaN(t *testing.T) { func TestContextPassedToMarshal(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.StringFromContextInterface = func(ctx context.Context) (*StringFromContextInterface, error) { return &StringFromContextInterface{}, nil diff --git a/codegen/testserver/singlefile/scalar_default_test.go b/codegen/testserver/singlefile/scalar_default_test.go index f23f6c2e82..5bf0aceaef 100644 --- a/codegen/testserver/singlefile/scalar_default_test.go +++ b/codegen/testserver/singlefile/scalar_default_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestDefaultScalarImplementation(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.DefaultScalar = func(ctx context.Context, arg string) (i string, e error) { return arg, nil diff --git a/codegen/testserver/singlefile/slices_test.go b/codegen/testserver/singlefile/slices_test.go index 596e332528..1716f718ba 100644 --- a/codegen/testserver/singlefile/slices_test.go +++ b/codegen/testserver/singlefile/slices_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestSlices(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("nulls vs empty slices", func(t *testing.T) { resolvers.QueryResolver.Slices = func(ctx context.Context) (slices *Slices, e error) { diff --git a/codegen/testserver/singlefile/subscription_test.go b/codegen/testserver/singlefile/subscription_test.go index 5303c2d2ea..10a46a7c05 100644 --- a/codegen/testserver/singlefile/subscription_test.go +++ b/codegen/testserver/singlefile/subscription_test.go @@ -86,9 +86,8 @@ func TestSubscriptions(t *testing.T) { return res, nil } - srv := handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolvers}), - ) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.Websocket{KeepAlivePingInterval: time.Second}) srv.AroundFields(func(ctx context.Context, next graphql.Resolver) (res any, err error) { path, _ := ctx.Value(ckey("path")).([]int) return next(context.WithValue(ctx, ckey("path"), append(path, 1))) diff --git a/codegen/testserver/singlefile/time_test.go b/codegen/testserver/singlefile/time_test.go index 1a7c9f9ac3..c7b1002377 100644 --- a/codegen/testserver/singlefile/time_test.go +++ b/codegen/testserver/singlefile/time_test.go @@ -5,16 +5,18 @@ import ( "testing" "time" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestTime(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.User = func(ctx context.Context, id int) (user *User, e error) { return &User{}, nil diff --git a/codegen/testserver/singlefile/typefallback_test.go b/codegen/testserver/singlefile/typefallback_test.go index 55f49282ed..6050cd0103 100644 --- a/codegen/testserver/singlefile/typefallback_test.go +++ b/codegen/testserver/singlefile/typefallback_test.go @@ -4,16 +4,18 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestTypeFallback(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.Fallback = func(ctx context.Context, arg FallbackToStringEncoding) (FallbackToStringEncoding, error) { return arg, nil diff --git a/codegen/testserver/singlefile/v-ok_test.go b/codegen/testserver/singlefile/v-ok_test.go index f7ea5055a1..dbacad580e 100644 --- a/codegen/testserver/singlefile/v-ok_test.go +++ b/codegen/testserver/singlefile/v-ok_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestOk(t *testing.T) { @@ -19,9 +19,9 @@ func TestOk(t *testing.T) { return &VOkCaseNil{}, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("v ok case value", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/singlefile/validtypes_test.go b/codegen/testserver/singlefile/validtypes_test.go index 6b27a4a399..d9625290a0 100644 --- a/codegen/testserver/singlefile/validtypes_test.go +++ b/codegen/testserver/singlefile/validtypes_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestValidType(t *testing.T) { @@ -19,7 +19,9 @@ func TestValidType(t *testing.T) { }, nil } - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("fields with differing cases can be distinguished", func(t *testing.T) { var resp struct { diff --git a/codegen/testserver/singlefile/variadic_test.go b/codegen/testserver/singlefile/variadic_test.go index eba02a2db7..eb05c12fa0 100644 --- a/codegen/testserver/singlefile/variadic_test.go +++ b/codegen/testserver/singlefile/variadic_test.go @@ -4,10 +4,10 @@ import ( "context" "testing" - "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" + "github.com/stretchr/testify/require" ) func TestVariadic(t *testing.T) { @@ -15,9 +15,9 @@ func TestVariadic(t *testing.T) { resolver.QueryResolver.VariadicModel = func(ctx context.Context) (*VariadicModel, error) { return &VariadicModel{}, nil } - c := client.New(handler.NewDefaultServer( - NewExecutableSchema(Config{Resolvers: resolver}), - )) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolver})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) var resp struct { VariadicModel struct { diff --git a/codegen/testserver/singlefile/wrapped_type_test.go b/codegen/testserver/singlefile/wrapped_type_test.go index 98ffaa3a7c..ee48194ad5 100644 --- a/codegen/testserver/singlefile/wrapped_type_test.go +++ b/codegen/testserver/singlefile/wrapped_type_test.go @@ -4,17 +4,20 @@ import ( "context" "testing" + "github.com/99designs/gqlgen/client" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" - "github.com/99designs/gqlgen/client" "github.com/99designs/gqlgen/codegen/testserver/singlefile/otherpkg" - "github.com/99designs/gqlgen/graphql/handler" ) func TestWrappedTypes(t *testing.T) { resolvers := &Stub{} - c := client.New(handler.NewDefaultServer(NewExecutableSchema(Config{Resolvers: resolvers}))) + srv := handler.New(NewExecutableSchema(Config{Resolvers: resolvers})) + srv.AddTransport(transport.POST{}) + c := client.New(srv) resolvers.QueryResolver.WrappedScalar = func(ctx context.Context) (scalar WrappedScalar, e error) { return "hello", nil diff --git a/docs/content/recipes/authentication.md b/docs/content/recipes/authentication.md index 5b90b4ca7c..2c0321960f 100644 --- a/docs/content/recipes/authentication.md +++ b/docs/content/recipes/authentication.md @@ -79,6 +79,7 @@ import ( "github.com/99designs/gqlgen/_examples/starwars" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" "github.com/go-chi/chi" ) @@ -88,7 +89,8 @@ func main() { router.Use(auth.Middleware(db)) - srv := handler.NewDefaultServer(starwars.NewExecutableSchema(starwars.NewResolver())) + srv := handler.New(starwars.NewExecutableSchema(starwars.NewResolver())) + srv.AddTransport(transport.POST{}) router.Handle("/", playground.Handler("Starwars", "/query")) router.Handle("/query", srv) @@ -116,8 +118,8 @@ func (r *queryResolver) Hero(ctx context.Context, episode Episode) (Character, e ### Websockets -If you need access to the websocket init payload you can add your `InitFunc` in `AddTransport`. -Your InitFunc implementation could then attempt to extract items from the payload: +If you need access to the websocket init payload you can add your `InitFunc` in `AddTransport`. +Your InitFunc implementation could then attempt to extract items from the payload: ```go package main @@ -177,7 +179,6 @@ func main() { }) srv := handler.New(generated.NewExecutableSchema(generated.Config{Resolvers: &graph.Resolver{}})) - srv.AddTransport(transport.POST{}) srv.AddTransport(transport.Websocket{ KeepAlivePingInterval: 10 * time.Second, Upgrader: websocket.Upgrader{ @@ -189,6 +190,7 @@ func main() { return webSocketInit(ctx, initPayload) }, }) + srv.AddTransport(transport.POST{}) srv.Use(extension.Introspection{}) router.Handle("/", playground.Handler("My GraphQL App", "/app")) diff --git a/docs/content/recipes/cors.md b/docs/content/recipes/cors.md index 1c20562366..9542b82c41 100644 --- a/docs/content/recipes/cors.md +++ b/docs/content/recipes/cors.md @@ -38,7 +38,9 @@ func main() { }).Handler) - srv := handler.NewDefaultServer(starwars.NewExecutableSchema(starwars.NewResolver())) + srv := handler.New(starwars.NewExecutableSchema(starwars.NewResolver())) + + // Handle cross-origin checks in for websocket upgrade requests: srv.AddTransport(&transport.Websocket{ Upgrader: websocket.Upgrader{ CheckOrigin: func(r *http.Request) bool { @@ -49,6 +51,7 @@ func main() { WriteBufferSize: 1024, }, }) + srv.AddTransport(transport.POST{}) router.Handle("/", playground.Handler("Starwars", "/query")) router.Handle("/query", srv) diff --git a/docs/content/recipes/gin.md b/docs/content/recipes/gin.md index 7780401acd..1d3cf4aa0f 100644 --- a/docs/content/recipes/gin.md +++ b/docs/content/recipes/gin.md @@ -12,6 +12,7 @@ Gin is an excellent alternative for the `net/http` router. From their official [ Here are the steps to setup Gin and gqlgen together: Install Gin: + ```bash $ go get github.com/gin-gonic/gin ``` @@ -22,8 +23,12 @@ In your router file, define the handlers for the GraphQL and Playground endpoint import ( "github.com/[username]/gqlgen-todos/graph" // Replace username with your github username "github.com/gin-gonic/gin" + "github.com/vektah/gqlparser/v2/ast" "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/extension" + "github.com/99designs/gqlgen/graphql/handler/lru" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" ) @@ -31,7 +36,19 @@ import ( func graphqlHandler() gin.HandlerFunc { // NewExecutableSchema and Config are in the generated.go file // Resolver is in the resolver.go file - h := handler.NewDefaultServer(graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}})) + h := handler.New(graph.NewExecutableSchema(graph.Config{Resolvers: &graph.Resolver{}})) + + // Server setup: + srv.AddTransport(transport.Options{}) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + + srv.SetQueryCache(lru.New[*ast.QueryDocument](1000)) + + srv.Use(extension.Introspection{}) + srv.Use(extension.AutomaticPersistedQuery{ + Cache: lru.New[string](100), + }) return func(c *gin.Context) { h.ServeHTTP(c.Writer, c.Request) @@ -58,9 +75,11 @@ func main() { ``` ## Accessing gin.Context + At the Resolver level, `gqlgen` gives you access to the `context.Context` object. One way to access the `gin.Context` is to add it to the context and retrieve it again. First, create a `gin` middleware to add its context to the `context.Context`: + ```go func GinContextToContextMiddleware() gin.HandlerFunc { return func(c *gin.Context) { @@ -72,11 +91,13 @@ func GinContextToContextMiddleware() gin.HandlerFunc { ``` In the router definition, use the middleware: + ```go r.Use(GinContextToContextMiddleware()) ``` Define a function to recover the `gin.Context` from the `context.Context` struct: + ```go func GinContextFromContext(ctx context.Context) (*gin.Context, error) { ginContext := ctx.Value("GinContextKey") diff --git a/docs/content/recipes/migration-0.11.md b/docs/content/recipes/migration-0.11.md index 258f93ee68..96f08a38f0 100644 --- a/docs/content/recipes/migration-0.11.md +++ b/docs/content/recipes/migration-0.11.md @@ -104,13 +104,6 @@ srv.Use(extension.AutomaticPersistedQuery{ srv.Use(apollotracing.Tracer{}) ``` -### Default server - -We provide a set of default extensions and transports if you aren't ready to customize them yet. Simply: -```go -handler.NewDefaultServer(es) -``` - ### More consistent naming As part of cleaning up the names the RequestContext has been renamed to OperationContext, as there can be multiple created during the lifecycle of a request. A new ResponseContext has also been created and error handling has been moved here. This allows each response in a subscription to have its own errors. I'm not sure what bugs this might have been causing before... diff --git a/docs/content/recipes/subscriptions.md b/docs/content/recipes/subscriptions.md index 2884af4379..028ba744f0 100644 --- a/docs/content/recipes/subscriptions.md +++ b/docs/content/recipes/subscriptions.md @@ -16,20 +16,20 @@ to be careful to configure routing correctly. In this recipe you will learn how to -1. add WebSocket Transport to your server +1. add a WebSocket Transport to your server 2. add the `Subscription` type to your schema 3. implement a real-time resolver. -## Adding WebSocket Transport +## Adding a WebSocket Transport To send real-time data to clients, your GraphQL server needs to have an open connection with the client. This is done using WebSockets. -To add the WebSocket transport change your `main.go` by calling `AddTransport(&transport.Websocket{})` +To add the WebSocket transport change your `main.go` by calling `AddTransport(transport.Websocket{})` on your query handler. -**If you are using an external router, remember to send *ALL* `/query`-requests to your handler!** -**Not just POST requests!** +> If you are using an external router, remember to send *ALL* requests go to your handler (at `/query`), +> not just POST requests! ```go package main @@ -54,9 +54,12 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer(generated.NewExecutableSchema(generated.Config{Resolvers: &graph.Resolver{}})) + srv := handler.New(generated.NewExecutableSchema(generated.Config{Resolvers: &graph.Resolver{}})) - srv.AddTransport(&transport.Websocket{}) // <---- This is the important part! + srv.AddTransport(transport.Websocket{}) // Add WebSocket first. Here there is no config, see below for examples. + srv.AddTransport(transport.Options{}) // If you are using the playground, it's smart to add Options and GET. + srv.AddTransport(transport.GET{}) // ... + srv.AddTransport(transport.POST{}) // ... Make sure this is after the WebSocket transport! http.Handle("/", playground.Handler("GraphQL playground", "/query")) http.Handle("/query", srv) @@ -66,6 +69,57 @@ func main() { } ``` +## Configuring WebSockets + +The WebSocket transport is complex, and for any non-trivial application you will need to +configure it. The transport handles this configuration by setting fields on the `transport.Websocket` +struct. For an in-depth look at all configuration options, [explore the implementation][code]. + +At it's most basic, the transport uses [`github.com/gorilla/websocket`][gorilla] to implement +a WebSocket connection that sets up the subscription and then sends data to the client from +the Go channel returned by the resolver. The initial handshake and the structure of the data +payloads are defined by one of two protocols: `graphql-ws` or `graphql-transport-ws` Which +one is used is negotiated by the client, defaulting to [`graphql-ws`][graphql-ws]. + +A minimal WebSocket configuration will handle two basic things: keep-alives and security +checks that are normally handled by HTTP middleware that may not be available or compatible +with WebSockets: + +```go +srv.AddTransport(transport.Websocket{ + // Keep-alives are important for WebSockets to detect dead connections. This is + // not unlike asking a partner who seems to have zoned out while you tell them + // a story crucial to understanding the dynamics of your workplace: "Are you + // listening to me?" + // + // Failing to set a keep-alive interval can result in the connection being held + // open and the server expending resources to communicate with a client that has + // long since walked to the kitchen to make a sandwich instead. + KeepAlivePingInterval: 10 * time.Second, + + // The `github.com/gorilla/websocket.Upgrader` is used to handle the transition + // from an HTTP connection to a WebSocket connection. Among other options, here + // you must check the origin of the request to prevent cross-site request forgery + // attacks. + Upgrader: websocket.Upgrader{ + CheckOrigin: func(r *http.Request) bool { + // Allow exact match on host. + origin := r.Header.Get("Origin") + if origin == "" || origin == r.Header.Get("Host") { + return true + } + + // Match on allow-listed origins. + return slices.Contains([]string{":3000", "https://ui.mysite.com"}, origin) + }, + }, +}) +``` + +[code]: https://github.com/99designs/gqlgen/blob/master/graphql/handler/transport/websocket.go +[gorilla]: https://pkg.go.dev/github.com/gorilla/websocket +[graphql-ws]: https://github.com/enisdenjo/graphql-ws/blob/master/PROTOCOL.md + ## Adding Subscriptions to your Schema Next you'll have to define the subscriptions in your schema in the `Subscription` top-level type. @@ -144,9 +198,9 @@ func (r *subscriptionResolver) CurrentTime(ctx context.Context) (<-chan *model.T fmt.Println("Subscription Closed") // Handle deregistration of the channel here. `close(ch)` return // Remember to return to end the routine. - + case ch <- t: // This is the actual send. - // Our message went through, do nothing + // Our message went through, do nothing } } }() @@ -177,6 +231,7 @@ second. To gracefully stop the connection click the `Execute query` button again ## Adding Server-Sent Events transport + You can use instead of WebSocket (or in addition) [Server-Sent Events](https://en.wikipedia.org/wiki/Server-sent_events) as transport for subscriptions. This can have advantages and disadvantages over transport via WebSocket and requires a compatible client library, for instance [graphql-sse](https://github.com/enisdenjo/graphql-sse). The connection between @@ -184,25 +239,21 @@ server and client should be HTTP/2+. The client must send the subscription reque the header `accept: text/event-stream` and `content-type: application/json` in order to be accepted by the SSE transport. The underling protocol is documented at [distinct connections mode](https://github.com/enisdenjo/graphql-sse/blob/master/PROTOCOL.md). -Add the SSE transport as first of all other transports, as the order is important. For that reason, `New` instead of -`NewDefaultServer` will be used. +Add the SSE transport as first of all other transports, as the order is important. + ```go srv := handler.New(generated.NewExecutableSchema(generated.Config{Resolvers: &graph.Resolver{}})) -srv.AddTransport(transport.SSE{}) // <---- This is the important -// default server +srv.AddTransport(transport.SSE{}) // Add SSE first. + +// Continue server setup: srv.AddTransport(transport.Options{}) srv.AddTransport(transport.GET{}) srv.AddTransport(transport.POST{}) -srv.AddTransport(transport.MultipartForm{}) -srv.SetQueryCache(lru.New(1000)) -srv.Use(extension.Introspection{}) -srv.Use(extension.AutomaticPersistedQuery{ - Cache: lru.New(100), -}) ``` The GraphQL playground does not support SSE yet. You can try out the subscription via curl: + ```bash curl -N --request POST --url http://localhost:8080/query \ --data '{"query":"subscription { currentTime { unixTime timeStamp } }"}' \ @@ -224,7 +275,10 @@ import ( "log" "net/http" "os" + "slices" + "time" + "github.com/gorilla/websocket" "github.com/99designs/gqlgen/graphql/handler" "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" @@ -240,9 +294,27 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer(generated.NewExecutableSchema(generated.Config{Resolvers: &graph.Resolver{}})) - - srv.AddTransport(&transport.Websocket{}) + srv := handler.New( + generated.NewExecutableSchema( + generated.Config{Resolvers: &graph.Resolver{}}, + ), + ) + srv.AddTransport(transport.SSE{}) + srv.AddTransport(transport.Websocket{ + KeepAlivePingInterval: 10 * time.Second, + Upgrader: websocket.Upgrader{ + CheckOrigin: func(r *http.Request) bool { + origin := r.Header.Get("Origin") + if origin == "" || origin == r.Header.Get("Host") { + return true + } + return slices.Contains([]string{":3000", "https://ui.mysite.com"}, origin) + }, + }, + }) + srv.AddTransport(transport.Options{}) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) http.Handle("/", playground.Handler("GraphQL playground", "/query")) http.Handle("/query", srv) @@ -312,10 +384,10 @@ func (r *subscriptionResolver) CurrentTime(ctx context.Context) (<-chan *model.T select { case <-ctx.Done(): - // Exit on cancellation + // Exit on cancellation fmt.Println("Subscription closed.") return - + case ch <- t: // Our message went through, do nothing } diff --git a/docs/content/reference/complexity.md b/docs/content/reference/complexity.md index 8086cc0173..4514ca0e02 100644 --- a/docs/content/reference/complexity.md +++ b/docs/content/reference/complexity.md @@ -49,8 +49,11 @@ Limiting query complexity is as simple as specifying it with the provided extens func main() { c := Config{ Resolvers: &resolvers{} } - srv := handler.NewDefaultServer(blog.NewExecutableSchema(c)) + srv := handler.New(blog.NewExecutableSchema(c)) + // Server setup... + srv.Use(extension.FixedComplexityLimit(5)) // This line is key + r.Handle("/query", srv) } ``` @@ -73,7 +76,8 @@ func main() { c.Complexity.Query.Posts = countComplexity c.Complexity.Post.Related = countComplexity - srv := handler.NewDefaultServer(blog.NewExecutableSchema(c)) + srv := handler.New(blog.NewExecutableSchema(c)) + srv.AddTransport(transport.POST{}) srv.Use(extension.FixedComplexityLimit(5)) http.Handle("/query", gqlHandler) } diff --git a/docs/content/reference/dataloaders.md b/docs/content/reference/dataloaders.md index 2df6614ed4..8e62e16c80 100644 --- a/docs/content/reference/dataloaders.md +++ b/docs/content/reference/dataloaders.md @@ -168,10 +168,13 @@ func GetUsers(ctx context.Context, userIDs []string) ([]*model.User, error) { Add the dataloader middleware to your server... ```go // create the query handler -var srv http.Handler = handler.NewDefaultServer(generated.NewExecutableSchema(...)) +h := handler.New(generated.NewExecutableSchema(...)) +h.AddTransport(transport.POST{}) + // wrap the query handler with middleware to inject dataloader in requests. // pass in your dataloader dependencies, in this case the db connection. -srv = loaders.Middleware(db, srv) +srv = loaders.Middleware(db, h) + // register the wrapped handler http.Handle("/query", srv) ``` diff --git a/docs/content/reference/directives.md b/docs/content/reference/directives.md index 0343860f02..6891a0a0d8 100644 --- a/docs/content/reference/directives.md +++ b/docs/content/reference/directives.md @@ -51,12 +51,23 @@ The arguments are: ## Implement the directive Now we must implement the directive. The directive function is assigned to the Config object before registering the GraphQL handler. + ```go package main +import ( + "context" + "log" + "net/http" + + "github.com/99designs/gqlgen/graphql" + "github.com/99designs/gqlgen/graphql/handler" + "github.com/99designs/gqlgen/graphql/handler/transport" +) + func main() { - c := generated.Config{ Resolvers: &resolvers{} } - c.Directives.HasRole = func(ctx context.Context, obj interface{}, next graphql.Resolver, role model.Role) (interface{}, error) { + c := Config{ Resolvers: &resolvers{} } + c.Directives.HasRole = func(ctx context.Context, obj interface{}, next graphql.Resolver, role Role) (interface{}, error) { if !getCurrentUser(ctx).HasRole(role) { // block calling the next resolver return nil, fmt.Errorf("Access denied") @@ -66,7 +77,10 @@ func main() { return next(ctx) } - http.Handle("/query", handler.NewDefaultServer(generated.NewExecutableSchema(c), )) + srv := handler.New(NewExecutableSchema(c)) + srv.AddTransport(transport.POST{}) + + http.Handle("/query", srv) log.Fatal(http.ListenAndServe(":8081", nil)) } ``` diff --git a/docs/content/reference/errors.md b/docs/content/reference/errors.md index 1a11fe9c23..41ba1fd573 100644 --- a/docs/content/reference/errors.md +++ b/docs/content/reference/errors.md @@ -137,7 +137,10 @@ import ( ) func main() { - server := handler.NewDefaultServer(MakeExecutableSchema(resolvers)) + server := handler.New(MakeExecutableSchema(resolvers)) + + // Server setup... + server.SetErrorPresenter(func(ctx context.Context, e error) *gqlerror.Error { err := graphql.DefaultErrorPresenter(ctx, e) @@ -164,9 +167,12 @@ returned from here will also go through the error presenter. You change this when creating the server: ```go -server := handler.NewDefaultServer(MakeExecutableSchema(resolvers)) +server := handler.New(MakeExecutableSchema(resolvers)) + +// Server setup... + server.SetRecoverFunc(func(ctx context.Context, err interface{}) error { - // notify bug tracker... + // Notify bug tracker... return gqlerror.Errorf("Internal server error!") }) diff --git a/docs/content/reference/introspection.md b/docs/content/reference/introspection.md index bd1dcfba90..a89b2ac62f 100644 --- a/docs/content/reference/introspection.md +++ b/docs/content/reference/introspection.md @@ -1,21 +1,34 @@ --- -title: 'Disabling introspection' -description: Prevent users from introspecting schemas in production. +title: 'Enabling introspection' +description: Allow users to introspect schemas. linkTitle: Introspection menu: { main: { parent: 'reference', weight: 10 } } --- -One of the best features of GraphQL is it's powerful discoverability and its is automatically included when using `NewDefaultServer`. +One of the best features of GraphQL is it's powerful discoverability, known as [introspection][introspection]. Introspection allows clients to query the server's schema about itself, and is the foundation of many tools like GraphiQL and Apollo Studio. -## Disable introspection for the whole server +## Enabling introspection + +To enable introspection for the whole server, you use the bundled middleware extension `github.com/99designs/gqlgen/graphql/handler/extension.Introspection`: -To opt out of introspection globally you should build your own server with only the features you use. For example a simple server that only does POST, and only has introspection in dev could look like: ```go srv := handler.New(es) +// Add server setup. srv.AddTransport(transport.Options{}) srv.AddTransport(transport.POST{}) +// Add the introspection middleware. +srv.Use(extension.Introspection{}) +``` + +To opt in to introspection for certain environments, you can just guard the middleware with an environment variable: + +```go +srv := handler.New(es) + +// Server setup... + if os.Getenv("ENVIRONMENT") == "development" { srv.Use(extension.Introspection{}) } @@ -23,10 +36,14 @@ if os.Getenv("ENVIRONMENT") == "development" { ## Disabling introspection based on authentication -Introspection can also be enabled on a per-request context basis. For example, you could modify it in a middleware based on user authentication: +Introspection can also be guarded on a per-request context basis. For example, you can disable it in a middleware based on user authentication: ```go -srv := handler.NewDefaultServer(es) +srv := handler.New(es) + +// Server setup... + +srv.Use(extension.Introspection{}) srv.AroundOperations(func(ctx context.Context, next graphql.OperationHandler) graphql.ResponseHandler { if !userForContext(ctx).IsAdmin { graphql.GetOperationContext(ctx).DisableIntrospection = true @@ -35,3 +52,5 @@ srv.AroundOperations(func(ctx context.Context, next graphql.OperationHandler) gr return next(ctx) }) ``` + +[introspection]: https://graphql.org/learn/introspection/ diff --git a/graphql/handler/server.go b/graphql/handler/server.go index 644bad8d99..f186bb49ad 100644 --- a/graphql/handler/server.go +++ b/graphql/handler/server.go @@ -31,6 +31,21 @@ func New(es graphql.ExecutableSchema) *Server { } } +// NewDefaultServer is a demonstration only. Not for prod. +// +// Currently, the server just picks the first available transport, +// so this example NewDefaultServer orders them, but it is just +// for demonstration purposes. +// You will likely want to tune and better configure Websocket transport +// since adding a new one (To configure it) doesn't have effect. +// +// Also SSE support is not in here at all! +// SSE when used over HTTP/1.1 (but not HTTP/2 or HTTP/3), +// SSE suffers from a severe limitation to the maximum number +// of open connections of 6 per browser. See: +// https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#sect1 +// +// Deprecated: This was and is just an example. func NewDefaultServer(es graphql.ExecutableSchema) *Server { srv := New(es) diff --git a/plugin/federation/federation_computedrequires_test.go b/plugin/federation/federation_computedrequires_test.go index 369fb3b64e..3d91527301 100644 --- a/plugin/federation/federation_computedrequires_test.go +++ b/plugin/federation/federation_computedrequires_test.go @@ -4,6 +4,7 @@ package federation import ( "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -13,11 +14,13 @@ import ( ) func TestComputedRequires(t *testing.T) { - c := client.New(handler.NewDefaultServer( + srv := handler.New( generated.NewExecutableSchema(generated.Config{ Resolvers: &computedrequires.Resolver{}, }), - )) + ) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("PlanetRequires entities with requires directive", func(t *testing.T) { representations := []map[string]any{ @@ -134,11 +137,13 @@ func TestComputedRequires(t *testing.T) { } func TestMultiComputedRequires(t *testing.T) { - c := client.New(handler.NewDefaultServer( + srv := handler.New( generated.NewExecutableSchema(generated.Config{ Resolvers: &computedrequires.Resolver{}, }), - )) + ) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("MultiHelloRequires entities with requires directive", func(t *testing.T) { representations := []map[string]any{ diff --git a/plugin/federation/federation_entityresolver_test.go b/plugin/federation/federation_entityresolver_test.go index e4b3949d43..a4e973bd12 100644 --- a/plugin/federation/federation_entityresolver_test.go +++ b/plugin/federation/federation_entityresolver_test.go @@ -7,6 +7,7 @@ import ( "strings" "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -16,11 +17,13 @@ import ( ) func TestEntityResolver(t *testing.T) { - c := client.New(handler.NewDefaultServer( + srv := handler.New( generated.NewExecutableSchema(generated.Config{ Resolvers: &entityresolver.Resolver{}, }), - )) + ) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("Hello entities", func(t *testing.T) { representations := []map[string]any{ @@ -391,11 +394,13 @@ func TestEntityResolver(t *testing.T) { } func TestMultiEntityResolver(t *testing.T) { - c := client.New(handler.NewDefaultServer( + srv := handler.New( generated.NewExecutableSchema(generated.Config{ Resolvers: &entityresolver.Resolver{}, }), - )) + ) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("MultiHello entities", func(t *testing.T) { itemCount := 10 diff --git a/plugin/federation/federation_explicitrequires_test.go b/plugin/federation/federation_explicitrequires_test.go index b699655343..7ca250859d 100644 --- a/plugin/federation/federation_explicitrequires_test.go +++ b/plugin/federation/federation_explicitrequires_test.go @@ -4,6 +4,7 @@ package federation import ( "testing" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/stretchr/testify/require" "github.com/99designs/gqlgen/client" @@ -13,11 +14,13 @@ import ( ) func TestExplicitRequires(t *testing.T) { - c := client.New(handler.NewDefaultServer( + srv := handler.New( generated.NewExecutableSchema(generated.Config{ Resolvers: &explicitrequires.Resolver{}, }), - )) + ) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("PlanetRequires entities with requires directive", func(t *testing.T) { representations := []map[string]any{ @@ -137,11 +140,13 @@ func TestExplicitRequires(t *testing.T) { } func TestMultiExplicitRequires(t *testing.T) { - c := client.New(handler.NewDefaultServer( + srv := handler.New( generated.NewExecutableSchema(generated.Config{ Resolvers: &explicitrequires.Resolver{}, }), - )) + ) + srv.AddTransport(transport.POST{}) + c := client.New(srv) t.Run("MultiHelloRequires entities with requires directive", func(t *testing.T) { representations := []map[string]any{ diff --git a/plugin/federation/testdata/computedrequires/main/server.go b/plugin/federation/testdata/computedrequires/main/server.go index d714c71911..815ec65416 100644 --- a/plugin/federation/testdata/computedrequires/main/server.go +++ b/plugin/federation/testdata/computedrequires/main/server.go @@ -7,6 +7,7 @@ import ( "github.com/99designs/gqlgen/graphql/handler" "github.com/99designs/gqlgen/graphql/handler/debug" + "github.com/99designs/gqlgen/graphql/handler/transport" "github.com/99designs/gqlgen/graphql/playground" "github.com/99designs/gqlgen/plugin/federation/testdata/computedrequires" "github.com/99designs/gqlgen/plugin/federation/testdata/computedrequires/generated" @@ -20,7 +21,11 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer(generated.NewExecutableSchema(generated.Config{Resolvers: &computedrequires.Resolver{}})) + srv := handler.New( + generated.NewExecutableSchema(generated.Config{Resolvers: &computedrequires.Resolver{}}), + ) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) srv.Use(&debug.Tracer{}) http.Handle("/", playground.Handler("GraphQL playground", "/query")) diff --git a/plugin/resolvergen/testdata/filetemplate/out/schema.custom.go b/plugin/resolvergen/testdata/filetemplate/out/schema.custom.go index caed384f58..166fc59f3b 100644 --- a/plugin/resolvergen/testdata/filetemplate/out/schema.custom.go +++ b/plugin/resolvergen/testdata/filetemplate/out/schema.custom.go @@ -33,12 +33,6 @@ func (r *CustomResolverType) Resolver() customresolver.ResolverResolver { type queryCustomResolverType struct{ *CustomResolverType } type resolverCustomResolverType struct{ *CustomResolverType } -// !!! WARNING !!! -// The code below was going to be deleted when updating resolvers. It has been copied here so you have -// one last chance to move it out of harms way if you want. There are two reasons this happens: -// - When renaming or deleting a resolver the old code will be put in here. You can safely delete -// it when you're done. -// - You have helper methods in this file. Move them out to keep these resolver files clean. func AUserHelperFunction() { // AUserHelperFunction implementation } diff --git a/plugin/resolvergen/testdata/followschema/out/schema.resolvers.go b/plugin/resolvergen/testdata/followschema/out/schema.resolvers.go index 1efcef81c4..27661bed71 100644 --- a/plugin/resolvergen/testdata/followschema/out/schema.resolvers.go +++ b/plugin/resolvergen/testdata/followschema/out/schema.resolvers.go @@ -33,12 +33,6 @@ func (r *CustomResolverType) Resolver() customresolver.ResolverResolver { type queryCustomResolverType struct{ *CustomResolverType } type resolverCustomResolverType struct{ *CustomResolverType } -// !!! WARNING !!! -// The code below was going to be deleted when updating resolvers. It has been copied here so you have -// one last chance to move it out of harms way if you want. There are two reasons this happens: -// - When renaming or deleting a resolver the old code will be put in here. You can safely delete -// it when you're done. -// - You have helper methods in this file. Move them out to keep these resolver files clean. func AUserHelperFunction() { // AUserHelperFunction implementation } diff --git a/plugin/servergen/server.gotpl b/plugin/servergen/server.gotpl index a3ae2a877a..eda7863ce7 100644 --- a/plugin/servergen/server.gotpl +++ b/plugin/servergen/server.gotpl @@ -2,8 +2,12 @@ {{ reserveImport "log" }} {{ reserveImport "net/http" }} {{ reserveImport "os" }} +{{ reserveImport "github.com/vektah/gqlparser/v2/ast" }} {{ reserveImport "github.com/99designs/gqlgen/graphql/playground" }} {{ reserveImport "github.com/99designs/gqlgen/graphql/handler" }} +{{ reserveImport "github.com/99designs/gqlgen/graphql/handler/extension" }} +{{ reserveImport "github.com/99designs/gqlgen/graphql/handler/lru" }} +{{ reserveImport "github.com/99designs/gqlgen/graphql/handler/transport" }} const defaultPort = "8080" @@ -13,7 +17,18 @@ func main() { port = defaultPort } - srv := handler.NewDefaultServer({{ lookupImport .ExecPackageName }}.NewExecutableSchema({{ lookupImport .ExecPackageName}}.Config{Resolvers: &{{ lookupImport .ResolverPackageName}}.Resolver{}})) + srv := handler.New({{ lookupImport .ExecPackageName }}.NewExecutableSchema({{ lookupImport .ExecPackageName}}.Config{Resolvers: &{{ lookupImport .ResolverPackageName}}.Resolver{}})) + + srv.AddTransport(transport.Options{}) + srv.AddTransport(transport.GET{}) + srv.AddTransport(transport.POST{}) + + srv.SetQueryCache(lru.New[*ast.QueryDocument](1000)) + + srv.Use(extension.Introspection{}) + srv.Use(extension.AutomaticPersistedQuery{ + Cache: lru.New[string](100), + }) http.Handle("/", playground.Handler("GraphQL playground", "/query")) http.Handle("/query", srv)