2011-02-28 21:35:53 +00:00
|
|
|
describe("TrivialNodeReporter", function() {
|
|
|
|
|
|
|
|
|
2011-02-28 21:45:22 +00:00
|
|
|
function green(str) {
|
2011-02-28 21:35:53 +00:00
|
|
|
return '\033[32m' + str + '\033[0m'; //keep these literal. otherwise the test loses value as a test.
|
2011-02-28 21:45:22 +00:00
|
|
|
}
|
2011-02-28 21:35:53 +00:00
|
|
|
|
2011-02-28 21:45:22 +00:00
|
|
|
function red(str) {
|
2011-02-28 21:35:53 +00:00
|
|
|
return '\033[31m' + str + '\033[0m';
|
2011-02-28 21:45:22 +00:00
|
|
|
}
|
2011-02-28 21:35:53 +00:00
|
|
|
|
|
|
|
var newline = "\n";
|
|
|
|
|
2011-02-28 22:39:59 +00:00
|
|
|
var passingSpec = {
|
|
|
|
results: function(){
|
|
|
|
return {passed:function(){return true;}};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
var failingSpec = {
|
|
|
|
results: function(){
|
|
|
|
return {passed:function(){return false;}};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
function repeatedlyInvoke(f, times) {
|
|
|
|
for(var i=0; i<times; i++) f(times+1);
|
|
|
|
}
|
|
|
|
|
|
|
|
function repeat(thing, times) {
|
|
|
|
var arr = [];
|
|
|
|
for(var i=0; i<times; i++) arr.push(thing);
|
|
|
|
return arr;
|
|
|
|
}
|
|
|
|
|
|
|
|
var fiftyRedFs = repeat(red("F"), 50).join("");
|
|
|
|
var fiftyGreenDots = repeat(green("."), 50).join("");
|
|
|
|
|
2011-02-28 21:35:53 +00:00
|
|
|
beforeEach(function() {
|
|
|
|
this.fakeSys = (function(){
|
|
|
|
var output = "";
|
|
|
|
return {
|
|
|
|
puts:function(str) {output += str + "\n";},
|
|
|
|
print:function(str) {output += str;},
|
|
|
|
getOutput:function(){return output;}
|
|
|
|
};
|
|
|
|
})();
|
|
|
|
|
|
|
|
this.env = new jasmine.Env();
|
|
|
|
this.env.updateInterval = 0;
|
|
|
|
|
|
|
|
this.reporter = new jasmine.TrivialNodeReporter(this.fakeSys);
|
|
|
|
});
|
|
|
|
|
|
|
|
// 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');
|
|
|
|
// },
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
describe('A Test Run', function(){
|
|
|
|
|
|
|
|
describe('A spec runs', function(){
|
|
|
|
it("prints a green dot if the spec passes", function(){
|
|
|
|
this.reporter.reportSpecResults(passingSpec);
|
|
|
|
|
|
|
|
expect(this.fakeSys.getOutput()).toEqual(
|
|
|
|
green(".")
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2011-02-28 21:45:22 +00:00
|
|
|
it("prints a red dot if the spec fails", function(){
|
|
|
|
var failingSpec = {
|
|
|
|
results: function(){
|
|
|
|
return {passed:function(){return false;}};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
this.reporter.reportSpecResults(failingSpec);
|
|
|
|
|
|
|
|
expect(this.fakeSys.getOutput()).toEqual(
|
2011-02-28 21:46:30 +00:00
|
|
|
red("F")
|
2011-02-28 21:45:22 +00:00
|
|
|
);
|
|
|
|
});
|
2011-02-28 22:39:59 +00:00
|
|
|
});
|
|
|
|
|
2011-02-28 21:45:22 +00:00
|
|
|
|
2011-02-28 22:39:59 +00:00
|
|
|
describe('many specs run', function(){
|
|
|
|
it("starts a new line every 50 specs", function(){
|
|
|
|
var self = this;
|
|
|
|
repeatedlyInvoke(function(){self.reporter.reportSpecResults(failingSpec);}, 49);
|
|
|
|
|
|
|
|
expect(this.fakeSys.getOutput()).
|
|
|
|
toEqual(repeat(red("F"), 49).join(""));
|
|
|
|
|
|
|
|
repeatedlyInvoke(function(){self.reporter.reportSpecResults(failingSpec);}, 3);
|
|
|
|
|
|
|
|
expect(this.fakeSys.getOutput()).
|
|
|
|
toEqual(fiftyRedFs + newline +
|
|
|
|
red("F") + red("F"));
|
|
|
|
|
|
|
|
repeatedlyInvoke(function(){self.reporter.reportSpecResults(failingSpec);}, 48);
|
|
|
|
repeatedlyInvoke(function(){self.reporter.reportSpecResults(passingSpec);}, 2);
|
|
|
|
expect(this.fakeSys.getOutput()).
|
|
|
|
toEqual(fiftyRedFs + newline +
|
|
|
|
fiftyRedFs + newline +
|
|
|
|
green(".") + green("."));
|
|
|
|
});
|
2011-02-28 21:35:53 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|