2012-11-01 23:17:31 +01:00
|
|
|
var srcFolder = "../../../src/node_modules/";
|
|
|
|
var wd = require(srcFolder + "wd");
|
2012-11-03 16:55:14 +01:00
|
|
|
var async = require(srcFolder + "async");
|
2012-11-01 23:17:31 +01:00
|
|
|
|
|
|
|
var config = {
|
|
|
|
host: "ondemand.saucelabs.com"
|
|
|
|
, port: 80
|
|
|
|
, username: process.env.SAUCE_USER
|
|
|
|
, accessKey: process.env.SAUCE_KEY
|
|
|
|
}
|
|
|
|
|
2012-11-03 16:55:14 +01:00
|
|
|
var allTestsPassed = true;
|
2012-11-01 23:17:31 +01:00
|
|
|
|
2012-11-03 16:55:14 +01:00
|
|
|
var sauceTestWorker = async.queue(function (testSettings, callback) {
|
|
|
|
var browser = wd.remote(config.host, config.port, config.username, config.accessKey);
|
|
|
|
var browserChain = browser.chain();
|
|
|
|
var name = process.env.GIT_HASH + " - " + testSettings.browserName + " " + testSettings.version + ", " + testSettings.platform;
|
|
|
|
testSettings.name = name;
|
2012-11-03 18:46:02 +01:00
|
|
|
testSettings["public"] = true;
|
|
|
|
testSettings["build"] = process.env.GIT_HASH;
|
2012-11-03 16:55:14 +01:00
|
|
|
console.log("Remote sauce test '" + name + "' started!");
|
|
|
|
|
|
|
|
browserChain.init(testSettings).get("http://localhost:9001/tests/frontend/", function(){
|
|
|
|
//tear down the test excecution
|
|
|
|
var stopSauce = function(success){
|
|
|
|
getStatusInterval && clearInterval(getStatusInterval);
|
|
|
|
clearTimeout(timeout);
|
|
|
|
|
|
|
|
browserChain.quit();
|
|
|
|
|
|
|
|
if(!success){
|
|
|
|
allTestsPassed = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
var testResult = knownConsoleText.replace(/\[red\]/g,'\x1B[31m').replace(/\[yellow\]/g,'\x1B[33m')
|
|
|
|
.replace(/\[green\]/g,'\x1B[32m').replace(/\[clear\]/g, '\x1B[39m');
|
2012-11-03 18:02:28 +01:00
|
|
|
testResult = testResult.split("\\n").map(function(line){
|
2012-11-03 17:21:28 +01:00
|
|
|
return "[" + testSettings.browserName + (testSettings.version === "" ? '' : (" " + testSettings.version)) + "] " + line;
|
2012-11-03 17:11:15 +01:00
|
|
|
}).join("\n");
|
2012-11-03 16:55:14 +01:00
|
|
|
|
|
|
|
console.log(testResult);
|
|
|
|
console.log("Remote sauce test '" + name + "' finished!");
|
|
|
|
|
|
|
|
callback();
|
|
|
|
}
|
|
|
|
|
|
|
|
//timeout for the case the test hangs
|
|
|
|
var timeout = setTimeout(function(){
|
|
|
|
stopSauce(false);
|
|
|
|
}, 60000 * 10);
|
|
|
|
|
|
|
|
var knownConsoleText = "";
|
|
|
|
var getStatusInterval = setInterval(function(){
|
|
|
|
browserChain.eval("$('#console').text()", function(err, consoleText){
|
|
|
|
if(!consoleText || err){
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
knownConsoleText = consoleText;
|
|
|
|
|
|
|
|
if(knownConsoleText.indexOf("FINISHED") > 0){
|
|
|
|
var success = knownConsoleText.indexOf("FAILED") === -1;
|
|
|
|
stopSauce(success);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}, 5000);
|
|
|
|
});
|
2012-11-03 17:50:48 +01:00
|
|
|
}, 5); //run 5 tests in parrallel
|
2012-11-03 16:55:14 +01:00
|
|
|
|
|
|
|
// Firefox
|
|
|
|
sauceTestWorker.push({
|
2012-11-01 23:17:31 +01:00
|
|
|
'platform' : 'Linux'
|
|
|
|
, 'browserName' : 'firefox'
|
|
|
|
, 'version' : ''
|
2012-11-03 16:55:14 +01:00
|
|
|
});
|
2012-11-01 23:17:31 +01:00
|
|
|
|
2012-11-03 16:55:14 +01:00
|
|
|
// Chrome
|
|
|
|
sauceTestWorker.push({
|
|
|
|
'platform' : 'Linux'
|
|
|
|
, 'browserName' : 'googlechrome'
|
|
|
|
, 'version' : ''
|
|
|
|
});
|
2012-11-03 14:20:44 +01:00
|
|
|
|
2012-11-03 16:55:14 +01:00
|
|
|
// IE 8
|
|
|
|
sauceTestWorker.push({
|
|
|
|
'platform' : 'Windows 2003'
|
|
|
|
, 'browserName' : 'iexplore'
|
|
|
|
, 'version' : '8'
|
|
|
|
});
|
|
|
|
|
|
|
|
// IE 9
|
|
|
|
sauceTestWorker.push({
|
|
|
|
'platform' : 'Windows 2008'
|
|
|
|
, 'browserName' : 'iexplore'
|
|
|
|
, 'version' : '9'
|
|
|
|
});
|
|
|
|
|
|
|
|
// IE 10
|
|
|
|
sauceTestWorker.push({
|
|
|
|
'platform' : 'Windows 2012'
|
|
|
|
, 'browserName' : 'iexplore'
|
|
|
|
, 'version' : '10'
|
|
|
|
});
|
|
|
|
|
|
|
|
sauceTestWorker.drain = function() {
|
|
|
|
setTimeout(function(){
|
|
|
|
process.exit(allTestsPassed ? 0 : 1);
|
|
|
|
}, 3000);
|
|
|
|
}
|