/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */ /* globals SpecialPowers */ 'use strict'; var TestReporter = function(browser, appPath) { function send(action, json, cb) { var 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: message}); } function sendResult(status, description, error) { var message = { status: status, description: description }; if (typeof error !== 'undefined') { message['error'] = error; } send('/submit_task_results', message); } function sendQuitRequest() { send('/tellMeToQuit?path=' + escape(appPath), {}, function () { if (window.SpecialPowers) { SpecialPowers.quit(); } }); } this.now = function() { return new Date().getTime(); }; this.reportRunnerStarting = function() { this.runnerStartTime = this.now(); sendInfo('Started unit tests for ' + browser + '.'); }; this.reportSpecStarting = function() { }; this.reportSpecResults = function(spec) { var results = spec.results(); if (results.skipped) { sendResult('TEST-SKIPPED', results.description); } else if (results.passed()) { sendResult('TEST-PASSED', results.description); } else { var failedMessages = ''; var items = results.getItems(); for (var i = 0, ii = items.length; i < ii; i++) { if (!items[i].passed()) { failedMessages += items[i].message + ' '; } } sendResult('TEST-UNEXPECTED-FAIL', results.description, failedMessages); } }; this.reportSuiteResults = function(suite) { }; this.reportRunnerResults = function(runner) { // Give the test.py some time process any queued up requests setTimeout(sendQuitRequest, 500); }; };