Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Deprecate apollo-server-testing; allow ASTs for executeOperation #5238

Merged
merged 1 commit into from
May 25, 2021

Conversation

glasser
Copy link
Member

@glasser glasser commented May 25, 2021

The apollo-server-testing package exports one small function which is
just a tiny wrapper around server.executeOperation. The one main
advantage it provides is that you can pass in operations as ASTs rather
than only as strings.

This extra layer doesn't add much value but does require us to update
things in two places (which cross a package barrier and thus can be
installed at skewed versions). So for example when adding the second
argument to executeOperation in #4166 I did not bother to add it to
apollo-server-testing too. We've also found that users have been
confused by the createTestClient API (eg #5111) and that some linters
get confused by the unbound methods it returns (#4724).

So the simplest thing is to just teach people how to use the real
ApolloServer method instead of an unrelated API.

This PR allows you to pass an AST to server.executeOperation (just
like with the apollo-server-testing API), and changes the docs to
recommend executeOperation instead of apollo-server-testing. It also
makes some other suggestions about how to test Apollo Server code in a
more end-to-end fashion, and adds some basic tests for
executeOperation.

Fixes #4952.

The `apollo-server-testing` package exports one small function which is
just a tiny wrapper around `server.executeOperation`. The one main
advantage it provides is that you can pass in operations as ASTs rather
than only as strings.

This extra layer doesn't add much value but does require us to update
things in two places (which cross a package barrier and thus can be
installed at skewed versions). So for example when adding the second
argument to `executeOperation` in #4166 I did not bother to add it to
`apollo-server-testing` too. We've also found that users have been
confused by the `createTestClient` API (eg #5111) and that some linters
get confused by the unbound methods it returns (#4724).

So the simplest thing is to just teach people how to use the real
`ApolloServer` method instead of an unrelated API.

This PR allows you to pass an AST to `server.executeOperation` (just
like with the `apollo-server-testing` API), and changes the docs to
recommend `executeOperation` instead of `apollo-server-testing`. It also
makes some other suggestions about how to test Apollo Server code in a
more end-to-end fashion, and adds some basic tests for
`executeOperation`.

Fixes #4952.
@glasser glasser merged commit cd779db into main May 25, 2021
@glasser glasser deleted the glasser/no-apollo-server-testing branch May 25, 2021 18:56
glasser added a commit that referenced this pull request May 25, 2021
This was deprecated on main in #5238.
glasser added a commit that referenced this pull request May 25, 2021
This was deprecated on main in #5238.
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Apr 21, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Consider removing apollo-server-testing
1 participant