-
Notifications
You must be signed in to change notification settings - Fork 273
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
connectors: add warnings when using plugins
This commit adds a few informative warnings when using connectors with certain plugins which are currently incompatible. These warnings should better inform router operators of certain features which aren't yet supported when used in tandem with connectors.
- Loading branch information
1 parent
affe462
commit 1cadd00
Showing
5 changed files
with
343 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
33 changes: 33 additions & 0 deletions
33
apollo-router/tests/fixtures/connectors/incompatible.router.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
# A valid router configuration with every incompatible | ||
# router feature turned on for testing warnings. | ||
|
||
apq: | ||
subgraph: | ||
subgraphs: | ||
connectors: | ||
enabled: true | ||
coprocessor: | ||
url: http://127.0.0.1:8081 | ||
subgraph: | ||
all: | ||
request: | ||
headers: true | ||
headers: | ||
all: | ||
request: | ||
- propagate: | ||
matching: ^upstream-header-.* | ||
- remove: | ||
named: "x-legacy-account-id" | ||
telemetry: | ||
apollo: | ||
errors: | ||
subgraph: | ||
all: | ||
send: true | ||
redact: false | ||
traffic_shaping: | ||
subgraphs: | ||
connectors: | ||
deduplicate_query: false | ||
compression: gzip |
158 changes: 158 additions & 0 deletions
158
apollo-router/tests/fixtures/connectors/quickstart.graphql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,158 @@ | ||
schema | ||
@link(url: "https://specs.apollo.dev/link/v1.0") | ||
@link(url: "https://specs.apollo.dev/join/v0.5", for: EXECUTION) | ||
@link(url: "https://specs.apollo.dev/connect/v0.1", for: EXECUTION) | ||
@join__directive( | ||
graphs: [CONNECTORS] | ||
name: "link" | ||
args: { | ||
url: "https://specs.apollo.dev/connect/v0.1" | ||
import: ["@connect", "@source"] | ||
} | ||
) | ||
@join__directive( | ||
graphs: [CONNECTORS] | ||
name: "source" | ||
args: { | ||
name: "jsonPlaceholder" | ||
http: { baseURL: "https://jsonplaceholder.typicode.com/" } | ||
} | ||
) { | ||
query: Query | ||
} | ||
|
||
directive @join__directive( | ||
graphs: [join__Graph!] | ||
name: String! | ||
args: join__DirectiveArguments | ||
) repeatable on SCHEMA | OBJECT | INTERFACE | FIELD_DEFINITION | ||
|
||
directive @join__enumValue(graph: join__Graph!) repeatable on ENUM_VALUE | ||
|
||
directive @join__field( | ||
graph: join__Graph | ||
requires: join__FieldSet | ||
provides: join__FieldSet | ||
type: String | ||
external: Boolean | ||
override: String | ||
usedOverridden: Boolean | ||
overrideLabel: String | ||
contextArguments: [join__ContextArgument!] | ||
) repeatable on FIELD_DEFINITION | INPUT_FIELD_DEFINITION | ||
|
||
directive @join__graph(name: String!, url: String!) on ENUM_VALUE | ||
|
||
directive @join__implements( | ||
graph: join__Graph! | ||
interface: String! | ||
) repeatable on OBJECT | INTERFACE | ||
|
||
directive @join__type( | ||
graph: join__Graph! | ||
key: join__FieldSet | ||
extension: Boolean! = false | ||
resolvable: Boolean! = true | ||
isInterfaceObject: Boolean! = false | ||
) repeatable on OBJECT | INTERFACE | UNION | ENUM | INPUT_OBJECT | SCALAR | ||
|
||
directive @join__unionMember( | ||
graph: join__Graph! | ||
member: String! | ||
) repeatable on UNION | ||
|
||
directive @link( | ||
url: String | ||
as: String | ||
for: link__Purpose | ||
import: [link__Import] | ||
) repeatable on SCHEMA | ||
|
||
input join__ContextArgument { | ||
name: String! | ||
type: String! | ||
context: String! | ||
selection: join__FieldValue! | ||
} | ||
|
||
scalar join__DirectiveArguments | ||
|
||
scalar join__FieldSet | ||
|
||
scalar join__FieldValue | ||
|
||
enum join__Graph { | ||
CONNECTORS @join__graph(name: "connectors", url: "none") | ||
} | ||
|
||
scalar link__Import | ||
|
||
enum link__Purpose { | ||
""" | ||
`SECURITY` features provide metadata necessary to securely resolve fields. | ||
""" | ||
SECURITY | ||
|
||
""" | ||
`EXECUTION` features provide metadata necessary for operation execution. | ||
""" | ||
EXECUTION | ||
} | ||
|
||
type Post @join__type(graph: CONNECTORS) { | ||
id: ID! | ||
body: String | ||
title: String | ||
author: User | ||
} | ||
|
||
type Query @join__type(graph: CONNECTORS) { | ||
posts: [Post] | ||
@join__directive( | ||
graphs: [CONNECTORS] | ||
name: "connect" | ||
args: { | ||
source: "jsonPlaceholder" | ||
http: { GET: "/posts" } | ||
selection: "id\ntitle\nbody\nauthor: { id: userId }" | ||
} | ||
) | ||
post(id: ID!): Post | ||
@join__directive( | ||
graphs: [CONNECTORS] | ||
name: "connect" | ||
args: { | ||
source: "jsonPlaceholder" | ||
http: { GET: "/posts/{$args.id}" } | ||
selection: "id\ntitle\nbody\nauthor: { id: userId }" | ||
entity: true | ||
} | ||
) | ||
user(id: ID!): User | ||
@join__directive( | ||
graphs: [CONNECTORS] | ||
name: "connect" | ||
args: { | ||
source: "jsonPlaceholder" | ||
http: { GET: "/users/{$args.id}" } | ||
selection: "id\nname\nusername" | ||
entity: true | ||
} | ||
) | ||
} | ||
|
||
type User @join__type(graph: CONNECTORS) { | ||
id: ID! | ||
name: String | ||
username: String | ||
posts: [Post] | ||
@join__directive( | ||
graphs: [CONNECTORS] | ||
name: "connect" | ||
args: { | ||
source: "jsonPlaceholder" | ||
http: { GET: "/users/{$this.id}/posts" } | ||
selection: "id\ntitle\nbody" | ||
} | ||
) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
use std::path::PathBuf; | ||
|
||
use tower::BoxError; | ||
|
||
use crate::integration::IntegrationTest; | ||
|
||
const INCOMPATIBLE_PLUGINS_CONFIG: &str = | ||
include_str!("../fixtures/connectors/incompatible.router.yaml"); | ||
|
||
#[tokio::test(flavor = "multi_thread")] | ||
async fn test_incompatible_plugin_warnings() -> Result<(), BoxError> { | ||
// Ensure that we have the test keys before running | ||
// Note: The [IntegrationTest] ensures that these test credentials get | ||
// set before running the router. | ||
if std::env::var("TEST_APOLLO_KEY").is_err() || std::env::var("TEST_APOLLO_GRAPH_REF").is_err() | ||
{ | ||
return Ok(()); | ||
}; | ||
|
||
let mut router = IntegrationTest::builder() | ||
.config(INCOMPATIBLE_PLUGINS_CONFIG) | ||
.supergraph(PathBuf::from_iter([ | ||
"tests", | ||
"fixtures", | ||
"connectors", | ||
"quickstart.graphql", | ||
])) | ||
.build() | ||
.await; | ||
|
||
router.start().await; | ||
|
||
// Make sure that we have the warnings we expect | ||
let plugins = ["coprocessor", "headers", "telemetry", "traffic_shaping"]; | ||
for plugin in plugins { | ||
let msg = format!("plugin `{plugin}` is enabled for connector-enabled subgraphs, which is not yet supported"); | ||
router.assert_log_contains(&msg).await; | ||
} | ||
|
||
Ok(()) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters