chore(testrunner): show 5 slowest tests on CI (#3919)
Show top slowest tests on CI. Drive-by: some facelifting for the test reporter.
This commit is contained in:
parent
00bcecbf72
commit
a210dd7ee2
@ -107,5 +107,8 @@ if (process.env.CI && testRunner.hasFocusedTestsOrSuites()) {
|
|||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
new Reporter(testRunner, utils.projectRoot());
|
new Reporter(testRunner, {
|
||||||
|
projectFolder: utils.projectRoot(),
|
||||||
|
showSlowTests: process.env.CI ? 5 : 0,
|
||||||
|
});
|
||||||
testRunner.run();
|
testRunner.run();
|
||||||
|
@ -20,9 +20,14 @@ const YELLOW_COLOR = '\x1b[33m';
|
|||||||
const RESET_COLOR = '\x1b[0m';
|
const RESET_COLOR = '\x1b[0m';
|
||||||
|
|
||||||
class Reporter {
|
class Reporter {
|
||||||
constructor(runner, testFolder = null) {
|
constructor(runner, options = {}) {
|
||||||
|
const {
|
||||||
|
projectFolder = null,
|
||||||
|
showSlowTests = 3,
|
||||||
|
} = options;
|
||||||
this._runner = runner;
|
this._runner = runner;
|
||||||
this._testFolder = testFolder;
|
this._projectFolder = projectFolder;
|
||||||
|
this._showSlowTests = showSlowTests;
|
||||||
runner.on('started', this._onStarted.bind(this));
|
runner.on('started', this._onStarted.bind(this));
|
||||||
runner.on('terminated', this._onTerminated.bind(this));
|
runner.on('terminated', this._onTerminated.bind(this));
|
||||||
runner.on('finished', this._onFinished.bind(this));
|
runner.on('finished', this._onFinished.bind(this));
|
||||||
@ -31,9 +36,13 @@ class Reporter {
|
|||||||
this._workersState = new Map();
|
this._workersState = new Map();
|
||||||
}
|
}
|
||||||
|
|
||||||
_onStarted() {
|
_onStarted(runnableTests) {
|
||||||
this._timestamp = Date.now();
|
this._timestamp = Date.now();
|
||||||
console.log(`Running ${YELLOW_COLOR}${this._runner.parallel()}${RESET_COLOR} worker(s):\n`);
|
const allTests = this._runner.tests();
|
||||||
|
if (allTests.length === runnableTests.length)
|
||||||
|
console.log(`Running all ${YELLOW_COLOR}${runnableTests.length}${RESET_COLOR} tests on ${YELLOW_COLOR}${this._runner.parallel()}${RESET_COLOR} worker(s):\n`);
|
||||||
|
else
|
||||||
|
console.log(`Running ${YELLOW_COLOR}${runnableTests.length}${RESET_COLOR} focused tests out of total ${YELLOW_COLOR}${allTests.length}${RESET_COLOR} on ${YELLOW_COLOR}${this._runner.parallel()}${RESET_COLOR} worker(s):\n`);
|
||||||
}
|
}
|
||||||
|
|
||||||
_onTerminated(message, error) {
|
_onTerminated(message, error) {
|
||||||
@ -102,17 +111,31 @@ class Reporter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const tests = this._runner.tests();
|
const skippedTests = this._runner.skippedTests();
|
||||||
const skippedTests = tests.filter(test => test.result === 'skipped');
|
|
||||||
if (skippedTests.length > 0) {
|
if (skippedTests.length > 0) {
|
||||||
console.log('\nSkipped:');
|
console.log('\nSkipped:');
|
||||||
for (let i = 0; i < skippedTests.length; ++i) {
|
for (let i = 0; i < skippedTests.length; ++i) {
|
||||||
const test = skippedTests[i];
|
const test = skippedTests[i];
|
||||||
console.log(`${i + 1}) ${test.fullName}`);
|
console.log(`${i + 1}) ${test.fullName} (${YELLOW_COLOR}${formatTestLocation(test)}${RESET_COLOR})`);
|
||||||
console.log(` ${YELLOW_COLOR}Temporary disabled with xit${RESET_COLOR} ${formatTestLocation(test)}\n`);
|
console.log(` ${YELLOW_COLOR}Temporary disabled with xit${RESET_COLOR}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (this._showSlowTests) {
|
||||||
|
const slowTests = this._runner.passedTests().sort((a, b) => {
|
||||||
|
const aDuration = a.endTimestamp - a.startTimestamp;
|
||||||
|
const bDuration = b.endTimestamp - b.startTimestamp;
|
||||||
|
return bDuration - aDuration;
|
||||||
|
}).slice(0, this._showSlowTests);
|
||||||
|
console.log(`\nSlowest tests:`);
|
||||||
|
for (let i = 0; i < slowTests.length; ++i) {
|
||||||
|
const test = slowTests[i];
|
||||||
|
const duration = test.endTimestamp - test.startTimestamp;
|
||||||
|
console.log(` (${i + 1}) ${YELLOW_COLOR}${duration / 1000}s${RESET_COLOR} - ${test.fullName} (${YELLOW_COLOR}${formatTestLocation(test)}${RESET_COLOR})`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const tests = this._runner.tests();
|
||||||
const executedTests = tests.filter(test => test.result);
|
const executedTests = tests.filter(test => test.result);
|
||||||
console.log(`\nRan ${executedTests.length} of ${tests.length} test(s)`);
|
console.log(`\nRan ${executedTests.length} of ${tests.length} test(s)`);
|
||||||
const milliseconds = Date.now() - this._timestamp;
|
const milliseconds = Date.now() - this._timestamp;
|
||||||
@ -121,7 +144,7 @@ class Reporter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_beautifyStack(stack) {
|
_beautifyStack(stack) {
|
||||||
if (!this._testFolder)
|
if (!this._projectFolder)
|
||||||
return stack;
|
return stack;
|
||||||
const lines = stack.split('\n').map(line => ' ' + line);
|
const lines = stack.split('\n').map(line => ' ' + line);
|
||||||
// Find last stack line that include testrunner code.
|
// Find last stack line that include testrunner code.
|
||||||
@ -133,7 +156,7 @@ class Reporter {
|
|||||||
if (index >= lines.length)
|
if (index >= lines.length)
|
||||||
return stack;
|
return stack;
|
||||||
const line = lines[index];
|
const line = lines[index];
|
||||||
const fromIndex = line.lastIndexOf(this._testFolder) + this._testFolder.length;
|
const fromIndex = line.lastIndexOf(this._projectFolder) + this._projectFolder.length;
|
||||||
const toIndex = line.lastIndexOf(')');
|
const toIndex = line.lastIndexOf(')');
|
||||||
lines[index] = line.substring(0, fromIndex) + YELLOW_COLOR + line.substring(fromIndex, toIndex) + RESET_COLOR + line.substring(toIndex);
|
lines[index] = line.substring(0, fromIndex) + YELLOW_COLOR + line.substring(fromIndex, toIndex) + RESET_COLOR + line.substring(toIndex);
|
||||||
return lines.join('\n');
|
return lines.join('\n');
|
||||||
|
@ -108,6 +108,8 @@ class Test {
|
|||||||
// Test results
|
// Test results
|
||||||
this.result = null;
|
this.result = null;
|
||||||
this.error = null;
|
this.error = null;
|
||||||
|
this.startTimestamp = 0;
|
||||||
|
this.endTimestamp = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -267,7 +269,6 @@ class TestRunner extends EventEmitter {
|
|||||||
// Default timeout is 10 seconds.
|
// Default timeout is 10 seconds.
|
||||||
this._timeout = options.timeout === 0 ? 2147483647 : options.timeout || 10 * 1000;
|
this._timeout = options.timeout === 0 ? 2147483647 : options.timeout || 10 * 1000;
|
||||||
this._parallel = options.parallel || 1;
|
this._parallel = options.parallel || 1;
|
||||||
this._retryFailures = !!options.retryFailures;
|
|
||||||
|
|
||||||
this._hasFocusedTestsOrSuites = false;
|
this._hasFocusedTestsOrSuites = false;
|
||||||
|
|
||||||
@ -322,8 +323,9 @@ class TestRunner extends EventEmitter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async run() {
|
async run() {
|
||||||
this.emit(TestRunner.Events.Started);
|
const runnableTests = this._runnableTests();
|
||||||
const pass = new TestPass(this, this._rootSuite, this._runnableTests(), this._parallel);
|
this.emit(TestRunner.Events.Started, runnableTests);
|
||||||
|
const pass = new TestPass(this, this._rootSuite, runnableTests, this._parallel);
|
||||||
const termination = await pass.run();
|
const termination = await pass.run();
|
||||||
if (termination)
|
if (termination)
|
||||||
this.emit(TestRunner.Events.Terminated, termination.message, termination.error);
|
this.emit(TestRunner.Events.Terminated, termination.message, termination.error);
|
||||||
@ -376,15 +378,25 @@ class TestRunner extends EventEmitter {
|
|||||||
return this._tests.filter(test => test.result === 'failed' || test.result === 'timedout');
|
return this._tests.filter(test => test.result === 'failed' || test.result === 'timedout');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
passedTests() {
|
||||||
|
return this._tests.filter(test => test.result === 'ok');
|
||||||
|
}
|
||||||
|
|
||||||
|
skippedTests() {
|
||||||
|
return this._tests.filter(test => test.result === 'skipped');
|
||||||
|
}
|
||||||
|
|
||||||
parallel() {
|
parallel() {
|
||||||
return this._parallel;
|
return this._parallel;
|
||||||
}
|
}
|
||||||
|
|
||||||
_willStartTest(test, workerId) {
|
_willStartTest(test, workerId) {
|
||||||
|
test.startTimestamp = Date.now();
|
||||||
this.emit(TestRunner.Events.TestStarted, test, workerId);
|
this.emit(TestRunner.Events.TestStarted, test, workerId);
|
||||||
}
|
}
|
||||||
|
|
||||||
_didFinishTest(test, workerId) {
|
_didFinishTest(test, workerId) {
|
||||||
|
test.endTimestamp = Date.now();
|
||||||
this.emit(TestRunner.Events.TestFinished, test, workerId);
|
this.emit(TestRunner.Events.TestFinished, test, workerId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user