console/integration-tests/testkit/graphql.ts

53 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-05-18 07:26:57 +00:00
import * as utils from 'dockest/test-helper';
// eslint-disable-next-line import/no-extraneous-dependencies
import { ExecutionResult, print } from 'graphql';
2022-05-18 07:26:57 +00:00
import { TypedDocumentNode } from '@graphql-typed-document-node/core';
import { createFetch } from '@whatwg-node/fetch';
2022-05-18 07:26:57 +00:00
const registryAddress = utils.getServiceAddress('server', 3001);
const { fetch } = createFetch({
useNodeFetch: true,
});
feat: replace auth0 with supertokens (#303) * add supertoken container to docker-compose file * yeah I am sorry this one big commit and I am ashamed of it * use logOut function * feat: show header on 404 page * feat: better handling for organization cookie when not authenticated * wrap it * check session within server side props * add is_admin flag user migration * simplify and annotate the config * fix: handle status codes + fix email/password sign up with import from auth0 * no hardcoded env pls * decode process.env * secure update user id mapping via a key * fix: login form * lol we don't need to hit the API * fix: do graphql api authorization via authorization header instead of cookie * implement isAdmin flag * fix: types :) * skipit * yo we can run this * set env variables * disable because it annoys the hell out of me * use the right host * add not about token length * refactor: decode environment variables * feat: store external user id from guthub/google provider in the database * workaround supertokens omitting null values from the token * re-enable check * i have no time for this shit * add missing env variable * fix: email test; missing domain extension * configure pulumi deployment Co-authored-by: Kamil Kisiela <kamil.kisiela@gmail.com> Co-authored-by: Dotan Simha <dotansimha@gmail.com> * configure pulumi deployment Co-authored-by: Kamil Kisiela <kamil.kisiela@gmail.com> Co-authored-by: Dotan Simha <dotansimha@gmail.com> * configure pulumi deployment Co-authored-by: Kamil Kisiela <kamil.kisiela@gmail.com> Co-authored-by: Dotan Simha <dotansimha@gmail.com> * configure pulumi deployment Co-authored-by: Kamil Kisiela <kamil.kisiela@gmail.com> * fix: env names * fix: link google account to the correct db record * feat: email confirmation emails * ? * bump ts-node * fix types * omit package form the bundle * remove it from dependencies... * add emails apckage to dev deps * resolve eslint issues * remove comments * update dev info + change env variable (no need to expose it on the frontend) * use correct user id lol Co-authored-by: Kamil Kisiela <kamil.kisiela@gmail.com> Co-authored-by: Dotan Simha <dotansimha@gmail.com>
2022-09-06 07:38:31 +00:00
export async function execute<TResult, TVariables>(
params: {
document: TypedDocumentNode<TResult, TVariables>;
operationName?: string;
authToken?: string;
token?: string;
legacyAuthorizationMode?: boolean;
} & (TVariables extends Record<string, never> ? { variables?: never } : { variables: TVariables })
) {
const response = await fetch(`http://${registryAddress}/graphql`, {
method: 'POST',
body: JSON.stringify({
query: print(params.document),
2022-05-18 07:26:57 +00:00
operationName: params.operationName,
variables: params.variables,
}),
headers: {
accept: 'application/json',
'content-type': 'application/json',
...(params.authToken
? {
authorization: `Bearer ${params.authToken}`,
}
: {}),
...(params.token
? params.legacyAuthorizationMode
2022-05-18 07:26:57 +00:00
? {
'x-api-token': params.token,
2022-05-18 07:26:57 +00:00
}
: {
authorization: `Bearer ${params.token}`,
}
: {}),
},
});
2022-05-18 07:26:57 +00:00
return {
body: (await response.json()) as ExecutionResult<TResult>,
status: response.status,
2022-05-18 07:26:57 +00:00
};
}