SimpleGraphQLClient
SimpleGraphQLClient
A minimalistic GraphQL client for populating and querying test data.
class SimpleGraphQLClient {
constructor(vendureConfig: Required<VendureConfig>, apiUrl: string = '')
setAuthToken(token: string) => ;
setChannelToken(token: string | null) => ;
getAuthToken() => string;
query(query: DocumentNode | TypedDocumentNode<T, V>, variables?: V, queryParams?: QueryParams) => Promise<T>;
fetch(url: string, options: RequestInit = {}) => Promise<Response>;
queryStatus(query: DocumentNode, variables?: V) => Promise<number>;
asUserWithCredentials(username: string, password: string) => ;
asSuperAdmin() => ;
asAnonymousUser() => ;
fileUploadMutation(options: {
mutation: DocumentNode;
filePaths: string[];
mapVariables: (filePaths: string[]) => any;
}) => Promise<any>;
}
constructor
(vendureConfig: Required<VendureConfig>, apiUrl: string = '') => SimpleGraphQLClient
setAuthToken
(token: string) =>
Sets the authToken to be used in each GraphQL request.
setChannelToken
(token: string | null) =>
Sets the authToken to be used in each GraphQL request.
getAuthToken
() => string
Returns the authToken currently being used.
query
(query: DocumentNode | TypedDocumentNode<T, V>, variables?: V, queryParams?: QueryParams) => Promise<T>
Performs both query and mutation operations.
fetch
(url: string, options: RequestInit = {}) => Promise<Response>
Performs a raw HTTP request to the given URL, but also includes the authToken & channelToken headers if they have been set. Useful for testing non-GraphQL endpoints, e.g. for plugins which make use of REST controllers.
queryStatus
(query: DocumentNode, variables?: V) => Promise<number>
Performs a query or mutation and returns the resulting status code.
asUserWithCredentials
(username: string, password: string) =>
Attempts to log in with the specified credentials.
asSuperAdmin
() =>
Logs in as the SuperAdmin user.
asAnonymousUser
() =>
Logs out so that the client is then treated as an anonymous user.
fileUploadMutation
(options: {
mutation: DocumentNode;
filePaths: string[];
mapVariables: (filePaths: string[]) => any;
}) => Promise<any>
Perform a file upload mutation.
Upload spec: https://github.com/jaydenseric/graphql-multipart-request-spec
Discussion of issue: https://github.com/jaydenseric/apollo-upload-client/issues/32
Example
// Testing a custom mutation:
const result = await client.fileUploadMutation({
mutation: gql`
mutation AddSellerImages($input: AddSellerImagesInput!) {
addSellerImages(input: $input) {
id
name
}
}
`,
filePaths: ['./images/profile-picture.jpg', './images/logo.png'],
mapVariables: () => ({
name: "George's Pans",
profilePicture: null, // corresponds to filePaths[0]
branding: {
logo: null // corresponds to filePaths[1]
}
})
});