just-test-node 2.0.0-alpha.1 → 2.0.0-alpha.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/StackTrace.d.ts +2 -0
- package/lib/StackTrace.js +23 -3
- package/lib/Test.d.ts +1 -0
- package/lib/Test.js +19 -5
- package/lib/examples/exampleTestFile.test.js +4 -1
- package/lib/index.js +46 -21
- package/lib/reporters/SpecReporter.js +2 -7
- package/lib/run-results/TestRunResult.d.ts +2 -2
- package/lib/run-results/TestRunResult.js +1 -1
- package/package.json +1 -1
package/lib/StackTrace.d.ts
CHANGED
package/lib/StackTrace.js
CHANGED
|
@@ -1,6 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getCallerLocationText = void 0;
|
|
3
|
+
exports.getCallerLocationText = exports.setStackRoot = void 0;
|
|
4
|
+
function setStackRoot(predicate) {
|
|
5
|
+
const original = Error.prepareStackTrace;
|
|
6
|
+
Error.prepareStackTrace = (error, callsites) => {
|
|
7
|
+
const index = callsites.findIndex(predicate);
|
|
8
|
+
callsites = callsites.slice(0, index);
|
|
9
|
+
const callSiteLines = callsites.map(e => formatCallSiteAt(e));
|
|
10
|
+
const callSitesText = callSiteLines.join("\n");
|
|
11
|
+
return `Error: ${error.message}\n${callSitesText}`;
|
|
12
|
+
};
|
|
13
|
+
return () => Error.prepareStackTrace = original;
|
|
14
|
+
}
|
|
15
|
+
exports.setStackRoot = setStackRoot;
|
|
4
16
|
function getCallerLocationText(currentFunction) {
|
|
5
17
|
const originalLimit = Error.stackTraceLimit;
|
|
6
18
|
const originalPrepare = Error.prepareStackTrace;
|
|
@@ -17,11 +29,19 @@ exports.getCallerLocationText = getCallerLocationText;
|
|
|
17
29
|
function getFirstCallLocation(object, stack) {
|
|
18
30
|
const callSite = stack[0];
|
|
19
31
|
if (!object.originalPrepare)
|
|
20
|
-
return
|
|
32
|
+
return formatCallSite(callSite);
|
|
21
33
|
// Support for ts-node
|
|
22
34
|
const formattedByRuntime = object.originalPrepare(object, [new SimplifiedCallSite(callSite)]);
|
|
23
35
|
return formattedByRuntime.slice("Error\n at ".length);
|
|
24
36
|
}
|
|
37
|
+
function formatCallSite(callSite) {
|
|
38
|
+
return `${callSite.getFileName()}:${callSite.getLineNumber()}:${callSite.getColumnNumber()}`;
|
|
39
|
+
}
|
|
40
|
+
function formatCallSiteAt(callSite) {
|
|
41
|
+
const line = (callSite.getLineNumber() ?? 0) + 1;
|
|
42
|
+
const column = (callSite.getColumnNumber() ?? 0) + 1;
|
|
43
|
+
return `\tat ${callSite.getFileName()}:${line}:${column}`;
|
|
44
|
+
}
|
|
25
45
|
class SimplifiedCallSite {
|
|
26
46
|
constructor(callSite) {
|
|
27
47
|
this.callSite = callSite;
|
|
@@ -41,4 +61,4 @@ class SimplifiedCallSite {
|
|
|
41
61
|
isConstructor() { return false; }
|
|
42
62
|
}
|
|
43
63
|
|
|
44
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,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
|
package/lib/Test.d.ts
CHANGED
package/lib/Test.js
CHANGED
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.Test = void 0;
|
|
4
4
|
const TestRunResult_1 = require("./run-results/TestRunResult");
|
|
5
5
|
const TestStage_1 = require("./TestStage");
|
|
6
|
+
const StackTrace_1 = require("./StackTrace");
|
|
6
7
|
class TestParamsClass {
|
|
7
8
|
constructor() {
|
|
8
9
|
this.stage = TestStage_1.TestStage.NoStage;
|
|
@@ -31,9 +32,11 @@ class Test {
|
|
|
31
32
|
async run(options) {
|
|
32
33
|
const testParams = new TestParamsClass();
|
|
33
34
|
const startTime = performance.now();
|
|
35
|
+
const restoreStackFunc = (0, StackTrace_1.setStackRoot)(callSite => callSite.getTypeName() == Test.name &&
|
|
36
|
+
callSite.getFunctionName() == this.run.name);
|
|
34
37
|
try {
|
|
35
38
|
let result = this.testFunction(testParams);
|
|
36
|
-
if (
|
|
39
|
+
if (this.isPromise(result)) {
|
|
37
40
|
if (options.debug)
|
|
38
41
|
await result;
|
|
39
42
|
else
|
|
@@ -42,11 +45,15 @@ class Test {
|
|
|
42
45
|
return Promise.resolve(new TestRunResult_1.TestRunResult(this.title, performance.now() - startTime, testParams.stage, true));
|
|
43
46
|
}
|
|
44
47
|
catch (reason) {
|
|
45
|
-
|
|
48
|
+
const reasonText = this.stringifyReason(reason);
|
|
49
|
+
return Promise.resolve(new TestRunResult_1.TestRunResult(this.title, performance.now() - startTime, testParams.stage, false, reasonText));
|
|
50
|
+
}
|
|
51
|
+
finally {
|
|
52
|
+
restoreStackFunc();
|
|
46
53
|
}
|
|
47
54
|
}
|
|
48
55
|
isPromise(result) {
|
|
49
|
-
return typeof result.then === "function";
|
|
56
|
+
return !!result && typeof result.then === "function";
|
|
50
57
|
}
|
|
51
58
|
async withTimeout(promise, timeout) {
|
|
52
59
|
let timer = undefined;
|
|
@@ -57,13 +64,20 @@ class Test {
|
|
|
57
64
|
})
|
|
58
65
|
]);
|
|
59
66
|
if (typeof firstValue === "string" && firstValue === "timeout") {
|
|
60
|
-
throw
|
|
67
|
+
throw `Timeout (${timeout} milliseconds).`;
|
|
61
68
|
}
|
|
62
69
|
else {
|
|
63
70
|
clearTimeout(timer);
|
|
64
71
|
}
|
|
65
72
|
}
|
|
73
|
+
stringifyReason(reason) {
|
|
74
|
+
if (typeof reason == "string")
|
|
75
|
+
return reason;
|
|
76
|
+
if (reason instanceof Error && reason.stack)
|
|
77
|
+
return reason.stack;
|
|
78
|
+
return String(reason);
|
|
79
|
+
}
|
|
66
80
|
}
|
|
67
81
|
exports.Test = Test;
|
|
68
82
|
|
|
69
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,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
|
|
@@ -1,9 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
function someFunction() { }
|
|
4
|
+
console.log("When discovering, or using json reporter - Should not print in module scope");
|
|
4
5
|
function default_1(suite) {
|
|
5
6
|
suite.describe("Passing suite", suite => {
|
|
7
|
+
console.log("When discovering, or using json reporter - Should not print in describe");
|
|
6
8
|
suite.test("Simple test", t => {
|
|
9
|
+
console.log("When discovering, or using json reporter - Should not print in test");
|
|
7
10
|
});
|
|
8
11
|
suite.test("Async", async (t) => {
|
|
9
12
|
await Promise.resolve("Hi");
|
|
@@ -54,4 +57,4 @@ exports.default = default_1;
|
|
|
54
57
|
function named_function_test_with_spaces(t) {
|
|
55
58
|
}
|
|
56
59
|
|
|
57
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImV4YW1wbGVzL2V4YW1wbGVUZXN0RmlsZS50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsU0FBUyxZQUFZLEtBQUssQ0FBQztBQUUzQixPQUFPLENBQUMsR0FBRyxDQUFDLDZFQUE2RSxDQUFDLENBQUM7QUFFM0YsbUJBQXlCLEtBQWdCO0lBQ3hDLEtBQUssQ0FBQyxRQUFRLENBQUMsZUFBZSxFQUFFLEtBQUssQ0FBQyxFQUFFO1FBQ3ZDLE9BQU8sQ0FBQyxHQUFHLENBQUMseUVBQXlFLENBQUMsQ0FBQztRQUV2RixLQUFLLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUMsRUFBRTtZQUM3QixPQUFPLENBQUMsR0FBRyxDQUFDLHFFQUFxRSxDQUFDLENBQUM7UUFDcEYsQ0FBQyxDQUFDLENBQUM7UUFFSCxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUMsQ0FBQyxFQUFDLEVBQUU7WUFDN0IsTUFBTSxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzdCLENBQUMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsS0FBSyxDQUFDLEVBQUU7WUFDcEMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQUU7WUFDdkIsQ0FBQyxDQUFDLENBQUM7UUFDSixDQUFDLENBQUMsQ0FBQztJQUNKLENBQUMsQ0FBQyxDQUFDO0lBRUgsS0FBSyxDQUFDLFFBQVEsQ0FBQyxlQUFlLEVBQUUsS0FBSyxDQUFDLEVBQUU7UUFFdkMsS0FBSyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLENBQUMsRUFBRTtZQUNoQyxNQUFNLE1BQU0sQ0FBQztRQUNkLENBQUMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDLEVBQUU7WUFDOUIsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ1osTUFBTSxNQUFNLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FBQztRQUVILEtBQUssQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxFQUFFO1lBQzNCLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNSLE1BQU0sTUFBTSxDQUFDO1FBQ2QsQ0FBQyxDQUFDLENBQUM7UUFFSCxLQUFLLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUMsRUFBRTtZQUM5QixDQUFDLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDWCxNQUFNLE1BQU0sQ0FBQztRQUNkLENBQUMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFDLEVBQUU7WUFDN0IsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ1gsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ3hDLENBQUMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxLQUFLLEVBQUMsQ0FBQyxFQUFDLEVBQUU7WUFDMUMsTUFBTSxJQUFJLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUV6QyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDWCxNQUFNLE9BQU8sQ0FBQztRQUNmLENBQUMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxLQUFLLEVBQUMsQ0FBQyxFQUFDLEVBQUU7WUFDeEMsQ0FBQyxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUM7WUFDZCxNQUFNLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQzVDLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQyxDQUFDLENBQUM7SUFFSCxLQUFLLENBQUMsUUFBUSxDQUFDLGFBQWEsRUFBRSxLQUFLLENBQUMsRUFBRTtJQUN0QyxDQUFDLENBQUMsQ0FBQztJQUVILEtBQUssQ0FBQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLEVBQUU7UUFDekMsS0FBSyxDQUFDLFFBQVEsQ0FBQywrQkFBK0IsQ0FBQyxDQUFDO1FBQ2hELEtBQUssQ0FBQyxRQUFRLENBQUMsU0FBUyxlQUFlLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDaEQsQ0FBQyxDQUFDLENBQUM7QUFDSixDQUFDO0FBaEVELDRCQWdFQztBQUVELFNBQVMsK0JBQStCLENBQUMsQ0FBYTtBQUN0RCxDQUFDIiwiZmlsZSI6ImV4YW1wbGVzL2V4YW1wbGVUZXN0RmlsZS50ZXN0LmpzIiwic291cmNlUm9vdCI6Ii4uXFwuLlxcc3JjIn0=
|
package/lib/index.js
CHANGED
|
@@ -39,13 +39,7 @@ async function main() {
|
|
|
39
39
|
(0, help_1.printHelp)(OptionsDefinitions_1.optionsDefinitions);
|
|
40
40
|
return;
|
|
41
41
|
}
|
|
42
|
-
const
|
|
43
|
-
const testFilesPromise = getTestFilesAsync(options);
|
|
44
|
-
const directorySuitesPromise = getDirectorySuitesAsync(options);
|
|
45
|
-
const directorySuites = await directorySuitesPromise;
|
|
46
|
-
const suiteProvider = new SuiteProvider_1.SuiteProvider(directorySuites);
|
|
47
|
-
const testFiles = await testFilesPromise;
|
|
48
|
-
restoreConsole();
|
|
42
|
+
const { testFiles, suiteProvider } = await resolveFiles(options);
|
|
49
43
|
if (options.discover) {
|
|
50
44
|
await outputDiscoveredTests(testFiles, suiteProvider);
|
|
51
45
|
return;
|
|
@@ -60,12 +54,29 @@ async function main() {
|
|
|
60
54
|
}
|
|
61
55
|
}
|
|
62
56
|
;
|
|
57
|
+
async function resolveFiles(options) {
|
|
58
|
+
const restoreConsole = disableConsole();
|
|
59
|
+
try {
|
|
60
|
+
const testFilesPromise = getTestFilesAsync(options);
|
|
61
|
+
const directorySuitesPromise = getDirectorySuitesAsync(options);
|
|
62
|
+
const directorySuites = await directorySuitesPromise;
|
|
63
|
+
const suiteProvider = new SuiteProvider_1.SuiteProvider(directorySuites);
|
|
64
|
+
const testFiles = await testFilesPromise;
|
|
65
|
+
return { testFiles, suiteProvider };
|
|
66
|
+
}
|
|
67
|
+
finally {
|
|
68
|
+
restoreConsole();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
63
71
|
function disableConsole() {
|
|
64
72
|
const original = console;
|
|
73
|
+
console = createFakeConsole();
|
|
74
|
+
return () => { console = original; };
|
|
75
|
+
}
|
|
76
|
+
function createFakeConsole() {
|
|
65
77
|
function nothing() { }
|
|
66
78
|
;
|
|
67
|
-
|
|
68
|
-
return () => { console = original; };
|
|
79
|
+
return { log: nothing, info: nothing, debug: nothing, warn: nothing, error: nothing };
|
|
69
80
|
}
|
|
70
81
|
async function getTestFilesAsync(options) {
|
|
71
82
|
return await globAsync(options.glob);
|
|
@@ -84,15 +95,22 @@ function globAsync(pattern) {
|
|
|
84
95
|
});
|
|
85
96
|
}
|
|
86
97
|
async function test(files, suiteProvider, options) {
|
|
87
|
-
const reporter = createReporter(options.reporter);
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
suite
|
|
93
|
-
|
|
98
|
+
const reporter = createReporter(options.reporter, console);
|
|
99
|
+
const restoreConsole = options.reporter == "json" ?
|
|
100
|
+
disableConsole() :
|
|
101
|
+
() => { };
|
|
102
|
+
try {
|
|
103
|
+
const suite = await createTree(files, suiteProvider);
|
|
104
|
+
reporter.listenTo(suite);
|
|
105
|
+
if (options.filter)
|
|
106
|
+
suite.treeShake(options.filter.toLowerCase());
|
|
107
|
+
return await suite.run({ debug: options.debug });
|
|
108
|
+
}
|
|
109
|
+
finally {
|
|
110
|
+
restoreConsole();
|
|
111
|
+
}
|
|
94
112
|
}
|
|
95
|
-
function createReporter(reporter) {
|
|
113
|
+
function createReporter(reporter, console) {
|
|
96
114
|
switch (reporter) {
|
|
97
115
|
case "spec":
|
|
98
116
|
return new reporters_1.SpecReporter(console);
|
|
@@ -115,18 +133,25 @@ async function getTestFileFunctionAsync(file) {
|
|
|
115
133
|
testFileFunction = await Promise.resolve().then(() => __importStar(require(path_1.default.resolve(file))));
|
|
116
134
|
}
|
|
117
135
|
catch (reason) {
|
|
118
|
-
throw `The file
|
|
136
|
+
throw `The file "${file}" matched the tests glob but failed to be imported. reason: ${reason}`;
|
|
119
137
|
}
|
|
120
138
|
if (typeof testFileFunction != "function")
|
|
121
139
|
testFileFunction = testFileFunction.default;
|
|
122
140
|
if (typeof testFileFunction != "function") {
|
|
123
|
-
throw `The file
|
|
141
|
+
throw `The file "${file}" matched the tests glob but did not export a default function.`;
|
|
124
142
|
}
|
|
125
143
|
return testFileFunction;
|
|
126
144
|
}
|
|
127
145
|
async function outputDiscoveredTests(files, suiteProvider) {
|
|
128
|
-
|
|
146
|
+
const restoreConsole = disableConsole();
|
|
147
|
+
let suite;
|
|
148
|
+
try {
|
|
149
|
+
suite = await createTree(files, suiteProvider);
|
|
150
|
+
}
|
|
151
|
+
finally {
|
|
152
|
+
restoreConsole();
|
|
153
|
+
}
|
|
129
154
|
console.log(JSON.stringify(suite.discover()));
|
|
130
155
|
}
|
|
131
156
|
|
|
132
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
157
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,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QUMsT0FBTyxDQUFDLENBQUM7UUFDbEMsS0FBSyxNQUFNO1lBQ1YsT0FBTyxJQUFJLHdCQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7S0FDbEM7QUFDRixDQUFDO0FBRUQsS0FBSyxVQUFVLFVBQVUsQ0FBQyxVQUFvQixFQUFFLGFBQTRCO0lBQzNFLEtBQUssSUFBSSxRQUFRLElBQUksVUFBVSxFQUFFO1FBQ2hDLE1BQU0sZUFBZSxHQUFHLHdCQUF3QixDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzNELE1BQU0sS0FBSyxHQUFHLGFBQWEsQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUUxRCxNQUFNLFFBQVEsR0FBRyxNQUFNLGVBQWUsQ0FBQztRQUN2QyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDaEI7SUFFRCxPQUFPLGFBQWEsQ0FBQyxJQUFJLENBQUM7QUFDM0IsQ0FBQztBQUVELEtBQUssVUFBVSx3QkFBd0IsQ0FBQyxJQUFZO0lBQ25ELElBQUksZ0JBQXFCLENBQUM7SUFFMUIsSUFBSTtRQUNILGdCQUFnQixHQUFHLHdEQUFhLGNBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUMsQ0FBQztLQUNwRDtJQUNELE9BQU8sTUFBTSxFQUFFO1FBQ2QsTUFBTSxhQUFhLElBQUksK0RBQStELE1BQU0sRUFBRSxDQUFDO0tBQy9GO0lBRUQsSUFBSSxPQUFPLGdCQUFnQixJQUFJLFVBQVU7UUFDeEMsZ0JBQWdCLEdBQUcsZ0JBQWdCLENBQUMsT0FBTyxDQUFDO0lBRTdDLElBQUksT0FBTyxnQkFBZ0IsSUFBSSxVQUFVLEVBQUU7UUFDMUMsTUFBTSxhQUFhLElBQUksaUVBQWlFLENBQUM7S0FDekY7SUFFRCxPQUFPLGdCQUFnQixDQUFDO0FBQ3pCLENBQUM7QUFFRCxLQUFLLFVBQVUscUJBQXFCLENBQUMsS0FBZSxFQUFFLGFBQTRCO0lBQ2pGLE1BQU0sY0FBYyxHQUFHLGNBQWMsRUFBRSxDQUFDO0lBQ3hDLElBQUksS0FBWSxDQUFDO0lBRWpCLElBQUk7UUFDSCxLQUFLLEdBQUcsTUFBTSxVQUFVLENBQUMsS0FBSyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0tBQy9DO1lBQ087UUFDUCxjQUFjLEVBQUUsQ0FBQztLQUNqQjtJQUVELE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQy9DLENBQUMiLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiLi5cXHNyYyJ9
|
|
@@ -54,12 +54,7 @@ class SpecReporter {
|
|
|
54
54
|
this.output.log();
|
|
55
55
|
let title = this.getTestFullTitle(failedTestRun.test);
|
|
56
56
|
this.output.log(title);
|
|
57
|
-
|
|
58
|
-
let message = isError ?
|
|
59
|
-
failedTestRun.result.reason.message :
|
|
60
|
-
JSON.stringify(failedTestRun.result.reason);
|
|
61
|
-
this.output.log(this.indentation + chalk_1.default.red(`${message}`));
|
|
62
|
-
isError && this.output.log(this.indentation + `${failedTestRun.result.reason.stack}`);
|
|
57
|
+
this.output.log(this.indentation + chalk_1.default.red(`${failedTestRun.result.reason}`));
|
|
63
58
|
}
|
|
64
59
|
this.output.log();
|
|
65
60
|
this.output.log(chalk_1.default.green(`${this.passedCount} passing`));
|
|
@@ -87,4 +82,4 @@ class SpecReporter {
|
|
|
87
82
|
}
|
|
88
83
|
exports.SpecReporter = SpecReporter;
|
|
89
84
|
|
|
90
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlcG9ydGVycy9TcGVjUmVwb3J0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsa0RBQTBCO0FBSzFCLE1BQWEsWUFBWTtJQVd4QixZQUFvQixNQUFlO1FBQWYsV0FBTSxHQUFOLE1BQU0sQ0FBUztRQVYzQixZQUFPLEdBQUc7WUFDakIsRUFBRSxFQUFFLEdBQUc7WUFDUCxHQUFHLEVBQUUsR0FBRztTQUNSLENBQUM7UUFFTSxnQkFBVyxHQUFHLElBQUksQ0FBQztRQUVuQixnQkFBVyxHQUFHLENBQUMsQ0FBQztRQUNoQixXQUFNLEdBQW9CLEVBQUUsQ0FBQztJQUdyQyxDQUFDO0lBRU0sUUFBUSxDQUFDLFNBQWdCO1FBQy9CLElBQUksTUFBTSxHQUFHLEVBQUUsQ0FBQztRQUVoQixTQUFTLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNwQyxJQUFJLEtBQUssSUFBSSxTQUFTO2dCQUNyQixPQUFPO1lBRVIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNsQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3ZDLE1BQU0sSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQzVCLENBQUMsQ0FBQyxDQUFDO1FBRUgsU0FBUyxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDakMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUVuRSxJQUFJLElBQUksQ0FBQyxLQUFLLElBQUksU0FBUyxFQUFFO2dCQUM1QixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7YUFDYjtRQUNGLENBQUMsQ0FBQyxDQUFDO1FBRUgsU0FBUyxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDaEMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztZQUMzQixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUVuRCxJQUFJLE1BQU0sQ0FBQyxNQUFNLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztnQkFDbkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsZUFBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUUsSUFBSSxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsR0FBRyxJQUFJLE9BQU8sRUFBRSxDQUFDLENBQUM7YUFDNUY7aUJBQ0k7Z0JBQ0osSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3ZCLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxNQUFNLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQyxDQUFDO2FBQzNGO1FBQ0YsQ0FBQyxDQUFDLENBQUM7SUFDSixDQUFDO0lBRU8sS0FBSztRQUNaLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTTtZQUNmLE9BQU87UUFFUixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBRWpDLEtBQUssSUFBSSxhQUFhLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUN0QyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDO1lBRWxCLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFFdkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxlQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsYUFBYSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUM7U0FDaEY7UUFFRCxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBRTVELElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQzNCLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sVUFBVSxDQUFDLENBQUMsQ0FBQztTQUM1RDtRQUVELElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVPLGFBQWEsQ0FBQyxPQUFlO1FBQ3BDLE9BQU8sZUFBSyxDQUFDLElBQUksQ0FBQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyxJQUFVO1FBQ2xDLElBQUksTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTFCLElBQUksTUFBTSxHQUFzQixJQUFJLENBQUMsTUFBTSxDQUFDO1FBRTVDLE9BQU8sTUFBTSxJQUFJLE1BQU0sQ0FBQyxLQUFLLEVBQUU7WUFDOUIsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDMUIsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7U0FDdkI7UUFFRCxJQUFJLEtBQUssR0FBRyxNQUFNLENBQUMsR0FBRyxFQUFHLENBQUM7UUFFMUIsT0FBTyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN6QixLQUFLLElBQUksTUFBTSxHQUFHLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQztTQUMvQjtRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2QsQ0FBQztDQUNEO0FBbEdELG9DQWtHQyIsImZpbGUiOiJyZXBvcnRlcnMvU3BlY1JlcG9ydGVyLmpzIiwic291cmNlUm9vdCI6Ii4uXFwuLlxcc3JjIn0=
|
|
@@ -4,6 +4,6 @@ export declare class TestRunResult {
|
|
|
4
4
|
elapsed: number;
|
|
5
5
|
stage: TestStage;
|
|
6
6
|
passed: boolean;
|
|
7
|
-
reason?:
|
|
8
|
-
constructor(title: string, elapsed: number, stage: TestStage, passed: boolean, reason?:
|
|
7
|
+
reason?: string | undefined;
|
|
8
|
+
constructor(title: string, elapsed: number, stage: TestStage, passed: boolean, reason?: string | undefined);
|
|
9
9
|
}
|
|
@@ -12,4 +12,4 @@ class TestRunResult {
|
|
|
12
12
|
}
|
|
13
13
|
exports.TestRunResult = TestRunResult;
|
|
14
14
|
|
|
15
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJ1bi1yZXN1bHRzL1Rlc3RSdW5SZXN1bHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsTUFBYSxhQUFhO0lBQ3pCLFlBQW1CLEtBQWEsRUFBUyxPQUFlLEVBQVMsS0FBZ0IsRUFBUyxNQUFlLEVBQVMsTUFBZTtRQUE5RyxVQUFLLEdBQUwsS0FBSyxDQUFRO1FBQVMsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUFTLFVBQUssR0FBTCxLQUFLLENBQVc7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFTO1FBQVMsV0FBTSxHQUFOLE1BQU0sQ0FBUztJQUNqSSxDQUFDO0NBQ0Q7QUFIRCxzQ0FHQyIsImZpbGUiOiJydW4tcmVzdWx0cy9UZXN0UnVuUmVzdWx0LmpzIiwic291cmNlUm9vdCI6Ii4uXFwuLlxcc3JjIn0=
|