aboutsummaryrefslogtreecommitdiffstats
path: root/test/service/deferSpec.js
diff options
context:
space:
mode:
authorIgor Minar2011-10-21 23:33:24 -0700
committerIgor Minar2011-10-22 21:32:48 -0700
commitad90c3574f8365ee4a1a973d5e43c64fe9fcda2c (patch)
tree19b62a31a7804d4fb7ece4afd6e79d56d7e35ac0 /test/service/deferSpec.js
parente28171d5e493e0878d5276a44d4aa3db4ebd74f2 (diff)
downloadangular.js-ad90c3574f8365ee4a1a973d5e43c64fe9fcda2c.tar.bz2
feat($defer): add $defer.cancel
This functionality was previously available only as obscure $browser.defer.cancel. I also added docs and tests and fixed an issue in .defer.cancel mock.
Diffstat (limited to 'test/service/deferSpec.js')
-rw-r--r--test/service/deferSpec.js43
1 files changed, 43 insertions, 0 deletions
diff --git a/test/service/deferSpec.js b/test/service/deferSpec.js
index ad1459ec..117ddc27 100644
--- a/test/service/deferSpec.js
+++ b/test/service/deferSpec.js
@@ -69,10 +69,53 @@ describe('$defer', function() {
expect(applySpy).toHaveBeenCalled();
});
+
it('should allow you to specify the delay time', function() {
var defer = this.spyOn($browser, 'defer');
$defer(noop, 123);
expect(defer.callCount).toEqual(1);
expect(defer.mostRecentCall.args[1]).toEqual(123);
});
+
+
+ it('should return a cancelation token', function() {
+ var defer = this.spyOn($browser, 'defer').andReturn('xxx');
+ expect($defer(noop)).toEqual('xxx');
+ });
+
+
+ describe('cancel', function() {
+ it('should cancel tasks', function() {
+ var task1 = jasmine.createSpy('task1'),
+ task2 = jasmine.createSpy('task2'),
+ task3 = jasmine.createSpy('task3'),
+ token1, token3;
+
+ token1 = $defer(task1);
+ $defer(task2);
+ token3 = $defer(task3, 333);
+
+ $defer.cancel(token3);
+ $defer.cancel(token1);
+ $browser.defer.flush();
+
+ expect(task1).not.toHaveBeenCalled();
+ expect(task2).toHaveBeenCalledOnce();
+ expect(task3).not.toHaveBeenCalled();
+ });
+
+
+ it('should return true if a task was succesffuly canceled', function() {
+ var task1 = jasmine.createSpy('task1'),
+ task2 = jasmine.createSpy('task2'),
+ token1, token2;
+
+ token1 = $defer(task1);
+ $browser.defer.flush();
+ token2 = $defer(task2);
+
+ expect($defer.cancel(token1)).toBeFalsy();
+ expect($defer.cancel(token2)).toBe(true);
+ });
+ });
});