testing: add full json reporter to show more complete output
This commit is contained in:
parent
d39eefd1b0
commit
2b5ae783bf
3 changed files with 60 additions and 0 deletions
|
@ -68,3 +68,6 @@
|
||||||
border-bottom-width: 2px;
|
border-bottom-width: 2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.monaco-editor .zone-widget .zone-widget-container.peekview-widget .peekview-title .filename {
|
||||||
|
height: 22px;
|
||||||
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@ const events = require('events');
|
||||||
const MochaJUnitReporter = require('mocha-junit-reporter');
|
const MochaJUnitReporter = require('mocha-junit-reporter');
|
||||||
const url = require('url');
|
const url = require('url');
|
||||||
const createStatsCollector = require('mocha/lib/stats-collector');
|
const createStatsCollector = require('mocha/lib/stats-collector');
|
||||||
|
const FullJsonStreamReporter = require('../fullJsonStreamReporter');
|
||||||
|
|
||||||
// Disable render process reuse, we still have
|
// Disable render process reuse, we still have
|
||||||
// non-context aware native modules in the renderer.
|
// non-context aware native modules in the renderer.
|
||||||
|
@ -73,6 +74,10 @@ function deserializeRunnable(runnable) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function importMochaReporter(name) {
|
function importMochaReporter(name) {
|
||||||
|
if (name === 'full-json-stream') {
|
||||||
|
return FullJsonStreamReporter;
|
||||||
|
}
|
||||||
|
|
||||||
const reporterPath = path.join(path.dirname(require.resolve('mocha')), 'lib', 'reporters', name);
|
const reporterPath = path.join(path.dirname(require.resolve('mocha')), 'lib', 'reporters', name);
|
||||||
return require(reporterPath);
|
return require(reporterPath);
|
||||||
}
|
}
|
||||||
|
|
52
test/unit/fullJsonStreamReporter.js
Normal file
52
test/unit/fullJsonStreamReporter.js
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
/*---------------------------------------------------------------------------------------------
|
||||||
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||||
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
||||||
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
const { constants } = require('mocha/lib/runner');
|
||||||
|
const BaseRunner = require('mocha/lib/reporters/base');
|
||||||
|
|
||||||
|
const {
|
||||||
|
EVENT_TEST_PASS,
|
||||||
|
EVENT_TEST_FAIL,
|
||||||
|
EVENT_RUN_BEGIN,
|
||||||
|
EVENT_RUN_END,
|
||||||
|
} = constants;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Similar to the mocha JSON stream, but includes additional information
|
||||||
|
* on failure. Specifically, the mocha json-stream does not include unmangled
|
||||||
|
* expected versus actual results.
|
||||||
|
*
|
||||||
|
* Writes a superset of the data that json-stream normally would.
|
||||||
|
*/
|
||||||
|
module.exports = class FullJsonStreamReporter extends BaseRunner {
|
||||||
|
constructor(runner, options) {
|
||||||
|
super(runner, options);
|
||||||
|
|
||||||
|
const total = runner.total;
|
||||||
|
runner.once(EVENT_RUN_BEGIN, () => writeEvent(['start', { total }]));
|
||||||
|
runner.once(EVENT_RUN_END, () => writeEvent(['end', this.stats]));
|
||||||
|
|
||||||
|
runner.on(EVENT_TEST_PASS, test => writeEvent(['pass', clean(test)]));
|
||||||
|
runner.on(EVENT_TEST_FAIL, (test, err) => {
|
||||||
|
test = clean(test);
|
||||||
|
test.actual = err.actual;
|
||||||
|
test.expected = err.expected;
|
||||||
|
test.err = err.message;
|
||||||
|
test.stack = err.stack || null;
|
||||||
|
writeEvent(['fail', test]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function writeEvent(event) {
|
||||||
|
process.stdout.write(JSON.stringify(event) + '\n');
|
||||||
|
}
|
||||||
|
|
||||||
|
const clean = test => ({
|
||||||
|
title: test.title,
|
||||||
|
fullTitle: test.fullTitle(),
|
||||||
|
duration: test.duration,
|
||||||
|
currentRetry: test.currentRetry()
|
||||||
|
});
|
Loading…
Reference in a new issue