Skip to content

Commit

Permalink
Updates method interceptor to run last on http requests
Browse files Browse the repository at this point in the history
 - When chaining multiple http intercepetors the first interceptor will run last when the request is resolved. Updating http-loader to allow all other interceptors to run before it does on http response
 - Allows Angular-multimocks and Angular-http-loader to work together
  • Loading branch information
Chris Conolly committed Dec 11, 2015
1 parent 08bd641 commit aaa908b
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 2 deletions.
2 changes: 1 addition & 1 deletion app/src/js/httpMethodInterceptor.js
Original file line number Diff line number Diff line change
Expand Up @@ -117,5 +117,5 @@ angular
})

.config(['$httpProvider', function ($httpProvider) {
$httpProvider.interceptors.push('httpMethodInterceptor');
$httpProvider.interceptors.unshift('httpMethodInterceptor');
}]);
21 changes: 20 additions & 1 deletion app/src/js/httpMethodInterceptor.spec.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* global describe, beforeEach, module, it, inject, jasmine, expect */
/* global describe, beforeEach, module, it, inject, jasmine, expect, spyOn */

describe('httpMethodInterceptor', function () {
var httpMethodInterceptor, httpMethodInterceptorProvider, mockQ,
Expand Down Expand Up @@ -206,4 +206,23 @@ describe('httpMethodInterceptor', function () {
expect(res).toBe(response);
});
});

describe('config sets $httpProvider interceptor', function () {
var $httpProvider;

beforeEach(function () {
module(function (_$httpProvider_) {
$httpProvider = _$httpProvider_;
spyOn($httpProvider.interceptors, 'unshift');
});
module('ng.httpLoader.httpMethodInterceptor');
inject();
});

it('should add to $httpProvider interceptors', function () {
expect($httpProvider.interceptors.unshift)
.toHaveBeenCalledWith('httpMethodInterceptor');
});
});
});

0 comments on commit aaa908b

Please sign in to comment.