1
0
Fork 0
mirror of https://github.com/mozilla/pdf.js.git synced 2025-04-29 15:47:57 +02:00
pdf.js/test/unit/testreporter.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

104 lines
2.7 KiB
JavaScript
Raw Normal View History

const TestReporter = function (browser) {
function send(action, json) {
return new Promise(resolve => {
json.browser = browser;
fetch(action, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(json),
})
.then(response => {
// Retry until successful.
if (!response.ok || response.status !== 200) {
throw new Error(response.statusText);
2014-04-11 11:02:41 -07:00
}
resolve();
})
.catch(reason => {
console.warn(`TestReporter - send failed (${action}): ${reason}`);
resolve();
send(action, json);
});
});
2012-04-19 12:32:24 -07:00
}
function sendInfo(message) {
send("/info", { message });
2012-04-19 12:32:24 -07:00
}
function sendResult(status, description, error) {
const message = {
status,
description,
2012-04-19 12:32:24 -07:00
};
if (error !== undefined) {
message.error = error;
}
2012-04-19 12:32:24 -07:00
send("/submit_task_results", message);
}
function sendQuitRequest() {
send(`/tellMeToQuit?browser=${escape(browser)}`, {});
2012-04-19 12:32:24 -07:00
}
this.now = function () {
return Date.now();
2012-04-19 12:32:24 -07:00
};
this.jasmineStarted = function (suiteInfo) {
2012-04-19 12:32:24 -07:00
this.runnerStartTime = this.now();
const total = suiteInfo.totalSpecsDefined;
const seed = suiteInfo.order.seed;
sendInfo(`Started ${total} tests for ${browser} with seed ${seed}.`);
2012-04-19 12:32:24 -07:00
};
this.suiteStarted = function (result) {
// Report on the result of `beforeAll` invocations.
if (result.failedExpectations.length > 0) {
let failedMessages = "";
for (const item of result.failedExpectations) {
failedMessages += `${item.message} `;
}
sendResult("TEST-UNEXPECTED-FAIL", result.description, failedMessages);
}
};
2012-04-19 12:32:24 -07:00
this.specStarted = function (result) {};
2016-03-29 09:34:13 -05:00
this.specDone = function (result) {
// Report on the result of individual tests.
2016-03-29 09:34:13 -05:00
if (result.failedExpectations.length === 0) {
sendResult("TEST-PASSED", result.description);
2012-04-19 12:32:24 -07:00
} else {
let failedMessages = "";
for (const item of result.failedExpectations) {
failedMessages += `${item.message} `;
}
2016-03-29 09:34:13 -05:00
sendResult("TEST-UNEXPECTED-FAIL", result.description, failedMessages);
2012-04-19 12:32:24 -07:00
}
};
this.suiteDone = function (result) {
// Report on the result of `afterAll` invocations.
if (result.failedExpectations.length > 0) {
let failedMessages = "";
for (const item of result.failedExpectations) {
failedMessages += `${item.message} `;
}
sendResult("TEST-UNEXPECTED-FAIL", result.description, failedMessages);
}
};
2012-04-19 12:32:24 -07:00
this.jasmineDone = function () {
// Give the test runner some time process any queued requests.
2012-04-19 14:19:08 -07:00
setTimeout(sendQuitRequest, 500);
2012-04-19 12:32:24 -07:00
};
};
export { TestReporter };