70 lines
2.0 KiB
JavaScript
70 lines
2.0 KiB
JavaScript
/* istanbul ignore file */
|
|
'use strict';
|
|
// Maximum time in seconds to suppress output
|
|
const MAX_DELAY = 30;
|
|
function getTime() {
|
|
return (new Date()).getTime();
|
|
}
|
|
export function ReporterKeepAlive(runner) {
|
|
let suites = 0;
|
|
let fails = 0;
|
|
const errors = [];
|
|
const stdoutWrite = process.stdout.write.bind(process.stdout);
|
|
//process.stdout.write = function(buffer: string | Uint8Array, cb?: (err?: Error) => void): boolean {
|
|
process.stdout.write = function (...args) {
|
|
return stdoutWrite("*");
|
|
};
|
|
// Force Output; Keeps the console output alive with periodic updates
|
|
let lastOutput = getTime();
|
|
function forceOutput() {
|
|
if (((getTime() - lastOutput) / 1000) > MAX_DELAY) {
|
|
log(".");
|
|
}
|
|
}
|
|
const timer = setInterval(forceOutput, 1000);
|
|
function log(message) {
|
|
stdoutWrite(message);
|
|
lastOutput = getTime();
|
|
}
|
|
runner.on('suite', function (suite) {
|
|
suites++;
|
|
fails = 0;
|
|
log("[");
|
|
});
|
|
runner.on('suite end', function () {
|
|
suites--;
|
|
log("]");
|
|
if (suites === 0) {
|
|
process.stdout.write = stdoutWrite;
|
|
clearTimeout(timer);
|
|
console.log("");
|
|
if (errors.length) {
|
|
console.log("---------------");
|
|
errors.forEach((error, index) => {
|
|
if (index > 0) {
|
|
console.log("");
|
|
}
|
|
console.log(error);
|
|
});
|
|
}
|
|
console.log("---------------");
|
|
}
|
|
});
|
|
runner.on('test', function (test) {
|
|
forceOutput();
|
|
});
|
|
runner.on('fail', function (test, error) {
|
|
fails++;
|
|
if (fails < 10) {
|
|
errors.push(`Error #${errors.length} (${test.title}): ${error.message}\n${error.stack}`);
|
|
log("!");
|
|
}
|
|
});
|
|
runner.on('pass', function (test) {
|
|
forceOutput();
|
|
});
|
|
runner.on('pending', function (test) {
|
|
log("?");
|
|
});
|
|
}
|
|
//# sourceMappingURL=reporter-keepalive.js.map
|