diff --git a/common/schema-builder/src/main/java/io/smallrye/graphql/schema/SchemaBuilder.java b/common/schema-builder/src/main/java/io/smallrye/graphql/schema/SchemaBuilder.java
index f9b382c24..4cc790c13 100644
--- a/common/schema-builder/src/main/java/io/smallrye/graphql/schema/SchemaBuilder.java
+++ b/common/schema-builder/src/main/java/io/smallrye/graphql/schema/SchemaBuilder.java
@@ -69,6 +69,8 @@ public class SchemaBuilder {
private final DirectiveTypeCreator directiveTypeCreator;
private final UnionCreator unionCreator;
+ private final DotName FEDERATION_ANNOTATIONS_PACKAGE = DotName.createSimple("io.smallrye.graphql.api.federation");
+
/**
* This builds the Schema from Jandex
*
@@ -160,7 +162,13 @@ private void addDirectiveTypes(Schema schema) {
// custom directives from annotations
for (AnnotationInstance annotationInstance : ScanningContext.getIndex().getAnnotations(DIRECTIVE)) {
ClassInfo classInfo = annotationInstance.target().asClass();
- schema.addDirectiveType(directiveTypeCreator.create(classInfo));
+ boolean federationEnabled = Boolean.getBoolean("smallrye.graphql.federation.enabled");
+ // only add federation-related directive types to the schema if federation is enabled
+ DotName packageName = classInfo.name().packagePrefixName();
+ if (packageName == null || !packageName.equals(FEDERATION_ANNOTATIONS_PACKAGE) || federationEnabled) {
+ schema.addDirectiveType(directiveTypeCreator.create(classInfo));
+ }
+
}
// bean validation directives
schema.addDirectiveType(BeanValidationDirectivesHelper.CONSTRAINT_DIRECTIVE_TYPE);
diff --git a/server/implementation/src/test/java/io/smallrye/graphql/schema/SchemaTest.java b/server/implementation/src/test/java/io/smallrye/graphql/schema/SchemaTest.java
index becceb117..11bfd425f 100644
--- a/server/implementation/src/test/java/io/smallrye/graphql/schema/SchemaTest.java
+++ b/server/implementation/src/test/java/io/smallrye/graphql/schema/SchemaTest.java
@@ -130,7 +130,7 @@ void testSchemaWithFederationDisabled() {
" testTypeWithFederation(arg: String): TestTypeWithFederation\n" +
"}\n" +
"\n" +
- "type TestTypeWithFederation @key(fields : [\"id\"]) {\n" +
+ "type TestTypeWithFederation {\n" +
" id: String\n" +
"}\n");
}
@@ -138,26 +138,32 @@ void testSchemaWithFederationDisabled() {
@Test
void testSchemaWithFederation() {
config.federationEnabled = true;
- GraphQLSchema graphQLSchema = createGraphQLSchema(Directive.class, Key.class, TestTypeWithFederation.class,
- FederationTestApi.class);
-
- assertSchemaEndsWith(graphQLSchema, "\n" +
- "union _Entity = TestTypeWithFederation\n" +
- "\n" +
- "\"Query root\"\n" +
- "type Query {\n" +
- " _entities(representations: [_Any!]!): [_Entity]!\n" +
- " _service: _Service!\n" +
- " testTypeWithFederation(arg: String): TestTypeWithFederation\n" +
- "}\n" +
- "\n" +
- "type TestTypeWithFederation @key(fields : [\"id\"]) {\n" +
- " id: String\n" +
- "}\n" +
- "\n" +
- "type _Service {\n" +
- " sdl: String!\n" +
- "}\n");
+ // need to set it as system property because the SchemaBuilder doesn't have access to the Config object
+ System.setProperty("smallrye.graphql.federation.enabled", "true");
+ try {
+ GraphQLSchema graphQLSchema = createGraphQLSchema(Directive.class, Key.class, TestTypeWithFederation.class,
+ FederationTestApi.class);
+
+ assertSchemaEndsWith(graphQLSchema, "\n" +
+ "union _Entity = TestTypeWithFederation\n" +
+ "\n" +
+ "\"Query root\"\n" +
+ "type Query {\n" +
+ " _entities(representations: [_Any!]!): [_Entity]!\n" +
+ " _service: _Service!\n" +
+ " testTypeWithFederation(arg: String): TestTypeWithFederation\n" +
+ "}\n" +
+ "\n" +
+ "type TestTypeWithFederation @key(fields : [\"id\"]) {\n" +
+ " id: String\n" +
+ "}\n" +
+ "\n" +
+ "type _Service {\n" +
+ " sdl: String!\n" +
+ "}\n");
+ } finally {
+ System.clearProperty("smallrye.graphql.federation.enabled");
+ }
}
private GraphQLSchema createGraphQLSchema(Class>... api) {
diff --git a/server/tck/pom.xml b/server/tck/pom.xml
index e4c403f10..8c31d514a 100644
--- a/server/tck/pom.xml
+++ b/server/tck/pom.xml
@@ -130,6 +130,9 @@
testng.xml
+
+ true
+