1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- 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) {
- // 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 };
|