/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */ var TestReporter = function(browser, appPath) { 'use strict'; function send(action, json) { 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); } }; 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), {}); } 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); }; };