beforeEach now supports waits and Runs blocks

This commit is contained in:
ragaskar 2009-08-03 23:09:50 -07:00
parent 0d6c6c2a35
commit b55399bd4b
4 changed files with 105 additions and 102 deletions

View File

@ -844,7 +844,7 @@ jasmine.ActionCollection.prototype.waitForDone = function(action) {
self.env.clearInterval(id); self.env.clearInterval(id);
afterExecute(); afterExecute();
} }
}, 15000); }, 150);
}; };
/** No-op base class for Jasmine reporters. /** No-op base class for Jasmine reporters.
* *
@ -887,18 +887,14 @@ jasmine.Block = function(env, func, spec) {
this.spec = spec; this.spec = spec;
}; };
jasmine.Block.prototype._next = function() { jasmine.Block.prototype.execute = function(onComplete) {
this.spec.finish(); // default value is to be done after one function
};
jasmine.Block.prototype.execute = function() {
this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...'); this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...');
try { try {
this.func.apply(this.spec); this.func.apply(this.spec);
} catch (e) { } catch (e) {
this.fail(e); this.fail(e);
} }
this._next(); onComplete();
}; };
jasmine.Block.prototype.fail = function(e) { jasmine.Block.prototype.fail = function(e) {
@ -1462,52 +1458,59 @@ jasmine.StringPrettyPrinter.prototype.emitObject = function(obj) {
jasmine.StringPrettyPrinter.prototype.append = function(value) { jasmine.StringPrettyPrinter.prototype.append = function(value) {
this.string += value; this.string += value;
}; };
jasmine.Queue = function(onComplete) { jasmine.Queue = function() {
this.blocks = []; this.blocks = [];
this.onComplete = function () { this.running = false;
onComplete();
};
this.index = 0; this.index = 0;
this.offset = 0;
};
jasmine.Queue.prototype.addBefore = function (block) {
this.blocks.unshift(block);
}; };
jasmine.Queue.prototype.add = function(block) { jasmine.Queue.prototype.add = function(block) {
this.setNextOnLastInQueue(block);
this.blocks.push(block); this.blocks.push(block);
}; };
jasmine.Queue.prototype.start = function() { jasmine.Queue.prototype.insertNext = function (block) {
if (this.blocks[0]) { this.blocks.splice((this.index + this.offset + 1), 0, block);
this.blocks[0].execute(); this.offset++;
};
jasmine.Queue.prototype.start = function(onComplete) {
var self = this;
self.running = true;
self.onComplete = onComplete;
if (self.blocks[0]) {
self.blocks[0].execute(function () {
self._next();
});
} else { } else {
this.onComplete(); self.finish();
} }
}; };
jasmine.Queue.prototype.isRunning = function () {
return this.running;
};
jasmine.Queue.prototype._next = function () { jasmine.Queue.prototype._next = function () {
this.index++;
if (this.index < this.blocks.length) {
this.blocks[this.index].execute();
}
};
/**
* @private
*/
jasmine.Queue.prototype.setNextOnLastInQueue = function (block) {
var self = this; var self = this;
block._next = function () { self.offset = 0;
self.onComplete(); self.index++;
}; if (self.index < self.blocks.length) {
if (self.blocks.length > 0) { self.blocks[self.index].execute(function () {self._next();});
var previousBlock = self.blocks[self.blocks.length - 1]; } else {
previousBlock._next = function() { self.finish();
block.execute();
};
} }
}; };
jasmine.Queue.prototype.isComplete = function () { jasmine.Queue.prototype.finish = function () {
return this.index >= (this.blocks.length - 1); this.running = false;
if (this.onComplete) {
this.onComplete();
}
}; };
jasmine.Queue.prototype.getResults = function () { jasmine.Queue.prototype.getResults = function () {
@ -1598,9 +1601,7 @@ jasmine.Spec = function(env, suite, description) {
spec.env = env; spec.env = env;
spec.suite = suite; spec.suite = suite;
spec.description = description; spec.description = description;
spec.queue = new jasmine.Queue(function () { spec.queue = new jasmine.Queue();
spec.finish();
});
spec.finished = false; spec.finished = false;
spec.afterCallbacks = []; spec.afterCallbacks = [];
@ -1621,10 +1622,18 @@ jasmine.Spec.prototype.getResults = function() {
jasmine.Spec.prototype.runs = function (func) { jasmine.Spec.prototype.runs = function (func) {
var block = new jasmine.Block(this.env, func, this); var block = new jasmine.Block(this.env, func, this);
this.queue.add(block); this.addToQueue(block);
return this; return this;
}; };
jasmine.Spec.prototype.addToQueue = function (block) {
if (this.queue.isRunning()) {
this.queue.insertNext(block);
} else {
this.queue.add(block);
}
};
/** /**
* @private * @private
* @deprecated * @deprecated
@ -1642,13 +1651,13 @@ jasmine.Spec.prototype.expect = function(actual) {
jasmine.Spec.prototype.waits = function(timeout) { jasmine.Spec.prototype.waits = function(timeout) {
var waitsFunc = new jasmine.WaitsBlock(this.env, timeout, this); var waitsFunc = new jasmine.WaitsBlock(this.env, timeout, this);
this.queue.add(waitsFunc); this.addToQueue(waitsFunc);
return this; return this;
}; };
jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, timeoutMessage) { jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, timeoutMessage) {
var waitsForFunc = new jasmine.WaitsForBlock(this.env, timeout, latchFunction, timeoutMessage, this); var waitsForFunc = new jasmine.WaitsForBlock(this.env, timeout, latchFunction, timeoutMessage, this);
this.queue.add(waitsForFunc); this.addToQueue(waitsForFunc);
return this; return this;
}; };
@ -1676,16 +1685,15 @@ jasmine.Spec.prototype.finishCallback = function() {
this.env.reporter.reportSpecResults(this); this.env.reporter.reportSpecResults(this);
}; };
jasmine.Spec.prototype.finish = function() { jasmine.Spec.prototype.finish = function(onComplete) {
for (var i = 0; i < this.afterCallbacks.length; i++) { for (var i = 0; i < this.afterCallbacks.length; i++) {
this.afterCallbacks[i](); this.afterCallbacks[i]();
} }
this.safeExecuteAfters(); this.safeExecuteAfters();
this.removeAllSpies(); this.removeAllSpies();
this.finishCallback(); this.finishCallback();
this.finished = true; if (onComplete) {
if (this.suite.next) { onComplete();
this.suite.next();
} }
}; };
@ -1694,7 +1702,7 @@ jasmine.Spec.prototype.after = function(doAfter) {
}; };
jasmine.Spec.prototype.execute = function() { jasmine.Spec.prototype.execute = function(onComplete) {
var spec = this; var spec = this;
if (!spec.env.specFilter(spec)) { if (!spec.env.specFilter(spec)) {
spec.results.skipped = true; spec.results.skipped = true;
@ -1708,22 +1716,19 @@ jasmine.Spec.prototype.execute = function() {
spec.safeExecuteBefores(); spec.safeExecuteBefores();
spec.queue.start(); spec.queue.start(function () {
spec.finish(onComplete);
});
spec.env.currentlyRunningTests = false; spec.env.currentlyRunningTests = false;
}; };
jasmine.Spec.prototype.safeExecuteBefores = function() { jasmine.Spec.prototype.safeExecuteBefores = function() {
var befores = [];
for (var suite = this.suite; suite; suite = suite.parentSuite) { for (var suite = this.suite; suite; suite = suite.parentSuite) {
if (suite.beforeQueue) { if (suite.beforeQueue) {
for (var i = 0; i < suite.beforeQueue.length; i++) for (var i = 0; i < suite.beforeQueue.length; i++)
befores.push(suite.beforeQueue[i]); this.queue.addBefore(new jasmine.Block(this.env, suite.beforeQueue[i], this));
} }
} }
while (befores.length) {
this.safeExecuteBeforeOrAfter(befores.pop());
}
}; };
jasmine.Spec.prototype.safeExecuteAfters = function() { jasmine.Spec.prototype.safeExecuteAfters = function() {
@ -1813,11 +1818,11 @@ jasmine.Suite.prototype.getFullName = function() {
return fullName; return fullName;
}; };
jasmine.Suite.prototype.finish = function() { jasmine.Suite.prototype.finish = function(onComplete) {
this.env.reporter.reportSuiteResults(this); this.env.reporter.reportSuiteResults(this);
this.finished = true; this.finished = true;
for (var suite = this; suite; suite = suite.parentSuite) { if (typeof(onComplete) == 'function') {
suite.finished = true; onComplete();
} }
}; };
@ -1839,23 +1844,11 @@ jasmine.Suite.prototype.add = function(block) {
this.queue.add(block); this.queue.add(block);
}; };
jasmine.Suite.prototype.execute = function() { jasmine.Suite.prototype.execute = function(onComplete) {
this.queue.start(); var self = this;
this.queue.start(function () { self.finish(onComplete); });
}; };
jasmine.Suite.prototype.finished = function () {
//for (var suite = this; suite; suite = suite.parentSuite) {
// suite.finished = true;
//}
};
jasmine.Suite.prototype.next = function() {
if (this.queue.isComplete()) {
this.finish();
} else {
this.queue._next();
}
};
jasmine.WaitsBlock = function(env, timeout, spec) { jasmine.WaitsBlock = function(env, timeout, spec) {
this.timeout = timeout; this.timeout = timeout;
jasmine.Block.call(this, env, null, spec); jasmine.Block.call(this, env, null, spec);
@ -1863,12 +1856,11 @@ jasmine.WaitsBlock = function(env, timeout, spec) {
jasmine.util.inherit(jasmine.WaitsBlock, jasmine.Block); jasmine.util.inherit(jasmine.WaitsBlock, jasmine.Block);
jasmine.WaitsBlock.prototype.execute = function () { jasmine.WaitsBlock.prototype.execute = function (onComplete) {
var self = this; this.env.reporter.log('>> Jasmine waiting for ' + this.timeout + ' ms...');
self.env.reporter.log('>> Jasmine waiting for ' + this.timeout + ' ms...'); this.env.setTimeout(function () {
self.env.setTimeout(function () { onComplete();
self._next(); }, this.timeout);
}, self.timeout);
}; };
jasmine.WaitsForBlock = function(env, timeout, latchFunction, message, spec) { jasmine.WaitsForBlock = function(env, timeout, latchFunction, message, spec) {
this.timeout = timeout; this.timeout = timeout;
@ -1882,7 +1874,7 @@ jasmine.util.inherit(jasmine.WaitsForBlock, jasmine.Block);
jasmine.WaitsForBlock.TIMEOUT_INCREMENT = 100; jasmine.WaitsForBlock.TIMEOUT_INCREMENT = 100;
jasmine.WaitsForBlock.prototype.execute = function () { jasmine.WaitsForBlock.prototype.execute = function (onComplete) {
var self = this; var self = this;
self.env.reporter.log('>> Jasmine waiting for ' + (self.message || 'something to happen')); self.env.reporter.log('>> Jasmine waiting for ' + (self.message || 'something to happen'));
var latchFunctionResult; var latchFunctionResult;
@ -1890,12 +1882,12 @@ jasmine.WaitsForBlock.prototype.execute = function () {
latchFunctionResult = self.latchFunction.apply(self.spec); latchFunctionResult = self.latchFunction.apply(self.spec);
} catch (e) { } catch (e) {
self.fail(e); self.fail(e);
self._next(); onComplete();
return; return;
} }
if (latchFunctionResult) { if (latchFunctionResult) {
self._next(); onComplete();
} else if (self.totalTimeSpentWaitingForLatch >= self.timeout) { } else if (self.totalTimeSpentWaitingForLatch >= self.timeout) {
var message = 'timed out after ' + self.timeout + ' msec waiting for ' + (self.message || 'something to happen'); var message = 'timed out after ' + self.timeout + ' msec waiting for ' + (self.message || 'something to happen');
self.fail({ self.fail({
@ -1905,7 +1897,7 @@ jasmine.WaitsForBlock.prototype.execute = function () {
self.spec._next(); self.spec._next();
} else { } else {
self.totalTimeSpentWaitingForLatch += jasmine.WaitsForBlock.TIMEOUT_INCREMENT; self.totalTimeSpentWaitingForLatch += jasmine.WaitsForBlock.TIMEOUT_INCREMENT;
self.env.setTimeout(function () { self.execute(); }, jasmine.WaitsForBlock.TIMEOUT_INCREMENT); self.env.setTimeout(function () { self.execute(onComplete); }, jasmine.WaitsForBlock.TIMEOUT_INCREMENT);
} }
}; };
// Mock setTimeout, clearTimeout // Mock setTimeout, clearTimeout

View File

@ -593,14 +593,12 @@ describe("jasmine spec running", function () {
}); });
}); });
xit("#beforeEach should be able to eval runs and waits blocks", function () { it("#beforeEach should be able to eval runs and waits blocks", function () {
var foo = 0; var foo = 0;
var bar = 0; var bar = 0;
var suiteWithBefore = env.describe('one suite with a before', function () { var suiteWithBefore = env.describe('one suite with a before', function () {
this.beforeEach(function () { this.beforeEach(function () {
console.error('in beforeEach')
this.runs(function () { this.runs(function () {
console.error('in beforeEach runs')
foo++; foo++;
}); });
this.waits(500); this.waits(500);
@ -611,7 +609,6 @@ describe("jasmine spec running", function () {
}); });
env.it('should be a spec', function () { env.it('should be a spec', function () {
console.error('in spec ')
bar = 1; bar = 1;
foo++; foo++;
}); });
@ -621,12 +618,10 @@ describe("jasmine spec running", function () {
expect(foo).toEqual(0); expect(foo).toEqual(0);
expect(bar).toEqual(0); expect(bar).toEqual(0);
suiteWithBefore.execute(); suiteWithBefore.execute();
console.error('before tick');
expect(bar).toEqual(0); expect(bar).toEqual(0);
expect(foo).toEqual(1); expect(foo).toEqual(1);
fakeTimer.tick(500); fakeTimer.tick(500);
console.error('after tick')
expect(bar).toEqual(0); expect(bar).toEqual(0);
expect(foo).toEqual(2); expect(foo).toEqual(2);
@ -765,6 +760,7 @@ describe("jasmine spec running", function () {
env.execute(); env.execute();
var expected = [ var expected = [
"outer beforeEach", "outer beforeEach",
"outer it 1", "outer it 1",

View File

@ -2,14 +2,25 @@ jasmine.Queue = function() {
this.blocks = []; this.blocks = [];
this.running = false; this.running = false;
this.index = 0; this.index = 0;
this.offset = 0;
};
jasmine.Queue.prototype.addBefore = function (block) {
this.blocks.unshift(block);
}; };
jasmine.Queue.prototype.add = function(block) { jasmine.Queue.prototype.add = function(block) {
this.blocks.push(block); this.blocks.push(block);
}; };
jasmine.Queue.prototype.insertNext = function (block) {
this.blocks.splice((this.index + this.offset + 1), 0, block);
this.offset++;
};
jasmine.Queue.prototype.start = function(onComplete) { jasmine.Queue.prototype.start = function(onComplete) {
var self = this; var self = this;
self.running = true;
self.onComplete = onComplete; self.onComplete = onComplete;
if (self.blocks[0]) { if (self.blocks[0]) {
self.blocks[0].execute(function () { self.blocks[0].execute(function () {
@ -26,6 +37,7 @@ jasmine.Queue.prototype.isRunning = function () {
jasmine.Queue.prototype._next = function () { jasmine.Queue.prototype._next = function () {
var self = this; var self = this;
self.offset = 0;
self.index++; self.index++;
if (self.index < self.blocks.length) { if (self.index < self.blocks.length) {
self.blocks[self.index].execute(function () {self._next();}); self.blocks[self.index].execute(function () {self._next();});
@ -35,10 +47,10 @@ jasmine.Queue.prototype._next = function () {
}; };
jasmine.Queue.prototype.finish = function () { jasmine.Queue.prototype.finish = function () {
this.running = false;
if (this.onComplete) { if (this.onComplete) {
this.onComplete(); this.onComplete();
} }
this.running = false;
}; };
jasmine.Queue.prototype.getResults = function () { jasmine.Queue.prototype.getResults = function () {

View File

@ -12,9 +12,7 @@ jasmine.Spec = function(env, suite, description) {
spec.env = env; spec.env = env;
spec.suite = suite; spec.suite = suite;
spec.description = description; spec.description = description;
spec.queue = new jasmine.Queue(function () { spec.queue = new jasmine.Queue();
spec.finish();
});
spec.finished = false; spec.finished = false;
spec.afterCallbacks = []; spec.afterCallbacks = [];
@ -35,10 +33,18 @@ jasmine.Spec.prototype.getResults = function() {
jasmine.Spec.prototype.runs = function (func) { jasmine.Spec.prototype.runs = function (func) {
var block = new jasmine.Block(this.env, func, this); var block = new jasmine.Block(this.env, func, this);
this.queue.add(block); this.addToQueue(block);
return this; return this;
}; };
jasmine.Spec.prototype.addToQueue = function (block) {
if (this.queue.isRunning()) {
this.queue.insertNext(block);
} else {
this.queue.add(block);
}
};
/** /**
* @private * @private
* @deprecated * @deprecated
@ -56,13 +62,13 @@ jasmine.Spec.prototype.expect = function(actual) {
jasmine.Spec.prototype.waits = function(timeout) { jasmine.Spec.prototype.waits = function(timeout) {
var waitsFunc = new jasmine.WaitsBlock(this.env, timeout, this); var waitsFunc = new jasmine.WaitsBlock(this.env, timeout, this);
this.queue.add(waitsFunc); this.addToQueue(waitsFunc);
return this; return this;
}; };
jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, timeoutMessage) { jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, timeoutMessage) {
var waitsForFunc = new jasmine.WaitsForBlock(this.env, timeout, latchFunction, timeoutMessage, this); var waitsForFunc = new jasmine.WaitsForBlock(this.env, timeout, latchFunction, timeoutMessage, this);
this.queue.add(waitsForFunc); this.addToQueue(waitsForFunc);
return this; return this;
}; };
@ -121,22 +127,19 @@ jasmine.Spec.prototype.execute = function(onComplete) {
spec.safeExecuteBefores(); spec.safeExecuteBefores();
spec.queue.start(function () { spec.finish(onComplete); }); spec.queue.start(function () {
spec.finish(onComplete);
});
spec.env.currentlyRunningTests = false; spec.env.currentlyRunningTests = false;
}; };
jasmine.Spec.prototype.safeExecuteBefores = function() { jasmine.Spec.prototype.safeExecuteBefores = function() {
var befores = [];
for (var suite = this.suite; suite; suite = suite.parentSuite) { for (var suite = this.suite; suite; suite = suite.parentSuite) {
if (suite.beforeQueue) { if (suite.beforeQueue) {
for (var i = 0; i < suite.beforeQueue.length; i++) for (var i = 0; i < suite.beforeQueue.length; i++)
befores.push(suite.beforeQueue[i]); this.queue.addBefore(new jasmine.Block(this.env, suite.beforeQueue[i], this));
} }
} }
while (befores.length) {
this.safeExecuteBeforeOrAfter(befores.pop());
}
}; };
jasmine.Spec.prototype.safeExecuteAfters = function() { jasmine.Spec.prototype.safeExecuteAfters = function() {