Files
payloadcms/test/dev.ts
2023-10-03 12:34:48 -04:00

88 lines
2.2 KiB
TypeScript

import * as dotenv from 'dotenv'
import express from 'express'
import fs from 'fs'
import path from 'path'
import { v4 as uuid } from 'uuid'
import payload from '../packages/payload/src'
import { prettySyncLoggerDestination } from '../packages/payload/src/utilities/logger'
import { startLivePreviewDemo } from './live-preview/startLivePreviewDemo'
dotenv.config()
const [testSuiteDir] = process.argv.slice(2)
/**
* The default logger's options did not allow for forcing sync logging
* Using these options, to force both pretty print and sync logging
*/
const prettySyncLogger = {
loggerDestination: prettySyncLoggerDestination,
loggerOptions: {},
}
if (!testSuiteDir) {
console.error('ERROR: You must provide an argument for "testSuiteDir"')
process.exit(1)
}
const configPath = path.resolve(__dirname, testSuiteDir, 'config.ts')
if (!fs.existsSync(configPath)) {
console.error('ERROR: You must pass a valid directory under test/ that contains a config.ts')
process.exit(1)
}
process.env.PAYLOAD_CONFIG_PATH = configPath
// Default to true unless explicitly set to false
if (process.env.PAYLOAD_DROP_DATABASE === 'false') {
process.env.PAYLOAD_DROP_DATABASE = 'false'
} else {
process.env.PAYLOAD_DROP_DATABASE = 'true'
}
if (process.argv.includes('--no-auto-login') && process.env.NODE_ENV !== 'production') {
process.env.PAYLOAD_PUBLIC_DISABLE_AUTO_LOGIN = 'true'
}
const expressApp = express()
const startDev = async () => {
await payload.init({
secret: uuid(),
express: expressApp,
email: {
logMockCredentials: false,
fromName: 'Payload',
fromAddress: 'hello@payloadcms.com',
},
...prettySyncLogger,
onInit: async (payload) => {
payload.logger.info('Payload Dev Server Initialized')
},
})
// Redirect root to Admin panel
expressApp.get('/', (_, res) => {
res.redirect('/admin')
})
const externalRouter = express.Router()
externalRouter.use(payload.authenticate)
if (testSuiteDir === 'live-preview') {
await startLivePreviewDemo({
payload,
})
}
expressApp.listen(3000, async () => {
payload.logger.info(`Admin URL on http://localhost:3000${payload.getAdminURL()}`)
payload.logger.info(`API URL on http://localhost:3000${payload.getAPIURL()}`)
})
}
startDev()