mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-14 18:12:09 +08:00
ci: implement timeout for run-automated (#9209)
* ci: implement timeout for run-automated * fix: assign timeout_id
This commit is contained in:
@ -7,18 +7,36 @@
|
||||
const spawn = require('child_process').spawn
|
||||
const kill = require('tree-kill');
|
||||
|
||||
const TIMEOUT_MS = 5 * 60 * 1000; // 5 minutes
|
||||
|
||||
const spawned_process = spawn('npm', ['start', `apps.automated.${process.argv[2]}`], {
|
||||
stdio: ['inherit', 'pipe', 'pipe']
|
||||
})
|
||||
|
||||
const {stdout, stderr} = spawned_process
|
||||
|
||||
stdout.pipe(process.stdout)
|
||||
stderr.pipe(process.stderr)
|
||||
|
||||
let lineBuffer = []
|
||||
let timeout_id;
|
||||
|
||||
function exit(code) {
|
||||
kill(spawned_process.pid)
|
||||
process.exit(code)
|
||||
}
|
||||
|
||||
function onTimeout() {
|
||||
console.log(`Tests TIMEOUT (${TIMEOUT_MS}ms)`)
|
||||
exit(1)
|
||||
}
|
||||
|
||||
function healthCheck() {
|
||||
clearTimeout(timeout_id)
|
||||
timeout_id = setTimeout(onTimeout, TIMEOUT_MS)
|
||||
}
|
||||
|
||||
stdout.on('data', data => {
|
||||
healthCheck();
|
||||
const line = data.toString();
|
||||
|
||||
// start buffering lines when tests are complete
|
||||
@ -29,8 +47,6 @@ stdout.on('data', data => {
|
||||
if(line.includes('Tests EOF!')) {
|
||||
let ok = lineBuffer.join('\n').includes('OK, 0 failed')
|
||||
console.log(ok ? 'Tests PASSED' : 'Tests FAILED');
|
||||
kill(spawned_process.pid)
|
||||
process.exit(ok ? 0 : 1)
|
||||
exit(ok ? 0 : 1)
|
||||
}
|
||||
})
|
||||
|
||||
|
Reference in New Issue
Block a user