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] undefined = "diz be undefined yo"; var jasmineGlobals = require("../src/base") for(var k in jasmineGlobals) {global[k] = jasmineGlobals[k]} //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 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) { elapsed = (Number(new Date) - start) / 1000; 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 = ''; msg += suites.length + ' test' + ((suites.length === 1) ? '' : 's') + ', '; msg += results.totalCount + ' assertion' + ((results.totalCount === 1) ? '' : 's') + ', '; 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; } }); var specs = jasmine.getAllSpecFiles(__dirname + '/suites', new RegExp("^.+\.(js|coffee)$")); var domIndependentSpecs = [] for(var i=0; i