| // Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. |
| // |
| // Use of this source code is governed by a BSD-style license |
| // that can be found in the LICENSE file in the root of the source |
| // tree. An additional intellectual property rights grant can be found |
| // in the file PATENTS. All contributing project authors may |
| // be found in the AUTHORS file in the root of the source tree. |
| // |
| // Provides a Test class that exposes api to the tests. |
| // Read test.prototype to see what methods are exposed. |
| var fs = require('fs'); |
| var request = require('request'); |
| var BotManager = require('./botmanager.js'); |
| |
| function Test() { |
| this.timeout_ = setTimeout( |
| this.fail.bind(this, "Test timeout!"), |
| 100000); |
| } |
| |
| Test.prototype = { |
| log: function () { |
| console.log.apply(console.log, arguments); |
| }, |
| |
| abort: function (error) { |
| var error = new Error(error || "Test aborted"); |
| console.log(error.stack); |
| process.exit(1); |
| }, |
| |
| assert: function (value, message) { |
| if (value !== true) { |
| this.abort(message || "Assert failed."); |
| } |
| }, |
| |
| fail: function () { |
| this.assert(false, "Test failed."); |
| }, |
| |
| done: function () { |
| clearTimeout(this.timeout_); |
| console.log("Test succeeded"); |
| process.exit(0); |
| }, |
| |
| // Utility method to wait for multiple callbacks to be executed. |
| // functions - array of functions to call with a callback. |
| // doneCallback - called when all callbacks on the array have completed. |
| wait: function (functions, doneCallback) { |
| var result = new Array(functions.length); |
| var missingResult = functions.length; |
| for (var i = 0; i != functions.length; ++i) |
| functions[i](complete.bind(this, i)); |
| |
| function complete(index, value) { |
| missingResult--; |
| result[index] = value; |
| if (missingResult == 0) |
| doneCallback.apply(null, result); |
| } |
| }, |
| |
| spawnBot: function (name, botType, doneCallback) { |
| // Lazy initialization of botmanager. |
| if (!this.botManager_) |
| this.botManager_ = new BotManager(); |
| this.botManager_.spawnNewBot(name, botType, doneCallback); |
| }, |
| |
| createStatisticsReport: function (outputFileName) { |
| return new StatisticsReport(outputFileName); |
| }, |
| |
| // Ask computeengineondemand to give us TURN server credentials and URIs. |
| createTurnConfig: function (onSuccess, onError) { |
| request('https://computeengineondemand.appspot.com/turn?username=1234&key=5678', |
| function (error, response, body) { |
| if (error || response.statusCode != 200) { |
| onError('TURN request failed'); |
| return; |
| } |
| |
| var response = JSON.parse(body); |
| var iceServer = { |
| 'username': response.username, |
| 'credential': response.password, |
| 'urls': response.uris |
| }; |
| onSuccess({ 'iceServers': [ iceServer ] }); |
| } |
| ); |
| }, |
| } |
| |
| StatisticsReport = function (outputFileName) { |
| this.output_ = []; |
| this.output_.push("Version: 1"); |
| this.outputFileName_ = outputFileName; |
| } |
| |
| StatisticsReport.prototype = { |
| collectStatsFromPeerConnection: function (prefix, pc) { |
| setInterval(this.addPeerConnectionStats.bind(this, prefix, pc), 100); |
| }, |
| |
| addPeerConnectionStats: function (prefix, pc) { |
| pc.getStats(onStatsReady.bind(this)); |
| |
| function onStatsReady(reports) { |
| for (index in reports) { |
| var stats = {}; |
| stats[reports[index].id] = collectStats(reports[index].stats); |
| |
| var data = {}; |
| data[prefix] = stats; |
| |
| this.output_.push({ |
| type: "UpdateCounters", |
| startTime: (new Date()).getTime(), |
| data: data, |
| }); |
| } |
| }; |
| |
| function collectStats(stats) { |
| var outputStats = {}; |
| for (index in stats) { |
| var statValue = parseFloat(stats[index].stat); |
| outputStats[stats[index].name] = isNaN(statValue)? |
| stats[index].stat : statValue; |
| } |
| return outputStats; |
| }; |
| }, |
| |
| finish: function (doneCallback) { |
| fs.exists("test/reports/", function (exists) { |
| if(exists) { |
| writeFile.bind(this)(); |
| } else { |
| fs.mkdir("test/reports/", 0777, writeFile.bind(this)); |
| } |
| }.bind(this)); |
| |
| function writeFile () { |
| fs.writeFile("test/reports/" + this.outputFileName_ + "_" + |
| (new Date()).getTime() +".json", JSON.stringify(this.output_), |
| doneCallback); |
| } |
| }, |
| }; |
| |
| module.exports = Test; |