beforeEach now supports waits and Runs blocks
This commit is contained in:
parent
0d6c6c2a35
commit
b55399bd4b
156
lib/jasmine.js
156
lib/jasmine.js
@ -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
|
||||||
|
@ -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",
|
||||||
|
14
src/Queue.js
14
src/Queue.js
@ -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 () {
|
||||||
|
29
src/Spec.js
29
src/Spec.js
@ -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() {
|
||||||
|
Loading…
Reference in New Issue
Block a user