Skip to content

Commit

Permalink
chore: nicer stack highlight (#3259)
Browse files Browse the repository at this point in the history
Highlight part of the stack that points to where the actual
test failure happened.
  • Loading branch information
aslushnikov authored Sep 17, 2018
1 parent a4abb4a commit a1a211d
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 15 deletions.
2 changes: 1 addition & 1 deletion test/test.js
Original file line number Diff line number Diff line change
Expand Up @@ -189,5 +189,5 @@ if (process.env.CI && testRunner.hasFocusedTestsOrSuites()) {
process.exit(1);
}

new Reporter(testRunner);
new Reporter(testRunner, utils.projectRoot());
testRunner.run();
37 changes: 23 additions & 14 deletions utils/testrunner/Reporter.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,9 @@ const YELLOW_COLOR = '\x1b[33m';
const RESET_COLOR = '\x1b[0m';

class Reporter {
constructor(runner) {
constructor(runner, testFolder = null) {
this._runner = runner;
this._testFolder = testFolder;
runner.on('started', this._onStarted.bind(this));
runner.on('terminated', this._onTerminated.bind(this));
runner.on('finished', this._onFinished.bind(this));
Expand Down Expand Up @@ -90,19 +91,8 @@ class Reporter {
console.log(' Message:');
console.log(` ${RED_COLOR}${test.error.message || test.error}${RESET_COLOR}`);
console.log(' Stack:');
if (test.error.stack) {
const stack = test.error.stack.split('\n').map(line => ' ' + line);
let i = 0;
while (i < stack.length && !stack[i].includes(__dirname))
++i;
while (i < stack.length && stack[i].includes(__dirname))
++i;
if (i < stack.length) {
const indent = stack[i].match(/^\s*/)[0];
stack[i] = stack[i].substring(0, indent.length - 3) + YELLOW_COLOR + '⇨ ' + RESET_COLOR + stack[i].substring(indent.length - 1);
}
console.log(stack.join('\n'));
}
if (test.error.stack)
console.log(this._beautifyStack(test.error.stack));
}
if (test.output) {
console.log(' Output:');
Expand Down Expand Up @@ -130,6 +120,25 @@ class Reporter {
console.log(`Finished in ${YELLOW_COLOR}${seconds}${RESET_COLOR} seconds`);
}

_beautifyStack(stack) {
if (!this._testFolder)
return stack;
const lines = stack.split('\n').map(line => ' ' + line);
// Find last stack line that include testrunner code.
let index = 0;
while (index < lines.length && !lines[index].includes(__dirname))
++index;
while (index < lines.length && lines[index].includes(__dirname))
++index;
if (index >= lines.length)
return stack;
const line = lines[index];
const fromIndex = line.lastIndexOf(this._testFolder) + this._testFolder.length;
const toIndex = line.lastIndexOf(')');
lines[index] = line.substring(0, fromIndex) + YELLOW_COLOR + line.substring(fromIndex, toIndex) + RESET_COLOR + line.substring(toIndex);
return lines.join('\n');
}

_onTestStarted(test, workerId) {
this._workersState.set(workerId, {test, isRunning: true});
}
Expand Down

0 comments on commit a1a211d

Please sign in to comment.