2011-02-26 18:53:55 +00:00
|
|
|
var fs = require('fs');
|
|
|
|
var sys = require('sys');
|
|
|
|
var path = require('path');
|
|
|
|
|
|
|
|
// yes, really keep this here to keep us honest, but only for jasmine's own runner! [xw]
|
2011-02-26 23:07:59 +00:00
|
|
|
// undefined = "diz be undefined yo";
|
2011-02-26 18:53:55 +00:00
|
|
|
|
2011-02-26 19:01:33 +00:00
|
|
|
var jasmineGlobals = require("../src/base");
|
2011-02-26 23:07:59 +00:00
|
|
|
for(var k in jasmineGlobals) {global[k] = jasmineGlobals[k];}
|
2011-02-26 18:53:55 +00:00
|
|
|
|
|
|
|
//load jasmine src files based on the order in runner.html
|
|
|
|
var srcFilesInProperRequireOrder = [];
|
|
|
|
var runnerHtmlLines = fs.readFileSync("spec/runner.html", "utf8").split("\n");
|
|
|
|
var srcFileLines = [];
|
|
|
|
for (var i=0; i<runnerHtmlLines.length; i++)
|
|
|
|
if (runnerHtmlLines[i].match(/script(.*?)\/src\//))
|
|
|
|
srcFileLines.push(runnerHtmlLines[i]);
|
2011-02-26 23:07:59 +00:00
|
|
|
for (i=0; i<srcFileLines.length; i++) srcFilesInProperRequireOrder.push(srcFileLines[i].match(/src=\"(.*?)\"/)[1]);
|
2011-02-26 18:53:55 +00:00
|
|
|
for (i=0; i<srcFilesInProperRequireOrder.length; i++) require(srcFilesInProperRequireOrder[i]);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Pulling in code from jasmine-node.
|
|
|
|
|
|
|
|
We can't just depend on jasmine-node because it has its own jasmine that it uses.
|
|
|
|
*/
|
|
|
|
|
|
|
|
global.window = {
|
|
|
|
setTimeout: setTimeout,
|
|
|
|
clearTimeout: clearTimeout,
|
|
|
|
setInterval: setInterval,
|
|
|
|
clearInterval: clearInterval
|
|
|
|
};
|
|
|
|
|
|
|
|
delete global.window;
|
|
|
|
|
|
|
|
function noop(){}
|
|
|
|
|
|
|
|
jasmine.executeSpecs = function(specs, done, isVerbose, showColors){
|
|
|
|
var log = [];
|
|
|
|
var columnCounter = 0;
|
|
|
|
var start = 0;
|
|
|
|
var elapsed = 0;
|
|
|
|
var verbose = isVerbose || false;
|
|
|
|
var colors = showColors || false;
|
|
|
|
|
|
|
|
var ansi = {
|
|
|
|
green: '\033[32m',
|
|
|
|
red: '\033[31m',
|
|
|
|
yellow: '\033[33m',
|
|
|
|
none: '\033[0m'
|
|
|
|
};
|
|
|
|
|
|
|
|
for (var i = 0, len = specs.length; i < len; ++i){
|
|
|
|
var filename = specs[i];
|
|
|
|
require(filename.replace(/\.\w+$/, ""));
|
|
|
|
}
|
|
|
|
|
|
|
|
var jasmineEnv = jasmine.getEnv();
|
|
|
|
jasmineEnv.reporter = {
|
|
|
|
log: function(str){
|
|
|
|
},
|
|
|
|
|
|
|
|
reportSpecStarting: function(runner) {
|
|
|
|
},
|
|
|
|
|
|
|
|
reportRunnerStarting: function(runner) {
|
|
|
|
sys.puts('Started');
|
2011-02-26 23:07:59 +00:00
|
|
|
start = new Date().getTime();
|
2011-02-26 18:53:55 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
reportSuiteResults: function(suite) {
|
|
|
|
var specResults = suite.results();
|
|
|
|
var path = [];
|
|
|
|
while(suite) {
|
|
|
|
path.unshift(suite.description);
|
|
|
|
suite = suite.parentSuite;
|
|
|
|
}
|
|
|
|
var description = path.join(' ');
|
|
|
|
|
|
|
|
if (verbose)
|
|
|
|
log.push('Spec ' + description);
|
|
|
|
|
|
|
|
specResults.items_.forEach(function(spec){
|
|
|
|
if (spec.failedCount > 0 && spec.description) {
|
|
|
|
if (!verbose)
|
|
|
|
log.push(description);
|
|
|
|
log.push(' it ' + spec.description);
|
|
|
|
spec.items_.forEach(function(result){
|
|
|
|
log.push(' ' + result.trace.stack + '\n');
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
reportSpecResults: function(spec) {
|
|
|
|
var result = spec.results();
|
|
|
|
var msg = '';
|
|
|
|
if (result.passed())
|
|
|
|
{
|
|
|
|
msg = (colors) ? (ansi.green + '.' + ansi.none) : '.';
|
|
|
|
// } else if (result.skipped) { TODO: Research why "result.skipped" returns false when "xit" is called on a spec?
|
|
|
|
// msg = (colors) ? (ansi.yellow + '*' + ansi.none) : '*';
|
|
|
|
} else {
|
|
|
|
msg = (colors) ? (ansi.red + 'F' + ansi.none) : 'F';
|
|
|
|
}
|
|
|
|
sys.print(msg);
|
|
|
|
if (columnCounter++ < 50) return;
|
|
|
|
columnCounter = 0;
|
|
|
|
sys.print('\n');
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
reportRunnerResults: function(runner) {
|
2011-02-26 23:07:59 +00:00
|
|
|
elapsed = (new Date().getTime() - start) / 1000;
|
2011-02-26 18:53:55 +00:00
|
|
|
sys.puts('\n');
|
|
|
|
log.forEach(function(log){
|
|
|
|
sys.puts(log);
|
|
|
|
});
|
|
|
|
sys.puts('Finished in ' + elapsed + ' seconds');
|
|
|
|
|
|
|
|
var summary = jasmine.printRunnerResults(runner);
|
|
|
|
if(colors)
|
|
|
|
{
|
|
|
|
if(runner.results().failedCount === 0 )
|
|
|
|
sys.puts(ansi.green + summary + ansi.none);
|
|
|
|
else
|
|
|
|
sys.puts(ansi.red + summary + ansi.none);
|
|
|
|
} else {
|
|
|
|
sys.puts(summary);
|
|
|
|
}
|
|
|
|
(done||noop)(runner, log);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
jasmineEnv.execute();
|
|
|
|
};
|
|
|
|
|
|
|
|
jasmine.getAllSpecFiles = function(dir, matcher){
|
|
|
|
var specs = [];
|
|
|
|
|
|
|
|
if (fs.statSync(dir).isFile() && dir.match(matcher)) {
|
|
|
|
specs.push(dir);
|
|
|
|
} else {
|
|
|
|
var files = fs.readdirSync(dir);
|
|
|
|
for (var i = 0, len = files.length; i < len; ++i){
|
|
|
|
var filename = dir + '/' + files[i];
|
|
|
|
if (fs.statSync(filename).isFile() && filename.match(matcher)){
|
|
|
|
specs.push(filename);
|
|
|
|
}else if (fs.statSync(filename).isDirectory()){
|
|
|
|
var subfiles = this.getAllSpecFiles(filename, matcher);
|
|
|
|
subfiles.forEach(function(result){
|
|
|
|
specs.push(result);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return specs;
|
|
|
|
};
|
|
|
|
|
|
|
|
jasmine.printRunnerResults = function(runner){
|
|
|
|
var results = runner.results();
|
|
|
|
var suites = runner.suites();
|
|
|
|
var msg = '';
|
2011-03-08 06:34:58 +00:00
|
|
|
msg += suites.length + ' spec' + ((suites.length === 1) ? '' : 's') + ', ';
|
|
|
|
msg += results.totalCount + ' expectation' + ((results.totalCount === 1) ? '' : 's') + ', ';
|
2011-02-26 18:53:55 +00:00
|
|
|
msg += results.failedCount + ' failure' + ((results.failedCount === 1) ? '' : 's') + '\n';
|
|
|
|
return msg;
|
|
|
|
};
|
|
|
|
|
|
|
|
function now(){
|
|
|
|
return new Date().getTime();
|
|
|
|
}
|
|
|
|
|
|
|
|
jasmine.asyncSpecWait = function(){
|
|
|
|
var wait = jasmine.asyncSpecWait;
|
|
|
|
wait.start = now();
|
|
|
|
wait.done = false;
|
|
|
|
(function innerWait(){
|
|
|
|
waits(10);
|
|
|
|
runs(function() {
|
|
|
|
if (wait.start + wait.timeout < now()) {
|
|
|
|
expect('timeout waiting for spec').toBeNull();
|
|
|
|
} else if (wait.done) {
|
|
|
|
wait.done = false;
|
|
|
|
} else {
|
|
|
|
innerWait();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
})();
|
|
|
|
};
|
|
|
|
jasmine.asyncSpecWait.timeout = 4 * 1000;
|
|
|
|
jasmine.asyncSpecDone = function(){
|
|
|
|
jasmine.asyncSpecWait.done = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
for ( var key in jasmine) {
|
|
|
|
exports[key] = jasmine[key];
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
End jasmine-node runner
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var isVerbose = false;
|
|
|
|
var showColors = true;
|
|
|
|
process.argv.forEach(function(arg){
|
|
|
|
switch(arg) {
|
|
|
|
case '--color': showColors = true; break;
|
|
|
|
case '--noColor': showColors = false; break;
|
|
|
|
case '--verbose': isVerbose = true; break;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2011-02-26 23:07:59 +00:00
|
|
|
var specs = jasmine.getAllSpecFiles(__dirname + '/suites', new RegExp(".js$"));
|
2011-02-26 19:01:33 +00:00
|
|
|
var domIndependentSpecs = [];
|
2011-02-26 18:53:55 +00:00
|
|
|
for(var i=0; i<specs.length; i++) {
|
|
|
|
if (fs.readFileSync(specs[i], "utf8").indexOf("document.createElement")<0) {
|
2011-02-26 19:01:33 +00:00
|
|
|
domIndependentSpecs.push(specs[i]);
|
2011-02-26 23:07:59 +00:00
|
|
|
}
|
|
|
|
}
|
2011-02-26 18:53:55 +00:00
|
|
|
|
|
|
|
jasmine.executeSpecs(domIndependentSpecs, function(runner, log){
|
2011-02-26 23:07:59 +00:00
|
|
|
if (runner.results().failedCount === 0) {
|
2011-02-26 18:53:55 +00:00
|
|
|
process.exit(0);
|
|
|
|
} else {
|
|
|
|
process.exit(1);
|
|
|
|
}
|
|
|
|
}, isVerbose, showColors);
|