small QueueRunner refactors

This commit is contained in:
Colin O'Byrne and JR Boyens
2013-07-24 17:38:26 -07:00
parent 6bb8a91301
commit 984074ec95
3 changed files with 64 additions and 46 deletions

View File

@@ -275,12 +275,16 @@ getJasmineRequireObj().Spec = function() {
}
var befores = this.beforeFns() || [],
afters = this.afterFns() || [];
afters = this.afterFns() || [];
var allFns = befores.concat(this.fn).concat(afters);
this.queueRunner({
fns: allFns,
onException: function(e) {
onException: onException,
onComplete: complete
});
function onException(e) {
if (Spec.isPendingSpecException(e)) {
self.pend();
return;
@@ -293,9 +297,7 @@ getJasmineRequireObj().Spec = function() {
actual: "",
error: e
});
},
onComplete: complete
});
}
function complete() {
self.result.status = self.status();
@@ -1424,15 +1426,9 @@ getJasmineRequireObj().QueueRunner = function() {
for(iterativeIndex = recursiveIndex; iterativeIndex < length; iterativeIndex++) {
var fn = fns[iterativeIndex];
if (fn.length > 0) {
var attemptSuccessful = attempt(function() {
fn.call(self, function() { self.run(fns, iterativeIndex + 1); });
});
if(attemptSuccessful) {
return;
}
return attemptAsync(fn);
} else {
attempt(function() { fn.call(self); });
attemptSync(fn);
}
}
@@ -1442,18 +1438,31 @@ getJasmineRequireObj().QueueRunner = function() {
this.clearStack(this.onComplete);
}
function attempt(fn) {
function attemptSync(fn) {
try {
fn();
return true;
fn.call(self);
} catch (e) {
self.onException(e);
if (!self.catchException(e)) {
//TODO: set a var when we catch an exception and
//use a finally block to close the loop in a nice way..
throw e;
}
return false;
handleException(e);
}
}
function attemptAsync(fn) {
var next = function () { self.run(fns, iterativeIndex + 1); };
try {
fn.call(self, next);
} catch (e) {
handleException(e);
next();
}
}
function handleException(e) {
self.onException(e);
if (!self.catchException(e)) {
//TODO: set a var when we catch an exception and
//use a finally block to close the loop in a nice way..
throw e;
}
}
};

View File

@@ -20,15 +20,9 @@ getJasmineRequireObj().QueueRunner = function() {
for(iterativeIndex = recursiveIndex; iterativeIndex < length; iterativeIndex++) {
var fn = fns[iterativeIndex];
if (fn.length > 0) {
var attemptSuccessful = attempt(function() {
fn.call(self, function() { self.run(fns, iterativeIndex + 1); });
});
if(attemptSuccessful) {
return;
}
return attemptAsync(fn);
} else {
attempt(function() { fn.call(self); });
attemptSync(fn);
}
}
@@ -38,18 +32,31 @@ getJasmineRequireObj().QueueRunner = function() {
this.clearStack(this.onComplete);
}
function attempt(fn) {
function attemptSync(fn) {
try {
fn();
return true;
fn.call(self);
} catch (e) {
self.onException(e);
if (!self.catchException(e)) {
//TODO: set a var when we catch an exception and
//use a finally block to close the loop in a nice way..
throw e;
}
return false;
handleException(e);
}
}
function attemptAsync(fn) {
var next = function () { self.run(fns, iterativeIndex + 1); };
try {
fn.call(self, next);
} catch (e) {
handleException(e);
next();
}
}
function handleException(e) {
self.onException(e);
if (!self.catchException(e)) {
//TODO: set a var when we catch an exception and
//use a finally block to close the loop in a nice way..
throw e;
}
}
};

View File

@@ -52,12 +52,16 @@ getJasmineRequireObj().Spec = function() {
}
var befores = this.beforeFns() || [],
afters = this.afterFns() || [];
afters = this.afterFns() || [];
var allFns = befores.concat(this.fn).concat(afters);
this.queueRunner({
fns: allFns,
onException: function(e) {
onException: onException,
onComplete: complete
});
function onException(e) {
if (Spec.isPendingSpecException(e)) {
self.pend();
return;
@@ -70,9 +74,7 @@ getJasmineRequireObj().Spec = function() {
actual: "",
error: e
});
},
onComplete: complete
});
}
function complete() {
self.result.status = self.status();