8eeb0bcbe4
This way it's no longer necessary to load it as a script in the html-files.
93 lines
2.7 KiB
JavaScript
93 lines
2.7 KiB
JavaScript
const TestReporter = function (browser) {
|
|
function send(action, json, cb) {
|
|
const r = new XMLHttpRequest();
|
|
// (The POST URI is ignored atm.)
|
|
r.open("POST", action, true);
|
|
r.setRequestHeader("Content-Type", "application/json");
|
|
r.onreadystatechange = function sendTaskResultOnreadystatechange(e) {
|
|
if (r.readyState === 4) {
|
|
// Retry until successful
|
|
if (r.status !== 200) {
|
|
send(action, json, cb);
|
|
} else {
|
|
if (cb) {
|
|
cb();
|
|
}
|
|
}
|
|
}
|
|
};
|
|
json.browser = browser;
|
|
r.send(JSON.stringify(json));
|
|
}
|
|
|
|
function sendInfo(message) {
|
|
send("/info", { message });
|
|
}
|
|
|
|
function sendResult(status, description, error) {
|
|
const message = {
|
|
status,
|
|
description,
|
|
};
|
|
if (typeof error !== "undefined") {
|
|
message.error = error;
|
|
}
|
|
send("/submit_task_results", message);
|
|
}
|
|
|
|
function sendQuitRequest() {
|
|
send(`/tellMeToQuit?browser=${escape(browser)}`, {});
|
|
}
|
|
|
|
this.now = function () {
|
|
return new Date().getTime();
|
|
};
|
|
|
|
this.jasmineStarted = function (suiteInfo) {
|
|
this.runnerStartTime = this.now();
|
|
|
|
const total = suiteInfo.totalSpecsDefined;
|
|
const seed = suiteInfo.order.seed;
|
|
sendInfo(`Started ${total} tests for ${browser} with seed ${seed}.`);
|
|
};
|
|
|
|
this.suiteStarted = function (result) {
|
|
// Normally suite starts don't have to be reported because the individual
|
|
// specs inside them are reported, but it can happen that the suite cannot
|
|
// start, for instance due to an uncaught exception in `beforeEach`. This
|
|
// is problematic because the specs inside the suite will never be found
|
|
// and run, so if we don't report the suite start failure here it would be
|
|
// ignored silently, leading to passing tests even though some did not run.
|
|
if (result.failedExpectations.length > 0) {
|
|
let failedMessages = "";
|
|
for (const item of result.failedExpectations) {
|
|
failedMessages += `${item.message} `;
|
|
}
|
|
sendResult("TEST-UNEXPECTED-FAIL", result.description, failedMessages);
|
|
}
|
|
};
|
|
|
|
this.specStarted = function (result) {};
|
|
|
|
this.specDone = function (result) {
|
|
if (result.failedExpectations.length === 0) {
|
|
sendResult("TEST-PASSED", result.description);
|
|
} else {
|
|
let failedMessages = "";
|
|
for (const item of result.failedExpectations) {
|
|
failedMessages += `${item.message} `;
|
|
}
|
|
sendResult("TEST-UNEXPECTED-FAIL", result.description, failedMessages);
|
|
}
|
|
};
|
|
|
|
this.suiteDone = function (result) {};
|
|
|
|
this.jasmineDone = function () {
|
|
// Give the test runner some time process any queued requests.
|
|
setTimeout(sendQuitRequest, 500);
|
|
};
|
|
};
|
|
|
|
export { TestReporter };
|