mirror of
https://github.com/zhigang1992/angular.js.git
synced 2026-04-22 10:49:24 +08:00
fix($http): ensure case-insens. header overriding
If user send content-type header, both content-type and default Content-Type headers were sent. Now default header overriding is case-insensitive.
This commit is contained in:
committed by
Pete Bacon Darwin
parent
f1b94b4b59
commit
53359d549e
@@ -717,6 +717,21 @@ describe('$http', function() {
|
||||
$httpBackend.flush();
|
||||
});
|
||||
|
||||
it('should override default headers with custom in a case insensitive manner', function() {
|
||||
$httpBackend.expect('POST', '/url', 'messageBody', function(headers) {
|
||||
return headers['accept'] == 'Rewritten' &&
|
||||
headers['content-type'] == 'Content-Type Rewritten' &&
|
||||
headers['Accept'] === undefined &&
|
||||
headers['Content-Type'] === undefined;
|
||||
}).respond('');
|
||||
|
||||
$http({url: '/url', method: 'POST', data: 'messageBody', headers: {
|
||||
'accept': 'Rewritten',
|
||||
'content-type': 'Content-Type Rewritten'
|
||||
}});
|
||||
$httpBackend.flush();
|
||||
});
|
||||
|
||||
it('should not set XSRF cookie for cross-domain requests', inject(function($browser) {
|
||||
$browser.cookies('XSRF-TOKEN', 'secret');
|
||||
$browser.url('http://host.com/base');
|
||||
@@ -734,7 +749,12 @@ describe('$http', function() {
|
||||
return !headers.hasOwnProperty('Content-Type');
|
||||
}).respond('');
|
||||
|
||||
$httpBackend.expect('POST', '/url2', undefined, function(headers) {
|
||||
return !headers.hasOwnProperty('content-type');
|
||||
}).respond('');
|
||||
|
||||
$http({url: '/url', method: 'POST'});
|
||||
$http({url: '/url2', method: 'POST', headers: {'content-type': 'Rewritten'}});
|
||||
$httpBackend.flush();
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user