pdf.js.mirror/test/reporter.js
Tim van der Meij 5fb9f12d3e
Ignore pending tests in the custom reporters
Similar to excluded tests pending tests should not count towards runs or
result in console logging because they are effectively not (fully) run.
This reduces visual noise and helps to get the tests running on GitHub
Actions where non-passed tests will count towards a non-zero exit code.
2026-03-10 20:51:08 +01:00

105 lines
2.7 KiB
JavaScript

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);
}
resolve();
})
.catch(reason => {
console.warn(`TestReporter - send failed (${action}):`, reason);
resolve();
send(action, json);
});
});
}
function sendInfo(message) {
send("/info", { message });
}
function sendResult(status, description, error) {
const message = {
status,
description,
};
if (error !== undefined) {
message.error = error;
}
send("/submit_task_results", message);
}
function sendQuitRequest() {
send(`/tellMeToQuit?browser=${escape(browser)}`, {});
}
this.now = function () {
return Date.now();
};
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) {};
this.specStarted = function (result) {};
this.specDone = function (result) {
// Ignore excluded (fit/xit) or skipped (pending) tests.
if (["excluded", "pending"].includes(result.status)) {
return;
}
// Report on passed or failed tests.
if (result.status === "passed") {
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) {
// Ignore excluded (fdescribe/xdescribe) or skipped (pending) suites.
if (["excluded", "pending"].includes(result.status)) {
return;
}
// Report on failed suites only (indicates problems in setup/teardown).
if (result.status === "failed") {
let failedMessages = "";
for (const item of result.failedExpectations) {
failedMessages += `${item.message} `;
}
sendResult("TEST-UNEXPECTED-FAIL", result.description, failedMessages);
}
};
this.jasmineDone = function () {
// Give the test runner some time process any queued requests.
setTimeout(sendQuitRequest, 500);
};
};
export { TestReporter };