2011-01-25 16:59:32 +01:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
2012-04-16 15:26:42 +02:00
|
|
|
var util = require("util"),
|
|
|
|
fs = require("fs"),
|
|
|
|
PEG = require("../lib/peg"),
|
|
|
|
QUnit = require("./vendor/qunit/qunit");
|
|
|
|
|
|
|
|
var failedAssertions = [];
|
2011-01-25 16:59:32 +01:00
|
|
|
|
|
|
|
function bold(s) { return "\u001B[1m" + s + "\u001B[22m"; };
|
|
|
|
function message(s) { return "\u001B[35m" + s + "\u001B[39m"; };
|
|
|
|
function ok(s) { return "\u001B[32m" + s + "\u001B[39m"; };
|
|
|
|
function error(s) { return "\u001B[31m" + s + "\u001B[39m"; };
|
|
|
|
|
2012-04-16 15:29:04 +02:00
|
|
|
function indent(s) { return s.replace(/^/gm, " "); }
|
2011-01-25 16:59:32 +01:00
|
|
|
|
|
|
|
QUnit.init();
|
2012-04-16 15:26:42 +02:00
|
|
|
QUnit.config.blocking = true;
|
2011-01-25 16:59:32 +01:00
|
|
|
QUnit.config.updateRate = 0;
|
|
|
|
|
2012-04-16 14:54:34 +02:00
|
|
|
QUnit.moduleStart(function(details) {
|
2012-01-07 12:01:11 +01:00
|
|
|
util.puts("");
|
|
|
|
util.puts(bold(details.name));
|
2012-04-16 14:54:34 +02:00
|
|
|
});
|
2011-01-25 16:59:32 +01:00
|
|
|
|
2012-04-16 14:54:34 +02:00
|
|
|
QUnit.testStart(function(details) {
|
2011-01-25 16:59:32 +01:00
|
|
|
failedAssertions = [];
|
2012-04-16 14:54:34 +02:00
|
|
|
});
|
2011-01-25 16:59:32 +01:00
|
|
|
|
2012-04-16 14:54:34 +02:00
|
|
|
QUnit.testDone(function(details) {
|
2011-01-25 16:59:32 +01:00
|
|
|
if (details.failed == 0) {
|
2012-01-07 12:01:11 +01:00
|
|
|
util.puts('✔ ' + details.name);
|
2011-01-25 16:59:32 +01:00
|
|
|
} else {
|
2012-01-07 12:01:11 +01:00
|
|
|
util.puts(error('✖ ' + details.name));
|
|
|
|
util.puts("");
|
2011-01-25 16:59:32 +01:00
|
|
|
failedAssertions.forEach(function(assertion) {
|
2012-01-07 12:01:11 +01:00
|
|
|
util.puts(assertion);
|
2011-01-25 16:59:32 +01:00
|
|
|
});
|
|
|
|
}
|
2012-04-16 14:54:34 +02:00
|
|
|
});
|
2011-01-25 16:59:32 +01:00
|
|
|
|
2012-04-16 14:54:34 +02:00
|
|
|
QUnit.log(function(details) {
|
2012-04-16 15:26:42 +02:00
|
|
|
var output = "";
|
|
|
|
|
2011-01-25 16:59:32 +01:00
|
|
|
if (details.result) { return; }
|
|
|
|
|
|
|
|
if (details.message) {
|
|
|
|
output += indent("Message: " + message(details.message)) + "\n";
|
|
|
|
}
|
|
|
|
if (details.actual && details.expected) {
|
|
|
|
output += indent("Expected: " + QUnit.jsDump.parse(details.expected)) + "\n";
|
|
|
|
if (details.actual != details.expected) {
|
2011-09-18 18:05:10 +02:00
|
|
|
output += indent("Actual: " + QUnit.jsDump.parse(details.actual));
|
2011-01-25 16:59:32 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
failedAssertions.push(output);
|
2012-04-16 14:54:34 +02:00
|
|
|
});
|
2011-01-25 16:59:32 +01:00
|
|
|
|
2012-04-16 14:54:34 +02:00
|
|
|
QUnit.done(function(details) {
|
2012-01-07 12:01:11 +01:00
|
|
|
util.puts("");
|
2011-01-25 16:59:32 +01:00
|
|
|
if (details.failed > 0) {
|
2012-01-07 12:01:11 +01:00
|
|
|
util.puts(bold(error("FAILURES: "))
|
2011-01-25 16:59:32 +01:00
|
|
|
+ details.failed + "/"
|
|
|
|
+ details.total + " assertions failed ("
|
|
|
|
+ details.runtime + " ms)"
|
|
|
|
);
|
|
|
|
} else {
|
2012-01-07 12:01:11 +01:00
|
|
|
util.puts(bold(ok('OK: '))
|
2011-01-25 16:59:32 +01:00
|
|
|
+ details.total + " assertions ("
|
|
|
|
+ details.runtime + " ms)"
|
|
|
|
)
|
|
|
|
}
|
2012-04-16 14:54:34 +02:00
|
|
|
});
|
2011-01-25 16:59:32 +01:00
|
|
|
|
|
|
|
[
|
|
|
|
"helpers.js",
|
|
|
|
"parser-test.js",
|
|
|
|
"passes-test.js",
|
2011-01-26 13:05:40 +01:00
|
|
|
"compiler-test.js",
|
2011-01-25 16:59:32 +01:00
|
|
|
].forEach(function(file) {
|
2011-01-26 16:08:03 +01:00
|
|
|
eval("with (QUnit) {" + fs.readFileSync(__dirname + "/" + file, "utf8") + "}");
|
2011-01-25 16:59:32 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
QUnit.start();
|