I noticed a few issues when running e2e tests that will be resolved by this PR: - Most important: for some test suites (fields, fields-relationship, versions, queues, lexical), the database was cleared and seeded **twice** in between each test run. This is because the onInit function was running the clear and seed script, when it should only have been running the seed script. Clearing the database / the snapshot workflow is being done by the reInit endpoint, which then calls onInit to seed the actual data. - The slowest part of `clearAndSeedEverything` is recreating indexes on mongodb. This PR slightly improves performance here by: - Skipping this process for the built-in `['payload-migrations', 'payload-preferences', 'payload-locked-documents']` collections - Previously we were calling both `createIndexes` and `ensureIndexes`. This was unnecessary - `ensureIndexes` is a deprecated alias of `createIndexes`. This PR changes it to only call `createIndexes` - Makes the reinit endpoint accept GET requests instead of POST requests - this makes it easier to debug right in the browser - Some typescript fixes - Adds a `dev:memorydb` script to the package.json. For some reason, `dev` is super unreliable on mongodb locally when running e2e tests - it frequently fails during index creation. Using the memorydb fixes this issue, with the bonus of more closely resembling the CI environment - Previously, you were unable to run test suites using turbopack + postgres. This fixes it, by explicitly installing `pg` as devDependency in our monorepo - Fixes jest open handles warning
59 lines
1.3 KiB
TypeScript
59 lines
1.3 KiB
TypeScript
import type { Endpoint, PayloadHandler } from 'payload'
|
|
|
|
import { status as httpStatus } from 'http-status'
|
|
import * as qs from 'qs-esm'
|
|
|
|
import { path } from './reInitializeDB.js'
|
|
import { seedDB } from './seed.js'
|
|
|
|
const handler: PayloadHandler = async (req) => {
|
|
process.env.SEED_IN_CONFIG_ONINIT = 'true'
|
|
const { payload } = req
|
|
|
|
if (!req.url) {
|
|
throw new Error('Request URL is required')
|
|
}
|
|
|
|
const query: {
|
|
deleteOnly?: boolean
|
|
snapshotKey?: string
|
|
uploadsDir?: string | string[]
|
|
} = qs.parse(req.url.split('?')[1] ?? '', {
|
|
depth: 10,
|
|
ignoreQueryPrefix: true,
|
|
})
|
|
|
|
try {
|
|
console.log('Calling seedDB')
|
|
await seedDB({
|
|
_payload: payload,
|
|
collectionSlugs: payload.config.collections.map(({ slug }) => slug),
|
|
seedFunction: payload.config.onInit,
|
|
snapshotKey: String(query.snapshotKey),
|
|
// uploadsDir can be string or stringlist
|
|
uploadsDir: query.uploadsDir as string | string[],
|
|
deleteOnly: query.deleteOnly,
|
|
})
|
|
|
|
return Response.json(
|
|
{
|
|
message: 'Database reset and onInit run successfully.',
|
|
},
|
|
{
|
|
status: httpStatus.OK,
|
|
},
|
|
)
|
|
} catch (err) {
|
|
payload.logger.error(err)
|
|
return Response.json(err, {
|
|
status: httpStatus.BAD_REQUEST,
|
|
})
|
|
}
|
|
}
|
|
|
|
export const reInitEndpoint: Endpoint = {
|
|
path,
|
|
method: 'get',
|
|
handler,
|
|
}
|