Security News
UK Officials Consider Banning Ransomware Payments from Public Entities
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
mercurius-integration-testing
Advanced tools
[![npm version](https://badge.fury.io/js/mercurius-integration-testing.svg)](https://badge.fury.io/js/mercurius-integration-testing) [![codecov](https://codecov.io/gh/PabloSzx/mercurius-integration-testing/branch/master/graph/badge.svg)](https://codecov.i
yarn add mercurius-integration-testing
# or
npm install mercurius-integration-testing
// app.ts | app.js
import Fastify from "fastify";
import Mercurius from "mercurius";
import schema from "./schema";
import { buildContext } from "./buildContext";
export const app = Fastify();
app.register(Mercurius, {
schema,
resolvers: {},
context: buildContext,
allowBatchedQueries: true,
});
// integration.test.js | integration.test.ts
import { createMercuriusTestClient } from "mercurius-integration-testing";
import { app } from "../app";
// ...
const testClient = createMercuriusTestClient(app);
expect(testClient.query("query { helloWorld }")).resolves.toEqual({
data: {
helloWorld: "helloWorld",
},
});
Create a testing client instance, you should give it the fastify instance in which Mercurius was already registered, and optionally, some options
const client = createMercuriusTestClient(app, {
/**
* Optional, specify headers to be added to every request in the client
*/
headers: {
authorization: "hello-world",
},
/**
* Optional, by default it points to /graphql
*/
url: "/graphql",
/**
* Optional, specify cookies to be added to every request in the client
*/
cookies: {
authorization: "hello-world",
},
});
.query
and.mutate
are basically the same function, but for readability, both exists
// You can give it a simple string
const queryResponse = await client.query(`
query {
helloWorld
}
`);
// Data returned from the API
queryResponse.data;
// Possible array of errors from the API
queryResponse.errors;
// You can also call `mutate`
// to improve readability for mutations
const mutationResponse = await client.mutate(`
mutation {
helloWorld
}
`);
// You can also give them `DocumentNode`s
// from `graphql-tag` or equivalents
await client.query(gql`
query {
helloWorld
}
`);
// You can give variables in the second parameter options
await client.query(
`
query($foo: String!) {
hello(foo: $foo)
}
`,
{
variables: {
foo: "bar",
},
}
);
await client.query(
`
query example {
helloExample
}
`,
{
// You can specify operation name if the queries
// are named
operationName: "helloExample",
// Query specific headers
// These are going to be "merged" with the client set headers
headers: {
hello: "world",
},
// Query specific cookies
// These are going to be "merged" with the client set headers
cookies: {
foo: "bar",
},
}
);
You can change the default client headers whenever
client.setHeaders({
authorization: "other-header",
});
You can change the default client cookies whenever
client.setCookies({
authorization: "other-cookie",
});
If allowBatchedQueries
is set in the Mercurius registration, you can call some queries together
const batchedResponse = await client.batchQueries(
[
{
query: `
query {
helloWorld
}
`,
},
{
query: `
query($name: String!) {
user(name: $name) {
email
}
}
`,
variables: {
name: "bob",
},
// operationName: "you-can-specify-it-here-if-needed"
},
],
// Optional
{
// Optional request specific cookies
cookies: {
foo: "bar",
},
// Optional request specific headers
headers: {
foo: "bar",
},
}
);
batchedResponse ===
[{ data: { helloWorld: "foo" } }, { data: { user: { email: "hello@world.com" } } }];
If you are not already calling
.listen(PORT)
somewhere, it will automatically call it, assigning a random available port, this means you will have to manually call.close()
somewhere
.subscribe
returns a promise that resolves when the subscription connection is made
headers
&cookies
are applied the same as in.query
and.mutate
const subscription = await client.subscribe({
query: `
subscription {
notificationAdded {
id
message
}
}
`,
onData(data) {
data == { notificationAdded: { id: 1, message: "hello world" } };
},
// Optional
variables: { foo: "bar" },
// Optional, initialization payload, usually for authorization
initPayload: { authorization: "<token>" },
// Optional, subscription specific cookies
cookies: {
authorization: "<token>",
},
// Optional, subscription specific headers
headers: {
authorization: "<token>",
},
});
// You can manually call the unsubscribe
subscription.unsubscribe();
// You will need to manually close the fastify instance somewhere
app.close();
const dataResponse = await client.query<{
helloWorld: string;
}>(`
query {
helloWorld
}
`);
// string
dataResponse.data.helloWorld;
const variablesResponse = await client.query<
{
user: {
email: string;
};
},
{
name: string;
}
>(
`
query($name: String!) {
user(name: $name) {
email
}
}
`,
{
variables: {
name: "bob",
},
}
);
// string
variablesResponse.data.user.email;
await client.subscribe<
{
helloWorld: string;
},
{
foo: string;
}
>({
query: `
subscription($foo: String!) {
helloWorld(foo: $foo)
}
`,
variables: {
// Error, Type 'number' is not assignable to type 'string'.
foo: 123,
},
onData(data) {
// string
data.helloWorld;
},
});
MIT
FAQs
[![npm version](https://badge.fury.io/js/mercurius-integration-testing.svg)](https://badge.fury.io/js/mercurius-integration-testing) [![codecov](https://codecov.io/gh/PabloSzx/mercurius-integration-testing/branch/master/graph/badge.svg)](https://codecov.i
The npm package mercurius-integration-testing receives a total of 4,698 weekly downloads. As such, mercurius-integration-testing popularity was classified as popular.
We found that mercurius-integration-testing demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.