Files
payloadcms/test/dev.ts
2023-10-06 03:38:39 -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(4)
/**
* 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({
email: {
fromAddress: 'hello@payloadcms.com',
fromName: 'Payload',
logMockCredentials: false,
},
express: expressApp,
secret: uuid(),
...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()