2018-05-14 19:33:16 +02:00
|
|
|
/* eslint no-console: 0 */
|
|
|
|
|
|
|
|
/**
|
2018-05-17 17:11:34 +02:00
|
|
|
* Test Runner
|
2018-05-14 19:33:16 +02:00
|
|
|
*
|
|
|
|
* For running the tests in the test register.
|
|
|
|
*
|
|
|
|
* @author tlwr [toby@toby.codes]
|
|
|
|
* @author n1474335 [n1474335@gmail.com]
|
|
|
|
* @copyright Crown Copyright 2017
|
|
|
|
* @license Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Define global environment functions
|
|
|
|
global.ENVIRONMENT_IS_WORKER = function() {
|
|
|
|
return typeof importScripts === "function";
|
|
|
|
};
|
|
|
|
global.ENVIRONMENT_IS_NODE = function() {
|
|
|
|
return typeof process === "object" && typeof require === "function";
|
|
|
|
};
|
|
|
|
global.ENVIRONMENT_IS_WEB = function() {
|
|
|
|
return typeof window === "object";
|
|
|
|
};
|
|
|
|
|
|
|
|
import TestRegister from "./TestRegister";
|
2018-12-28 22:49:40 +01:00
|
|
|
import "./tests/BCD";
|
|
|
|
import "./tests/BSON";
|
|
|
|
import "./tests/Base58";
|
|
|
|
import "./tests/Base64";
|
|
|
|
import "./tests/Base62";
|
|
|
|
import "./tests/BitwiseOp";
|
|
|
|
import "./tests/ByteRepr";
|
|
|
|
import "./tests/CartesianProduct";
|
|
|
|
import "./tests/CharEnc";
|
2019-03-14 14:37:11 +01:00
|
|
|
import "./tests/Charts";
|
2018-12-28 22:49:40 +01:00
|
|
|
import "./tests/Checksum";
|
|
|
|
import "./tests/Ciphers";
|
|
|
|
import "./tests/Code";
|
|
|
|
import "./tests/Comment";
|
|
|
|
import "./tests/Compress";
|
|
|
|
import "./tests/ConditionalJump";
|
|
|
|
import "./tests/Crypt";
|
|
|
|
import "./tests/CSV";
|
|
|
|
import "./tests/DateTime";
|
|
|
|
import "./tests/ExtractEmailAddresses";
|
|
|
|
import "./tests/Fork";
|
|
|
|
import "./tests/FromDecimal";
|
|
|
|
import "./tests/Hash";
|
|
|
|
import "./tests/HaversineDistance";
|
|
|
|
import "./tests/Hexdump";
|
|
|
|
import "./tests/Image";
|
2019-06-08 22:49:31 +02:00
|
|
|
import "./tests/IndexOfCoincidence";
|
2018-12-28 22:49:40 +01:00
|
|
|
import "./tests/Jump";
|
|
|
|
import "./tests/JSONBeautify";
|
|
|
|
import "./tests/JSONMinify";
|
2019-04-28 22:29:15 +02:00
|
|
|
import "./tests/JSONtoCSV";
|
2018-12-28 22:49:40 +01:00
|
|
|
import "./tests/JWTDecode";
|
|
|
|
import "./tests/JWTSign";
|
|
|
|
import "./tests/JWTVerify";
|
|
|
|
import "./tests/MS";
|
|
|
|
import "./tests/Magic";
|
|
|
|
import "./tests/MorseCode";
|
|
|
|
import "./tests/NetBIOS";
|
|
|
|
import "./tests/OTP";
|
|
|
|
import "./tests/PGP";
|
|
|
|
import "./tests/PHP";
|
|
|
|
import "./tests/ParseIPRange";
|
|
|
|
import "./tests/ParseQRCode";
|
|
|
|
import "./tests/PowerSet";
|
|
|
|
import "./tests/Regex";
|
|
|
|
import "./tests/Register";
|
|
|
|
import "./tests/RemoveDiacritics";
|
|
|
|
import "./tests/Rotate";
|
|
|
|
import "./tests/SeqUtils";
|
|
|
|
import "./tests/SetDifference";
|
|
|
|
import "./tests/SetIntersection";
|
|
|
|
import "./tests/SetUnion";
|
|
|
|
import "./tests/StrUtils";
|
|
|
|
import "./tests/SymmetricDifference";
|
|
|
|
import "./tests/TextEncodingBruteForce";
|
|
|
|
import "./tests/TranslateDateTimeFormat";
|
|
|
|
import "./tests/Magic";
|
|
|
|
import "./tests/ParseTLV";
|
|
|
|
import "./tests/Media";
|
2019-01-10 15:53:21 +01:00
|
|
|
import "./tests/ToFromInsensitiveRegex";
|
2019-01-15 17:24:29 +01:00
|
|
|
import "./tests/YARA.mjs";
|
2019-01-18 17:05:44 +01:00
|
|
|
import "./tests/ConvertCoordinateFormat";
|
2019-01-03 17:36:56 +01:00
|
|
|
import "./tests/Enigma";
|
2019-01-04 14:33:31 +01:00
|
|
|
import "./tests/Bombe";
|
2019-01-10 19:04:02 +01:00
|
|
|
import "./tests/MultipleBombe";
|
2019-02-28 18:22:09 +01:00
|
|
|
import "./tests/Typex";
|
2019-03-26 20:09:57 +01:00
|
|
|
import "./tests/BLAKE2b";
|
|
|
|
import "./tests/BLAKE2s";
|
2019-04-12 17:13:10 +02:00
|
|
|
import "./tests/Protobuf";
|
2018-05-14 19:33:16 +02:00
|
|
|
|
2018-12-26 17:33:10 +01:00
|
|
|
// Cannot test operations that use the File type yet
|
2018-12-28 22:49:40 +01:00
|
|
|
//import "./tests/SplitColourChannels";
|
2018-12-26 17:33:10 +01:00
|
|
|
|
2018-05-14 19:33:16 +02:00
|
|
|
let allTestsPassing = true;
|
|
|
|
const testStatusCounts = {
|
|
|
|
total: 0,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper function to convert a status to an icon.
|
|
|
|
*
|
|
|
|
* @param {string} status
|
|
|
|
* @returns {string}
|
|
|
|
*/
|
|
|
|
function statusToIcon(status) {
|
|
|
|
const icons = {
|
|
|
|
erroring: "🔥",
|
|
|
|
failing: "❌",
|
|
|
|
passing: "✔️️",
|
|
|
|
};
|
|
|
|
return icons[status] || "?";
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Displays a given test result in the console.
|
|
|
|
*
|
|
|
|
* @param {Object} testResult
|
|
|
|
*/
|
|
|
|
function handleTestResult(testResult) {
|
|
|
|
allTestsPassing = allTestsPassing && testResult.status === "passing";
|
|
|
|
const newCount = (testStatusCounts[testResult.status] || 0) + 1;
|
|
|
|
testStatusCounts[testResult.status] = newCount;
|
|
|
|
testStatusCounts.total += 1;
|
|
|
|
|
|
|
|
console.log([
|
|
|
|
statusToIcon(testResult.status),
|
|
|
|
testResult.test.name
|
|
|
|
].join(" "));
|
|
|
|
|
|
|
|
if (testResult.output) {
|
|
|
|
console.log(
|
|
|
|
testResult.output
|
|
|
|
.trim()
|
|
|
|
.replace(/^/, "\t")
|
|
|
|
.replace(/\n/g, "\n\t")
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2018-11-13 18:54:43 +01:00
|
|
|
* Fail if the process takes longer than 60 seconds.
|
2018-05-14 19:33:16 +02:00
|
|
|
*/
|
|
|
|
setTimeout(function() {
|
2018-11-13 18:54:43 +01:00
|
|
|
console.log("Tests took longer than 60 seconds to run, returning.");
|
2018-05-14 19:33:16 +02:00
|
|
|
process.exit(1);
|
2018-11-13 18:54:43 +01:00
|
|
|
}, 60 * 1000);
|
2018-05-14 19:33:16 +02:00
|
|
|
|
|
|
|
|
|
|
|
TestRegister.runTests()
|
|
|
|
.then(function(results) {
|
|
|
|
results.forEach(handleTestResult);
|
|
|
|
|
|
|
|
console.log("\n");
|
|
|
|
|
|
|
|
for (const testStatus in testStatusCounts) {
|
|
|
|
const count = testStatusCounts[testStatus];
|
|
|
|
if (count > 0) {
|
|
|
|
console.log(testStatus.toUpperCase(), count);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!allTestsPassing) {
|
2018-12-25 23:38:53 +01:00
|
|
|
console.log("\nFailing tests:\n");
|
|
|
|
results.filter(r => r.status !== "passing").forEach(handleTestResult);
|
2018-05-14 19:33:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
process.exit(allTestsPassing ? 0 : 1);
|
|
|
|
});
|