diff options
| author | Igor Minar | 2011-10-21 23:33:24 -0700 |
|---|---|---|
| committer | Igor Minar | 2011-10-22 21:32:48 -0700 |
| commit | ad90c3574f8365ee4a1a973d5e43c64fe9fcda2c (patch) | |
| tree | 19b62a31a7804d4fb7ece4afd6e79d56d7e35ac0 /test/service/deferSpec.js | |
| parent | e28171d5e493e0878d5276a44d4aa3db4ebd74f2 (diff) | |
| download | angular.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.js | 43 |
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); + }); + }); }); |
