ui5-test-runner
Version:
Standalone test runner for UI5
176 lines (164 loc) • 4.31 kB
JavaScript
const { serve } = require('reserve')
const { watch } = require('fs')
const { capabilities } = require('./src/capabilities')
const { execute } = require('./src/tests')
const { fromCmdLine } = require('./src/job')
const { getOutput } = require('./src/output')
const { preload } = require('./src/ui5')
const { probe: probeBrowser } = require('./src/browsers')
const { recreateDir, allocPromise } = require('./src/tools')
const reserveConfigurationFactory = require('./src/reserve')
const { start } = require('./src/start')
const { executeIf } = require('./src/if')
const { batch } = require('./src/batch')
const { end } = require('./src/end')
const { checkLatest } = require('./src/npm')
const { cleanHandles } = require('./src/clean')
function send (message) {
if (process.send) {
process.send({
pid: process.pid,
...message
})
}
}
async function notifyAndExecuteTests (job) {
send({ msg: 'begin' })
try {
await execute(job)
let status
if (job.failed) {
status = -1
} else {
status = 0
}
send({ msg: 'end', status })
} catch (error) {
getOutput(job).genericError(error)
send({ msg: 'error', error })
}
}
let job
let output
async function main () {
job = fromCmdLine(process.cwd(), process.argv.slice(2))
output = getOutput(job)
await recreateDir(job.reportDir)
const { name, version } = output.version()
if (job.batchMode) {
output.batchMode()
}
output.reportOnJobProgress()
checkLatest(job, name, version)
if (job.mode === 'capabilities') {
return capabilities(job)
}
if (job.if && !executeIf(job)) {
output.skipIf()
output.stop()
return
}
let startedCommand
if (job.startCommand) {
startedCommand = await start(job)
}
if (job.mode === 'batch') {
return await batch(job)
.finally(() => {
if (startedCommand) {
return startedCommand.stop()
}
})
}
const configuration = await reserveConfigurationFactory(job)
output.debug('reserve', 'configuration', configuration)
const server = serve(configuration)
if (job.logServer) {
server
.on('incoming', output.logServerIncoming)
.on('redirected', output.logServerRedirected)
.on('closed', output.logServerClosed)
}
const { promise: serverStarted, resolve: serverReady, reject: serverError } = allocPromise()
server
.on('ready', async ({ url, port }) => {
job.port = port
send({ msg: 'ready', port: job.port })
output.serving(url)
serverReady()
})
.on('error', error => {
output.serverError(error)
send({ msg: 'error', error })
serverError()
})
await serverStarted
if (job.preload) {
await preload(job)
}
if (job.serveOnly) {
job.status = 'Serving'
return
}
await probeBrowser(job)
await notifyAndExecuteTests(job)
if (job.watch) {
if (!job.watching) {
job.status = 'Watching...'
let running = false
let rerun = false
const run = async () => {
running = true
do {
rerun = false
await recreateDir(job.reportDir)
await notifyAndExecuteTests(job)
} while (rerun)
running = false
job.status = 'Watching...'
}
output.watching(job.watchFolder)
watch(job.watchFolder, { recursive: true }, async (eventType, filename) => {
output.changeDetected(eventType, filename)
if (running) {
rerun = true
} else {
run()
}
})
job.watching = true
}
return
} else if (job.keepAlive) {
job.status = 'Serving'
return
} else if (job.failed) {
process.exitCode = -1
}
if (job.endScript) {
await end(job)
}
output.stop()
await server.close({ close: true })
await new Promise(resolve => setTimeout(resolve, 100)) // wait for server handles to be released
if (job.logServer) {
output.logServerSummary()
}
if (startedCommand) {
await startedCommand.stop()
}
output.debug('main', 'terminated')
cleanHandles(job)
}
main()
.catch(reason => {
if (output) {
output.genericError(reason)
output.stop()
} else if (reason.name !== 'CommanderError') {
console.error(reason)
}
process.exit(-1)
})