wallet-core/tooling/talertest/talertest.ts

123 lines
3.1 KiB
TypeScript
Raw Normal View History

2016-11-02 21:13:56 +01:00
/*
This file is part of TALER
(C) 2016 Inria
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU General Public License as published by the Free Software
Foundation; either version 3, or (at your option) any later version.
TALER is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with
TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
*/
/**
*
* @author Florian Dold
*/
export type TestFn = (t: TestLib) => void | Promise<void>;
2016-11-02 21:13:56 +01:00
interface Test {
name: string;
testFn: TestFn;
}
export interface TestLib {
pass(msg?: string): void;
fail(msg?: string): void;
assert(v: any, msg?: string): void;
assertEqualsStrict(v1: any, v2: any, msg?: string): void;
2016-11-02 21:13:56 +01:00
}
let tests: Test[] = [];
let testRunner: any;
/**
* Register a test case.
*/
export function test(name: string, testFn: TestFn) {
tests.push({name, testFn});
}
/**
* Run all registered test case, producing a TAP stream.
*/
2016-11-13 17:37:48 +01:00
export async function run(statusCallback?: (m: string) => void) {
2016-11-02 21:13:56 +01:00
console.log(`1..${tests.length}`);
for (let i in tests) {
let t = tests[i];
2016-11-08 16:52:03 +01:00
let passed = false;
2016-11-02 21:13:56 +01:00
let lastMsg: string|undefined = undefined;
let p = new Promise((resolve, reject) => {
let pass = (msg?: string) => {
2016-11-08 16:52:03 +01:00
if (passed) {
2016-11-14 03:37:35 +01:00
let e = Error("test passed twice");
reject(e);
throw e;
2016-11-08 16:52:03 +01:00
}
passed = true;
2016-11-02 21:13:56 +01:00
lastMsg = msg;
resolve();
};
let fail = (msg?: string) => {
lastMsg = msg;
2016-11-14 03:37:35 +01:00
let e = Error("test failed");
reject(e);
throw e;
2016-11-02 21:13:56 +01:00
};
let assert = (v: any, msg?: string) => {
if (!v) {
lastMsg = msg;
2016-11-14 03:37:35 +01:00
reject(Error("test failed"));
return;
2016-11-02 21:13:56 +01:00
}
};
let assertEqualsStrict = (v1: any, v2: any, msg?: string) => {
if (v1 !== v2) {
console.log(`# expected: ${v1}`);
console.log(`# actual: ${v2}`);
lastMsg = msg;
2016-11-14 03:37:35 +01:00
let e = Error("test failed");
reject(e);
throw e;
}
};
2016-11-08 16:52:03 +01:00
// Test might return a promise. If so, wait for it.
let r = t.testFn({pass,fail, assert, assertEqualsStrict});
if (r) {
r.then(() => pass(), (e) => fail(e.toString()));
}
2016-11-02 21:13:56 +01:00
});
console.log(`# ${t.name}`);
2016-11-13 17:37:48 +01:00
statusCallback && statusCallback(`starting test ${t.name}`);
2016-11-02 21:13:56 +01:00
if (!lastMsg) {
lastMsg = "-";
}
try {
await p;
2016-11-08 16:55:21 +01:00
if (!passed) {
2016-11-08 16:52:03 +01:00
throw Error("test did not call 'pass'");
}
2016-11-08 16:56:58 +01:00
console.log(`ok ${Number(i) + 1} ${lastMsg || "-"}`);
2016-11-13 17:37:48 +01:00
statusCallback && statusCallback(`finished test ${t.name}`);
2016-11-02 21:13:56 +01:00
} catch (e) {
2016-11-14 03:37:35 +01:00
try {
console.error(e.stack);
} catch (e2) {
console.error(e);
}
2016-11-08 16:56:58 +01:00
console.log(`not ok ${Number(i) + 1} ${lastMsg || "-"}`);
2016-11-13 17:37:48 +01:00
statusCallback && statusCallback(`failed test ${t.name}`);
2016-11-02 21:13:56 +01:00
}
}
}