mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-12 23:35:58 +00:00
This is a side quest of #8558. The motivation is to be able to do dependency injection in the tests without overwriting global data. I saw the first merge conflict from #8551 and voila: It seems @Mogge could have used this already. refactor: follow @Mogge's review See: https://github.com/Ocelot-Social-Community/Ocelot-Social/pull/8603#pullrequestreview-2880714796 refactor: better test helper methods wip: continue refactoring wip: continue posts continue wip: continue groups continue registration registration continue messages continue observeposts continue categories continue posts in groups continue invite codes refactor: continue notificationsMiddleware continue statistics spec followed-users online-status mentions-in-groups posts-in-groups email spec finish all tests improve typescript missed one test remove one more reference of CONFIG eliminate one more global import of CONFIG fix language spec test fix two more test suites refactor: completely mock out 3rd part API request refactor test fixed user_management spec fixed more locatoin specs install types for jsonwebtoken one more fetchmock fixed one more suite fix one more spec yet another spec fix spec delete whitespaces remove beforeAll that the same as the default fix merge conflict fix e2e test refactor: use single callback function for `context` setup refactor: display logs from backend during CI Because why not? fix seeds fix login refactor: one unnecessary naming refactor: better editor support refactor: fail early Interestingly, I've had to destructure `context.user` in order to make typescript happy. Weird. refactor: undo changes to workflows - no effect We're running in `--detached` mode on CI, so I guess we won't be able to see the logs anyways. refactor: remove fetch from context after review See: refactor: found an easier way for required props Co-authored-by: Max <maxharz@gmail.com> Co-authored-by: Ulf Gebhardt <ulf.gebhardt@webcraft-media.de>
101 lines
2.7 KiB
TypeScript
101 lines
2.7 KiB
TypeScript
import { createTestClient } from 'apollo-server-testing'
|
|
|
|
import databaseContext from '@context/database'
|
|
import type CONFIG from '@src/config'
|
|
import type { Context } from '@src/context'
|
|
import { getContext } from '@src/context'
|
|
import createServer from '@src/server'
|
|
|
|
import type { ApolloServerExpressConfig } from 'apollo-server-express'
|
|
|
|
export const TEST_CONFIG = {
|
|
NODE_ENV: 'test',
|
|
DEBUG: undefined,
|
|
TEST: true,
|
|
PRODUCTION: false,
|
|
PRODUCTION_DB_CLEAN_ALLOW: false,
|
|
DISABLED_MIDDLEWARES: [],
|
|
SEND_MAIL: false,
|
|
|
|
CLIENT_URI: 'http://webapp:3000',
|
|
GRAPHQL_URI: 'http://localhost:4000',
|
|
JWT_EXPIRES: '2y',
|
|
|
|
MAPBOX_TOKEN:
|
|
'pk.eyJ1IjoiYnVzZmFrdG9yIiwiYSI6ImNraDNiM3JxcDBhaWQydG1uczhpZWtpOW4ifQ.7TNRTO-o9aK1Y6MyW_Nd4g',
|
|
JWT_SECRET: 'JWT_SECRET',
|
|
PRIVATE_KEY_PASSPHRASE: 'PRIVATE_KEY_PASSPHRASE',
|
|
|
|
NEO4J_URI: 'bolt://localhost:7687',
|
|
NEO4J_USERNAME: 'neo4j',
|
|
NEO4J_PASSWORD: 'neo4j',
|
|
|
|
SENTRY_DSN_BACKEND: undefined,
|
|
COMMIT: undefined,
|
|
|
|
REDIS_DOMAIN: undefined,
|
|
REDIS_PORT: undefined,
|
|
REDIS_PASSWORD: undefined,
|
|
|
|
AWS_ACCESS_KEY_ID: '',
|
|
AWS_SECRET_ACCESS_KEY: '',
|
|
AWS_ENDPOINT: '',
|
|
AWS_REGION: '',
|
|
AWS_BUCKET: '',
|
|
S3_PUBLIC_GATEWAY: undefined,
|
|
|
|
EMAIL_DEFAULT_SENDER: '',
|
|
SUPPORT_EMAIL: '',
|
|
SUPPORT_URL: '',
|
|
APPLICATION_NAME: '',
|
|
ORGANIZATION_URL: '',
|
|
PUBLIC_REGISTRATION: false,
|
|
INVITE_REGISTRATION: true,
|
|
INVITE_CODES_PERSONAL_PER_USER: 7,
|
|
INVITE_CODES_GROUP_PER_USER: 7,
|
|
CATEGORIES_ACTIVE: false,
|
|
MAX_PINNED_POSTS: 1,
|
|
|
|
LANGUAGE_DEFAULT: 'en',
|
|
LOG_LEVEL: 'DEBUG',
|
|
} as const satisfies typeof CONFIG
|
|
|
|
interface OverwritableContextParams {
|
|
authenticatedUser?: Context['user']
|
|
config?: Partial<typeof CONFIG>
|
|
pubsub?: Context['pubsub']
|
|
}
|
|
interface CreateTestServerOptions {
|
|
context: () => OverwritableContextParams | Promise<OverwritableContextParams>
|
|
plugins?: ApolloServerExpressConfig['plugins']
|
|
}
|
|
|
|
export const createApolloTestSetup = (opts?: CreateTestServerOptions) => {
|
|
const defaultOpts: CreateTestServerOptions = { context: () => ({ authenticatedUser: null }) }
|
|
const { context: testContext, plugins } = opts ?? defaultOpts
|
|
const database = databaseContext()
|
|
const context = async (req: { headers: { authorization?: string } }) => {
|
|
const { authenticatedUser, config = {}, pubsub } = await testContext()
|
|
return getContext({
|
|
authenticatedUser,
|
|
database,
|
|
pubsub,
|
|
config: { ...TEST_CONFIG, ...config },
|
|
})(req)
|
|
}
|
|
|
|
const server = createServer({
|
|
context,
|
|
plugins,
|
|
}).server
|
|
const { mutate, query } = createTestClient(server)
|
|
return {
|
|
server,
|
|
query,
|
|
mutate,
|
|
database,
|
|
}
|
|
}
|
|
|
|
export type ApolloTestSetup = ReturnType<typeof createApolloTestSetup>
|