aboutsummaryrefslogtreecommitdiffstats
path: root/test/ngMock/angular-mocksSpec.js
diff options
context:
space:
mode:
Diffstat (limited to 'test/ngMock/angular-mocksSpec.js')
-rw-r--r--test/ngMock/angular-mocksSpec.js924
1 files changed, 924 insertions, 0 deletions
diff --git a/test/ngMock/angular-mocksSpec.js b/test/ngMock/angular-mocksSpec.js
new file mode 100644
index 00000000..2527ca48
--- /dev/null
+++ b/test/ngMock/angular-mocksSpec.js
@@ -0,0 +1,924 @@
+'use strict';
+
+describe('ngMock', function() {
+
+ describe('$browser', function() {
+
+ describe('addJs', function() {
+
+ it('should store url, done', inject(function($browser) {
+ var url = 'some.js',
+ done = noop;
+
+ $browser.addJs(url, done);
+
+ var script = $browser.$$scripts.shift();
+ expect(script.url).toBe(url);
+ expect(script.done).toBe(done);
+ }));
+
+
+ it('should return the script object', inject(function($browser) {
+ expect($browser.addJs('some.js', null, noop)).toBe($browser.$$scripts[0]);
+ }));
+ });
+ });
+
+
+ describe('TzDate', function() {
+
+ function minutes(min) {
+ return min*60*1000;
+ }
+
+ it('should look like a Date', function() {
+ var date = new angular.mock.TzDate(0,0);
+ expect(angular.isDate(date)).toBe(true);
+ });
+
+ it('should take millis as constructor argument', function() {
+ expect(new angular.mock.TzDate(0, 0).getTime()).toBe(0);
+ expect(new angular.mock.TzDate(0, 1283555108000).getTime()).toBe(1283555108000);
+ });
+
+ it('should take dateString as constructor argument', function() {
+ expect(new angular.mock.TzDate(0, '1970-01-01T00:00:00.000Z').getTime()).toBe(0);
+ expect(new angular.mock.TzDate(0, '2010-09-03T23:05:08.023Z').getTime()).toBe(1283555108023);
+ });
+
+
+ it('should fake getLocalDateString method', function() {
+ //0 in -3h
+ var t0 = new angular.mock.TzDate(-3, 0);
+ expect(t0.toLocaleDateString()).toMatch('1970');
+
+ //0 in +0h
+ var t1 = new angular.mock.TzDate(0, 0);
+ expect(t1.toLocaleDateString()).toMatch('1970');
+
+ //0 in +3h
+ var t2 = new angular.mock.TzDate(3, 0);
+ expect(t2.toLocaleDateString()).toMatch('1969');
+ });
+
+
+ it('should fake getHours method', function() {
+ //0 in -3h
+ var t0 = new angular.mock.TzDate(-3, 0);
+ expect(t0.getHours()).toBe(3);
+
+ //0 in +0h
+ var t1 = new angular.mock.TzDate(0, 0);
+ expect(t1.getHours()).toBe(0);
+
+ //0 in +3h
+ var t2 = new angular.mock.TzDate(3, 0);
+ expect(t2.getHours()).toMatch(21);
+ });
+
+
+ it('should fake getMinutes method', function() {
+ //0:15 in -3h
+ var t0 = new angular.mock.TzDate(-3, minutes(15));
+ expect(t0.getMinutes()).toBe(15);
+
+ //0:15 in -3.25h
+ var t0a = new angular.mock.TzDate(-3.25, minutes(15));
+ expect(t0a.getMinutes()).toBe(30);
+
+ //0 in +0h
+ var t1 = new angular.mock.TzDate(0, minutes(0));
+ expect(t1.getMinutes()).toBe(0);
+
+ //0:15 in +0h
+ var t1a = new angular.mock.TzDate(0, minutes(15));
+ expect(t1a.getMinutes()).toBe(15);
+
+ //0:15 in +3h
+ var t2 = new angular.mock.TzDate(3, minutes(15));
+ expect(t2.getMinutes()).toMatch(15);
+
+ //0:15 in +3.25h
+ var t2a = new angular.mock.TzDate(3.25, minutes(15));
+ expect(t2a.getMinutes()).toMatch(0);
+ });
+
+
+ it('should fake getSeconds method', function() {
+ //0 in -3h
+ var t0 = new angular.mock.TzDate(-3, 0);
+ expect(t0.getSeconds()).toBe(0);
+
+ //0 in +0h
+ var t1 = new angular.mock.TzDate(0, 0);
+ expect(t1.getSeconds()).toBe(0);
+
+ //0 in +3h
+ var t2 = new angular.mock.TzDate(3, 0);
+ expect(t2.getSeconds()).toMatch(0);
+ });
+
+
+ it('should create a date representing new year in Bratislava', function() {
+ var newYearInBratislava = new angular.mock.TzDate(-1, '2009-12-31T23:00:00.000Z');
+ expect(newYearInBratislava.getTimezoneOffset()).toBe(-60);
+ expect(newYearInBratislava.getFullYear()).toBe(2010);
+ expect(newYearInBratislava.getMonth()).toBe(0);
+ expect(newYearInBratislava.getDate()).toBe(1);
+ expect(newYearInBratislava.getHours()).toBe(0);
+ expect(newYearInBratislava.getMinutes()).toBe(0);
+ });
+
+
+ it('should delegate all the UTC methods to the original UTC Date object', function() {
+ //from when created from string
+ var date1 = new angular.mock.TzDate(-1, '2009-12-31T23:00:00.000Z');
+ expect(date1.getUTCFullYear()).toBe(2009);
+ expect(date1.getUTCMonth()).toBe(11);
+ expect(date1.getUTCDate()).toBe(31);
+ expect(date1.getUTCHours()).toBe(23);
+ expect(date1.getUTCMinutes()).toBe(0);
+ expect(date1.getUTCSeconds()).toBe(0);
+
+
+ //from when created from millis
+ var date2 = new angular.mock.TzDate(-1, date1.getTime());
+ expect(date2.getUTCFullYear()).toBe(2009);
+ expect(date2.getUTCMonth()).toBe(11);
+ expect(date2.getUTCDate()).toBe(31);
+ expect(date2.getUTCHours()).toBe(23);
+ expect(date2.getUTCMinutes()).toBe(0);
+ expect(date2.getUTCSeconds()).toBe(0);
+ });
+
+
+ it('should throw error when no third param but toString called', function() {
+ expect(function() { new angular.mock.TzDate(0,0).toString(); }).
+ toThrow('Method \'toString\' is not implemented in the TzDate mock');
+ });
+ });
+
+ describe('$log', function() {
+ var $log;
+ beforeEach(inject(['$log', function(log) {
+ $log = log;
+ }]));
+
+ afterEach(inject(function($log){
+ $log.reset();
+ }));
+
+ it('should provide log method', function() {
+ expect(function() { $log.log(''); }).not.toThrow();
+ });
+
+ it('should provide info method', function() {
+ expect(function() { $log.info(''); }).not.toThrow();
+ });
+
+ it('should provide warn method', function() {
+ expect(function() { $log.warn(''); }).not.toThrow();
+ });
+
+ it('should provide error method', function() {
+ expect(function() { $log.error(''); }).not.toThrow();
+ });
+
+ it('should store log messages', function() {
+ $log.log('fake log');
+ expect($log.log.logs).toContain(['fake log']);
+ });
+
+ it('should store info messages', function() {
+ $log.info('fake log');
+ expect($log.info.logs).toContain(['fake log']);
+ });
+
+ it('should store warn messages', function() {
+ $log.warn('fake log');
+ expect($log.warn.logs).toContain(['fake log']);
+ });
+
+ it('should store error messages', function() {
+ $log.error('fake log');
+ expect($log.error.logs).toContain(['fake log']);
+ });
+
+ it('should assertEmpty', function(){
+ try {
+ $log.error(Error('MyError'));
+ $log.warn(Error('MyWarn'));
+ $log.info(Error('MyInfo'));
+ $log.log(Error('MyLog'));
+ $log.assertEmpty();
+ } catch (error) {
+ error = error.message || error;
+ expect(error).toMatch(/Error: MyError/m);
+ expect(error).toMatch(/Error: MyWarn/m);
+ expect(error).toMatch(/Error: MyInfo/m);
+ expect(error).toMatch(/Error: MyLog/m);
+ } finally {
+ $log.reset();
+ }
+ });
+
+ it('should reset state', function(){
+ $log.error(Error('MyError'));
+ $log.warn(Error('MyWarn'));
+ $log.info(Error('MyInfo'));
+ $log.log(Error('MyLog'));
+ $log.reset();
+ var passed = false;
+ try {
+ $log.assertEmpty(); // should not throw error!
+ passed = true;
+ } catch (e) {
+ passed = e;
+ }
+ expect(passed).toBe(true);
+ });
+ });
+
+ describe('defer', function() {
+ var browser, log;
+ beforeEach(inject(function($browser) {
+ browser = $browser;
+ log = '';
+ }));
+
+ function logFn(text){ return function() {
+ log += text +';';
+ };
+ }
+
+ it('should flush', function() {
+ browser.defer(logFn('A'));
+ expect(log).toEqual('');
+ browser.defer.flush();
+ expect(log).toEqual('A;');
+ });
+
+ it('should flush delayed', function() {
+ browser.defer(logFn('A'));
+ browser.defer(logFn('B'), 10);
+ browser.defer(logFn('C'), 20);
+ expect(log).toEqual('');
+
+ expect(browser.defer.now).toEqual(0);
+ browser.defer.flush(0);
+ expect(log).toEqual('A;');
+
+ browser.defer.flush();
+ expect(log).toEqual('A;B;C;');
+ });
+
+ it('should defer and flush over time', function() {
+ browser.defer(logFn('A'), 1);
+ browser.defer(logFn('B'), 2);
+ browser.defer(logFn('C'), 3);
+
+ browser.defer.flush(0);
+ expect(browser.defer.now).toEqual(0);
+ expect(log).toEqual('');
+
+ browser.defer.flush(1);
+ expect(browser.defer.now).toEqual(1);
+ expect(log).toEqual('A;');
+
+ browser.defer.flush(2);
+ expect(browser.defer.now).toEqual(3);
+ expect(log).toEqual('A;B;C;');
+ });
+
+ it('should throw an exception if there is nothing to be flushed', function() {
+ expect(function() {browser.defer.flush();}).toThrow('No deferred tasks to be flushed');
+ });
+ });
+
+
+ describe('$exceptionHandler', function() {
+ it('should rethrow exceptions', inject(function($exceptionHandler) {
+ expect(function() { $exceptionHandler('myException'); }).toThrow('myException');
+ }));
+
+
+ it('should log exceptions', module(function($exceptionHandlerProvider){
+ $exceptionHandlerProvider.mode('log');
+ var $exceptionHandler = $exceptionHandlerProvider.$get();
+ $exceptionHandler('MyError');
+ expect($exceptionHandler.errors).toEqual(['MyError']);
+
+ $exceptionHandler('MyError', 'comment');
+ expect($exceptionHandler.errors[1]).toEqual(['MyError', 'comment']);
+ }));
+
+
+ it('should throw on wrong argument', module(function($exceptionHandlerProvider) {
+ expect(function() {
+ $exceptionHandlerProvider.mode('XXX');
+ }).toThrow("Unknown mode 'XXX', only 'log'/'rethrow' modes are allowed!");
+ }));
+ });
+
+
+ describe('angular.mock.dump', function(){
+ var d = angular.mock.dump;
+
+
+ it('should serialize primitive types', function(){
+ expect(d(undefined)).toEqual('undefined');
+ expect(d(1)).toEqual('1');
+ expect(d(null)).toEqual('null');
+ expect(d('abc')).toEqual('abc');
+ });
+
+
+ it('should serialize element', function(){
+ var e = angular.element('<div>abc</div><span>xyz</span>');
+ expect(d(e).toLowerCase()).toEqual('<div>abc</div><span>xyz</span>');
+ expect(d(e[0]).toLowerCase()).toEqual('<div>abc</div>');
+ });
+
+ it('should serialize scope', inject(function($rootScope){
+ $rootScope.obj = {abc:'123'};
+ expect(d($rootScope)).toMatch(/Scope\(.*\): \{/);
+ expect(d($rootScope)).toMatch(/{"abc":"123"}/);
+ }));
+
+
+ it('should be published on window', function(){
+ expect(window.dump instanceof Function).toBe(true);
+ });
+ });
+
+ describe('jasmine module and inject', function(){
+ var log;
+
+ beforeEach(function(){
+ log = '';
+ });
+
+ describe('module', function() {
+ describe('in DSL', function() {
+ it('should load module', module(function() {
+ log += 'module';
+ }));
+
+ afterEach(function() {
+ inject();
+ expect(log).toEqual('module');
+ });
+ });
+
+
+ describe('inline in test', function() {
+ it('should load module', function() {
+ module(function() {
+ log += 'module';
+ });
+ inject();
+ });
+
+ afterEach(function() {
+ expect(log).toEqual('module');
+ });
+ });
+ });
+
+ describe('inject', function() {
+ describe('in DSL', function() {
+ it('should load module', inject(function() {
+ log += 'inject';
+ }));
+
+ afterEach(function() {
+ expect(log).toEqual('inject');
+ });
+ });
+
+
+ describe('inline in test', function() {
+ it('should load module', function() {
+ inject(function() {
+ log += 'inject';
+ });
+ });
+
+ afterEach(function() {
+ expect(log).toEqual('inject');
+ });
+ });
+
+ describe('module with inject', function() {
+ beforeEach(module(function(){
+ log += 'module;';
+ }));
+
+ it('should inject', inject(function() {
+ log += 'inject;';
+ }));
+
+ afterEach(function() {
+ expect(log).toEqual('module;inject;')
+ });
+ });
+ });
+ });
+
+
+ describe('$httpBackend', function() {
+ var hb, callback, realBackendSpy;
+
+ beforeEach(inject(function($httpBackend) {
+ callback = jasmine.createSpy('callback');
+ hb = $httpBackend;
+ }));
+
+
+ it('should respond with first matched definition', function() {
+ hb.when('GET', '/url1').respond(200, 'content', {});
+ hb.when('GET', '/url1').respond(201, 'another', {});
+
+ callback.andCallFake(function(status, response) {
+ expect(status).toBe(200);
+ expect(response).toBe('content');
+ });
+
+ hb('GET', '/url1', null, callback);
+ expect(callback).not.toHaveBeenCalled();
+ hb.flush();
+ expect(callback).toHaveBeenCalledOnce();
+ });
+
+
+ it('should throw error when unexpected request', function() {
+ hb.when('GET', '/url1').respond(200, 'content');
+ expect(function() {
+ hb('GET', '/xxx');
+ }).toThrow('Unexpected request: GET /xxx\nNo more request expected');
+ });
+
+
+ it('should match headers if specified', function() {
+ hb.when('GET', '/url', null, {'X': 'val1'}).respond(201, 'content1');
+ hb.when('GET', '/url', null, {'X': 'val2'}).respond(202, 'content2');
+ hb.when('GET', '/url').respond(203, 'content3');
+
+ hb('GET', '/url', null, function(status, response) {
+ expect(status).toBe(203);
+ expect(response).toBe('content3');
+ });
+
+ hb('GET', '/url', null, function(status, response) {
+ expect(status).toBe(201);
+ expect(response).toBe('content1');
+ }, {'X': 'val1'});
+
+ hb('GET', '/url', null, function(status, response) {
+ expect(status).toBe(202);
+ expect(response).toBe('content2');
+ }, {'X': 'val2'});
+
+ hb.flush();
+ });
+
+
+ it('should match data if specified', function() {
+ hb.when('GET', '/a/b', '{a: true}').respond(201, 'content1');
+ hb.when('GET', '/a/b').respond(202, 'content2');
+
+ hb('GET', '/a/b', '{a: true}', function(status, response) {
+ expect(status).toBe(201);
+ expect(response).toBe('content1');
+ });
+
+ hb('GET', '/a/b', null, function(status, response) {
+ expect(status).toBe(202);
+ expect(response).toBe('content2');
+ });
+
+ hb.flush();
+ });
+
+
+ it('should match only method', function() {
+ hb.when('GET').respond(202, 'c');
+ callback.andCallFake(function(status, response) {
+ expect(status).toBe(202);
+ expect(response).toBe('c');
+ });
+
+ hb('GET', '/some', null, callback, {});
+ hb('GET', '/another', null, callback, {'X-Fake': 'Header'});
+ hb('GET', '/third', 'some-data', callback, {});
+ hb.flush();
+
+ expect(callback).toHaveBeenCalled();
+ });
+
+
+ it('should preserve the order of requests', function() {
+ hb.when('GET', '/url1').respond(200, 'first');
+ hb.when('GET', '/url2').respond(201, 'second');
+
+ hb('GET', '/url2', null, callback);
+ hb('GET', '/url1', null, callback);
+
+ hb.flush();
+
+ expect(callback.callCount).toBe(2);
+ expect(callback.argsForCall[0]).toEqual([201, 'second', '']);
+ expect(callback.argsForCall[1]).toEqual([200, 'first', '']);
+ });
+
+
+ describe('respond()', function() {
+ it('should take values', function() {
+ hb.expect('GET', '/url1').respond(200, 'first', {'header': 'val'});
+ hb('GET', '/url1', undefined, callback);
+ hb.flush();
+
+ expect(callback).toHaveBeenCalledOnceWith(200, 'first', 'header: val');
+ });
+
+ it('should take function', function() {
+ hb.expect('GET', '/some').respond(function(m, u, d, h) {
+ return [301, m + u + ';' + d + ';a=' + h.a, {'Connection': 'keep-alive'}];
+ });
+
+ hb('GET', '/some', 'data', callback, {a: 'b'});
+ hb.flush();
+
+ expect(callback).toHaveBeenCalledOnceWith(301, 'GET/some;data;a=b', 'Connection: keep-alive');
+ });
+
+ it('should default status code to 200', function() {
+ callback.andCallFake(function(status, response) {
+ expect(status).toBe(200);
+ expect(response).toBe('some-data');
+ });
+
+ hb.expect('GET', '/url1').respond('some-data');
+ hb.expect('GET', '/url2').respond('some-data', {'X-Header': 'true'});
+ hb('GET', '/url1', null, callback);
+ hb('GET', '/url2', null, callback);
+ hb.flush();
+ expect(callback).toHaveBeenCalled();
+ expect(callback.callCount).toBe(2);
+ });
+
+
+ it('should default response headers to ""', function() {
+ hb.expect('GET', '/url1').respond(200, 'first');
+ hb.expect('GET', '/url2').respond('second');
+
+ hb('GET', '/url1', null, callback);
+ hb('GET', '/url2', null, callback);
+
+ hb.flush();
+
+ expect(callback.callCount).toBe(2);
+ expect(callback.argsForCall[0]).toEqual([200, 'first', '']);
+ expect(callback.argsForCall[1]).toEqual([200, 'second', '']);
+ });
+ });
+
+
+ describe('expect()', function() {
+ it('should require specified order', function() {
+ hb.expect('GET', '/url1').respond(200, '');
+ hb.expect('GET', '/url2').respond(200, '');
+
+ expect(function() {
+ hb('GET', '/url2', null, noop, {});
+ }).toThrow('Unexpected request: GET /url2\nExpected GET /url1');
+ });
+
+
+ it('should have precedence over when()', function() {
+ callback.andCallFake(function(status, response) {
+ expect(status).toBe(300);
+ expect(response).toBe('expect');
+ });
+
+ hb.when('GET', '/url').respond(200, 'when');
+ hb.expect('GET', '/url').respond(300, 'expect');
+
+ hb('GET', '/url', null, callback, {});
+ hb.flush();
+ expect(callback).toHaveBeenCalledOnce();
+ });
+
+
+ it ('should throw exception when only headers differs from expectation', function() {
+ hb.when('GET').respond(200, '', {});
+ hb.expect('GET', '/match', undefined, {'Content-Type': 'application/json'});
+
+ expect(function() {
+ hb('GET', '/match', null, noop, {});
+ }).toThrow('Expected GET /match with different headers\n' +
+ 'EXPECTED: {"Content-Type":"application/json"}\nGOT: {}');
+ });
+
+
+ it ('should throw exception when only data differs from expectation', function() {
+ hb.when('GET').respond(200, '', {});
+ hb.expect('GET', '/match', 'some-data');
+
+ expect(function() {
+ hb('GET', '/match', 'different', noop, {});
+ }).toThrow('Expected GET /match with different data\n' +
+ 'EXPECTED: some-data\nGOT: different');
+ });
+
+
+ it("should use when's respond() when no expect() respond is defined", function() {
+ callback.andCallFake(function(status, response) {
+ expect(status).toBe(201);
+ expect(response).toBe('data');
+ });
+
+ hb.when('GET', '/some').respond(201, 'data');
+ hb.expect('GET', '/some');
+ hb('GET', '/some', null, callback);
+ hb.flush();
+
+ expect(callback).toHaveBeenCalled();
+ expect(function() { hb.verifyNoOutstandingExpectation(); }).not.toThrow();
+ });
+ });
+
+
+ describe('flush()', function() {
+ it('flush() should flush requests fired during callbacks', function() {
+ hb.when('GET').respond(200, '');
+ hb('GET', '/some', null, function() {
+ hb('GET', '/other', null, callback);
+ });
+
+ hb.flush();
+ expect(callback).toHaveBeenCalled();
+ });
+
+
+ it('should flush given number of pending requests', function() {
+ hb.when('GET').respond(200, '');
+ hb('GET', '/some', null, callback);
+ hb('GET', '/some', null, callback);
+ hb('GET', '/some', null, callback);
+
+ hb.flush(2);
+ expect(callback).toHaveBeenCalled();
+ expect(callback.callCount).toBe(2);
+ });
+
+
+ it('should throw exception when flushing more requests than pending', function() {
+ hb.when('GET').respond(200, '');
+ hb('GET', '/url', null, callback);
+
+ expect(function() {hb.flush(2);}).toThrow('No more pending request to flush !');
+ expect(callback).toHaveBeenCalledOnce();
+ });
+
+
+ it('should throw exception when no request to flush', function() {
+ expect(function() {hb.flush();}).toThrow('No pending request to flush !');
+
+ hb.when('GET').respond(200, '');
+ hb('GET', '/some', null, callback);
+ hb.flush();
+
+ expect(function() {hb.flush();}).toThrow('No pending request to flush !');
+ });
+
+
+ it('should throw exception if not all expectations satisfied', function() {
+ hb.expect('GET', '/url1').respond();
+ hb.expect('GET', '/url2').respond();
+
+ hb('GET', '/url1', null, angular.noop);
+ expect(function() {hb.flush();}).toThrow('Unsatisfied requests: GET /url2');
+ });
+ });
+
+
+ it('should throw an exception if no response defined', function() {
+ hb.when('GET', '/test');
+ expect(function() {
+ hb('GET', '/test', null, callback);
+ }).toThrow('No response defined !');
+ });
+
+
+ it('should throw an exception if no response for exception and no definition', function() {
+ hb.expect('GET', '/url');
+ expect(function() {
+ hb('GET', '/url', null, callback);
+ }).toThrow('No response defined !');
+ });
+
+
+ it('should respond undefined when JSONP method', function() {
+ hb.when('JSONP', '/url1').respond(200);
+ hb.expect('JSONP', '/url2').respond(200);
+
+ expect(hb('JSONP', '/url1')).toBeUndefined();
+ expect(hb('JSONP', '/url2')).toBeUndefined();
+ });
+
+
+ it('should not have passThrough method', function() {
+ expect(hb.passThrough).toBeUndefined();
+ });
+
+
+ describe('verifyExpectations', function() {
+
+ it('should throw exception if not all expectations were satisfied', function() {
+ hb.expect('POST', '/u1', 'ddd').respond(201, '', {});
+ hb.expect('GET', '/u2').respond(200, '', {});
+ hb.expect('POST', '/u3').respond(201, '', {});
+
+ hb('POST', '/u1', 'ddd', noop, {});
+
+ expect(function() {hb.verifyNoOutstandingExpectation();}).
+ toThrow('Unsatisfied requests: GET /u2, POST /u3');
+ });
+
+
+ it('should do nothing when no expectation', function() {
+ hb.when('DELETE', '/some').respond(200, '');
+
+ expect(function() {hb.verifyNoOutstandingExpectation();}).not.toThrow();
+ });
+
+
+ it('should do nothing when all expectations satisfied', function() {
+ hb.expect('GET', '/u2').respond(200, '', {});
+ hb.expect('POST', '/u3').respond(201, '', {});
+ hb.when('DELETE', '/some').respond(200, '');
+
+ hb('GET', '/u2', noop);
+ hb('POST', '/u3', noop);
+
+ expect(function() {hb.verifyNoOutstandingExpectation();}).not.toThrow();
+ });
+ });
+
+ describe('verifyRequests', function() {
+
+ it('should throw exception if not all requests were flushed', function() {
+ hb.when('GET').respond(200);
+ hb('GET', '/some', null, noop, {});
+
+ expect(function() {
+ hb.verifyNoOutstandingRequest();
+ }).toThrow('Unflushed requests: 1');
+ });
+ });
+
+
+ describe('resetExpectations', function() {
+
+ it('should remove all expectations', function() {
+ hb.expect('GET', '/u2').respond(200, '', {});
+ hb.expect('POST', '/u3').respond(201, '', {});
+ hb.resetExpectations();
+
+ expect(function() {hb.verifyNoOutstandingExpectation();}).not.toThrow();
+ });
+
+
+ it('should remove all pending responses', function() {
+ var cancelledClb = jasmine.createSpy('cancelled');
+
+ hb.expect('GET', '/url').respond(200, '');
+ hb('GET', '/url', null, cancelledClb);
+ hb.resetExpectations();
+
+ hb.expect('GET', '/url').respond(300, '');
+ hb('GET', '/url', null, callback, {});
+ hb.flush();
+
+ expect(callback).toHaveBeenCalledOnce();
+ expect(cancelledClb).not.toHaveBeenCalled();
+ });
+
+
+ it('should not remove definitions', function() {
+ var cancelledClb = jasmine.createSpy('cancelled');
+
+ hb.when('GET', '/url').respond(200, 'success');
+ hb('GET', '/url', null, cancelledClb);
+ hb.resetExpectations();
+
+ hb('GET', '/url', null, callback, {});
+ hb.flush();
+
+ expect(callback).toHaveBeenCalledOnce();
+ expect(cancelledClb).not.toHaveBeenCalled();
+ });
+ });
+
+
+ describe('expect/when shortcuts', function() {
+ angular.forEach(['expect', 'when'], function(prefix) {
+ angular.forEach(['GET', 'POST', 'PUT', 'DELETE', 'JSONP'], function(method) {
+ var shortcut = prefix + method;
+ it('should provide ' + shortcut + ' shortcut method', function() {
+ hb[shortcut]('/foo').respond('bar');
+ hb(method, '/foo', undefined, callback);
+ hb.flush();
+ expect(callback).toHaveBeenCalledOnceWith(200, 'bar', '');
+ });
+ });
+ });
+ });
+
+
+ describe('MockHttpExpectation', function() {
+
+ it('should accept url as regexp', function() {
+ var exp = new MockHttpExpectation('GET', /^\/x/);
+
+ expect(exp.match('GET', '/x')).toBe(true);
+ expect(exp.match('GET', '/xxx/x')).toBe(true);
+ expect(exp.match('GET', 'x')).toBe(false);
+ expect(exp.match('GET', 'a/x')).toBe(false);
+ });
+
+
+ it('should accept data as regexp', function() {
+ var exp = new MockHttpExpectation('POST', '/url', /\{.*?\}/);
+
+ expect(exp.match('POST', '/url', '{"a": "aa"}')).toBe(true);
+ expect(exp.match('POST', '/url', '{"one": "two"}')).toBe(true);
+ expect(exp.match('POST', '/url', '{"one"')).toBe(false);
+ });
+
+
+ it('should ignore data only if undefined (not null or false)', function() {
+ var exp = new MockHttpExpectation('POST', '/url', null);
+ expect(exp.matchData(null)).toBe(true);
+ expect(exp.matchData('some-data')).toBe(false);
+
+ exp = new MockHttpExpectation('POST', '/url', undefined);
+ expect(exp.matchData(null)).toBe(true);
+ expect(exp.matchData('some-data')).toBe(true);
+ });
+
+
+ it('should accept headers as function', function() {
+ var exp = new MockHttpExpectation('GET', '/url', undefined, function(h) {
+ return h['Content-Type'] == 'application/json';
+ });
+
+ expect(exp.matchHeaders({})).toBe(false);
+ expect(exp.matchHeaders({'Content-Type': 'application/json', 'X-Another': 'true'})).toBe(true);
+ });
+ });
+ });
+});
+
+
+describe('ngMockE2E', function() {
+ describe('$httpBackend', function() {
+ var hb, realHttpBackend, callback;
+
+ beforeEach(function() {
+ module(function($provide) {
+ callback = jasmine.createSpy('callback');
+ realHttpBackend = jasmine.createSpy('real $httpBackend');
+ $provide.value('$httpBackend', realHttpBackend);
+ $provide.decorator('$httpBackend', angular.mock.e2e.$httpBackendDecorator);
+ });
+ inject(function($injector) {
+ hb = $injector.get('$httpBackend');
+ });
+ });
+
+
+ describe('passThrough()', function() {
+ it('should delegate requests to the real backend when passThrough is invoked', function() {
+ hb.when('GET', /\/passThrough\/.*/).passThrough();
+ hb('GET', '/passThrough/23', null, callback);
+
+ expect(realHttpBackend).
+ toHaveBeenCalledOnceWith('GET', '/passThrough/23', null, callback, undefined);
+ });
+ });
+
+
+ describe('autoflush', function() {
+ it('should flush responses via $defer', inject(function($browser) {
+ hb.when('GET', '/foo').respond('bar');
+ hb('GET', '/foo', null, callback);
+
+ expect(callback).not.toHaveBeenCalled();
+ $browser.defer.flush();
+ expect(callback).toHaveBeenCalledOnce();
+ }));
+ });
+ });
+});