ethers.js/packages/tests/lib.esm/reporter-keepalive.js

104 lines
2.9 KiB
JavaScript
Raw Permalink Normal View History

2020-07-13 08:03:56 -04:00
/* istanbul ignore file */
'use strict';
// Maximum time in seconds to suppress output
2020-08-25 01:53:48 -04:00
const MAX_DELAY = 60;
2020-07-13 08:03:56 -04:00
function getTime() {
return (new Date()).getTime();
}
2020-08-25 01:53:48 -04:00
const stdoutWrite = process.stdout.write.bind(process.stdout);
let logOut = "";
let capturing = false;
function log(message) {
if (message == null) {
message = "";
}
if (capturing) {
logOut += message;
}
else {
console.log(message);
}
}
function captureLog(initialLog) {
capturing = true;
if (initialLog == null) {
initialLog = "";
}
logOut = initialLog;
process.stdout.write = function (...args) {
logOut += "*";
return true;
};
}
function releaseLog() {
capturing = false;
const result = logOut;
process.stdout.write = stdoutWrite;
logOut = "";
return result;
}
2020-07-13 08:03:56 -04:00
export function ReporterKeepAlive(runner) {
let suites = 0;
let fails = 0;
const errors = [];
2020-08-25 01:53:48 -04:00
// Catch anything attempting to write to the consolea
captureLog();
2020-07-13 08:03:56 -04:00
// Force Output; Keeps the console output alive with periodic updates
let lastOutput = getTime();
function forceOutput() {
if (((getTime() - lastOutput) / 1000) > MAX_DELAY) {
2020-08-25 01:53:48 -04:00
let currentLog = releaseLog();
console.log(`# Keep Alive: ${currentLog}`);
captureLog();
lastOutput = getTime();
2020-07-13 08:03:56 -04:00
}
}
const timer = setInterval(forceOutput, 1000);
runner.on('suite', function (suite) {
suites++;
fails = 0;
log("[");
});
runner.on('suite end', function () {
suites--;
log("]");
if (suites === 0) {
2020-08-25 01:53:48 -04:00
// Reset standard output
const currentLog = releaseLog();
if (logOut.length) {
console.log(`# Keep Alive: ${currentLog}`);
}
// Stop the keep-alive poller
2020-07-13 08:03:56 -04:00
clearTimeout(timer);
2020-08-25 01:53:48 -04:00
// Dump out any errors encountered
console.log("#");
2020-07-13 08:03:56 -04:00
if (errors.length) {
2020-08-25 01:53:48 -04:00
console.log("# ---------------");
2020-07-13 08:03:56 -04:00
errors.forEach((error, index) => {
if (index > 0) {
2020-08-25 01:53:48 -04:00
console.log("#");
2020-07-13 08:03:56 -04:00
}
2020-08-25 01:53:48 -04:00
error.toString().split("\n").forEach((line) => {
console.log(`# ${line}`);
});
2020-07-13 08:03:56 -04:00
});
}
2020-08-25 01:53:48 -04:00
console.log("# ---------------");
2020-07-13 08:03:56 -04:00
}
});
runner.on('test', function (test) {
});
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) {
});
runner.on('pending', function (test) {
log("?");
});
}
//# sourceMappingURL=reporter-keepalive.js.map