Skip to content

Commit

Permalink
tests: Introduce test which demonstrates regression in #3627.
Browse files Browse the repository at this point in the history
  • Loading branch information
abernix committed Dec 26, 2019
1 parent 3faf7e8 commit 33c435e
Showing 1 changed file with 49 additions and 0 deletions.
49 changes: 49 additions & 0 deletions packages/apollo-server-integration-testsuite/src/ApolloServer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1084,6 +1084,55 @@ export function testApolloServer<AS extends ApolloServerBase>(
);
});

it("doesn't internal server error on an APQ", async () => {
await setupApolloServerAndFetchPair();

const TEST_STRING_QUERY = `
{ onlyForThisApqTest${
Math.random()
.toString()
.split('.')[1]
}: justAField }
`;
const hash = sha256
.create()
.update(TEST_STRING_QUERY)
.hex();

const result = await apolloFetch({
// @ts-ignore The `ApolloFetch` types don't allow `extensions` to be
// passed in, in the same way as `variables`, with a request. This
// is a typing omission in `apollo-fetch`, as can be seen here:
// https://git.io/Jeb63 This will all be going away soon (and
// that package is already archived and deprecated.
extensions: {
persistedQuery: {
version: VERSION,
sha256Hash: hash,
}
},
});

// Having a persisted query not found error is fine.
expect(result.errors).toContainEqual(
expect.objectContaining({
extensions: expect.objectContaining({
code: "PERSISTED_QUERY_NOT_FOUND",
})
})
);

// However, having an internal server error is not okay!
expect(result.errors).not.toContainEqual(
expect.objectContaining({
extensions: expect.objectContaining({
code: "INTERNAL_SERVER_ERROR",
})
})
);

});

describe('error munging', () => {
describe('rewriteError', () => {
it('new error', async () => {
Expand Down

0 comments on commit 33c435e

Please sign in to comment.