Awesome
supertest-graphql
<p> <a href="https://badge.fury.io/js/supertest-graphql"><img src="https://badge.fury.io/js/supertest-graphql.svg" alt="npm version" height="18"></a> <a href="#" target="_blank"> <img alt="License: ISC" src="https://img.shields.io/badge/License-ISC-yellow.svg" /> </a> <a href="https://github.com/intuit/auto"><img src="https://img.shields.io/badge/release-auto.svg?style=flat-square&colorA=888888&colorB=9B065A&label=auto&logo=" alt="Auto Release" /></a> </p>Extends supertest to test a GraphQL endpoint
Install
npm install supertest-graphql
Usage
import request from 'supertest-graphql'
import gql from 'graphql-tag'
test('should get pets', async () => {
const { data } = await request(app)
.query(gql`
query {
pets {
name
petType
}
}
`)
.expectNoErrors()
expect(data.pets).toHaveLength(2)
})
Set expectations
expectNoErrors
will verify that the API response has no errors
in
its result payload.
await request(app)
.query('blooop')
.expectNoErrors()
// expected no errors but got 1 error(s) in GraphQL response: Syntax Error: Unexpected Name "blooop".
Variables
const { data } = await request(app)
.query(gql`
query GetPets($first: Int){
pets(first: $first) {
name
petType
}
}
`)
.variables({ first: 4 })
Mutation
const { data } = await request(app)
.mutate(gql`
mutation PetAnimal($petId: ID!) {
petAnimal(petId: $petId) {
name
petType
}
}
`)
.variables({petId: 'my-cat' })
Subscriptions with WebScoket
import { supertestWs } from 'supertest-graphql'
import gql from 'graphql-tag'
// for websocket the server needs to be started and stopped manually
beForeEach(() => server.listen(0, "localhost"))
afterEach(() => server.close())
test('should get pets', async () => {
const sub = await supertestWs(app)
.subscribe(gql`
subscription {
newPetAdded {
name
petType
}
}
`)
// will wait or pop the next value
const { data } = await sub.next().expectNoErrors()
expect(data.newPetAdded.name).toEqual('Fifi')
})
Authentication
const { data } = await request(app)
.auth('username', 'password')
.query(...)
or via headers:
const { data } = await request(app)
.set('authorization', 'my token')
.query(...)
For WebSocket with connectionParams
:
import { supertestWs } from 'supertest-graphql'
const sub = await supertestWs(app)
.connectionParams({
token: 'my token'
})
.subscribe(...)
Change GraphQL endpoint path
By default, the execution are sent to /graphql
.
You can change this with .path()
:
const { data } = await request(app)
.path('/new-graphql')
.query(...)
Use WebSocket legacy protocol
import { supertestWs, LEGACY_WEBSOCKET_PROTOCOL } from 'supertest-graphql'
const sub = await supertestWs(app)
.protocol(LEGACY_WEBSOCKET_PROTOCOL)
.subscribe(...)