From d5014050e3ed8c6ebbec557b87a15efc924df25f Mon Sep 17 00:00:00 2001 From: Robert Pospisil Date: Thu, 26 Oct 2023 14:26:55 +0200 Subject: [PATCH] Support non null types in batch resolver --- .../smallrye/graphql/bootstrap/FederationDataFetcher.java | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/server/implementation/src/main/java/io/smallrye/graphql/bootstrap/FederationDataFetcher.java b/server/implementation/src/main/java/io/smallrye/graphql/bootstrap/FederationDataFetcher.java index 91e5c794e..08b667e3e 100644 --- a/server/implementation/src/main/java/io/smallrye/graphql/bootstrap/FederationDataFetcher.java +++ b/server/implementation/src/main/java/io/smallrye/graphql/bootstrap/FederationDataFetcher.java @@ -19,6 +19,7 @@ import graphql.execution.Async; import graphql.execution.DataFetcherResult; +import graphql.language.NonNullType; import graphql.schema.DataFetcher; import graphql.schema.DataFetchingEnvironment; import graphql.schema.DelegatingDataFetchingEnvironment; @@ -27,8 +28,10 @@ import graphql.schema.GraphQLFieldDefinition; import graphql.schema.GraphQLList; import graphql.schema.GraphQLNamedSchemaElement; +import graphql.schema.GraphQLNonNull; import graphql.schema.GraphQLObjectType; import graphql.schema.GraphQLOutputType; +import graphql.schema.GraphQLType; import io.smallrye.graphql.spi.config.Config; class FederationDataFetcher implements DataFetcher>> { @@ -116,7 +119,10 @@ private boolean matchesReturnType(GraphQLFieldDefinition field, String typename) } private boolean matchesReturnTypeList(GraphQLFieldDefinition field, String typename) { - GraphQLOutputType listType = field.getType(); + GraphQLType listType = field.getType(); + if (listType instanceof GraphQLNonNull) { + listType = ((GraphQLNonNull) listType).getOriginalWrappedType(); + } if (listType instanceof GraphQLList) { var returnType = ((GraphQLList) listType).getOriginalWrappedType(); return returnType instanceof GraphQLNamedSchemaElement