1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104QUnit.config.requireExpects = true;
QUnit.begin(begin);
QUnit.log(testLog);
QUnit.testDone(testDone);
QUnit.done(done);
var testLogEntries = {};
// ******************************
function begin(details){
printEnvNotification();
if (details.totalTests > 0) {
console.log(`FPO Test Suite (${details.totalTests})`);
console.log("");
}
else {
console.log(`FPO Test Suite: empty!`);
process.exit(1);
}
}
function testLog(details) {
var testId = details.testId;
testLogEntries[testId] = testLogEntries[testId] || {};
testLogEntries[testId][details.message] = details;
}
function testDone(results){
var testId = results.testId;
if (results.failed > 0) {
console.log(`Failed: '${results.name}' (${results.failed}/${results.total})`);
for (let i = 0; i < results.assertions.length; i++) {
if (results.assertions[i].result === false) {
let { message, expected, actual } = testLogEntries[testId][results.assertions[i].message];
console.log(` ${message}`);
console.log(` expected: ${prettyPrint(expected)}`);
console.log(` actual: ${prettyPrint(actual)}`);
}
}
}
else if (results.passed > 0) {
console.log(`Passed: '${results.name}' (${results.passed}/${results.total})`);
}
else {
console.log(`No assertions run: '${results.name}'`);
}
}
function done(results){
console.log("");
if (results.failed > 0) {
console.log(`Failed (${results.failed}/${results.total})`);
printEnvNotification();
process.exit(1);
}
else if (results.passed > 0) {
console.log(`Passed (${results.passed}/${results.total})`);
printEnvNotification();
process.exit(0);
}
else {
console.log("No tests run!");
printEnvNotification();
process.exit(1);
}
}
function prettyPrint(v) {
if (Array.isArray(v)) {
return `[${ v.map( prettyPrint ).toString() }]`;
}
else if (v && typeof v == "object") {
return JSON.stringify(v,function(k,v){
if (v === undefined) {
return null;
}
return v;
});
}
return String(v);
}
function printEnvNotification() {
console.log("");
console.log("**********************************");
if (process.env.TEST_DIST) {
console.log("********** TESTING DIST **********");
}
else if (process.env.TEST_PACKAGE) {
console.log("******** TESTING PACKAGE *********");
}
else {
console.log("********** TESTING SRC ***********");
}
console.log("**********************************");
console.log("");
}