koa-lite/test/request/protocol.js

54 lines
1.4 KiB
JavaScript
Raw Normal View History

'use strict';
const request = require('../context').request;
describe('req.protocol', function(){
describe('when encrypted', function(){
it('should return "https"', function(){
const req = request();
req.req.socket = { encrypted: true };
req.protocol.should.equal('https');
})
})
describe('when unencrypted', function(){
it('should return "http"', function(){
const req = request();
req.req.socket = {};
req.protocol.should.equal('http');
})
})
describe('when X-Forwarded-Proto is set', function(){
describe('and proxy is trusted', function(){
it('should be used', function(){
const req = request();
req.app.proxy = true;
req.req.socket = {};
req.header['x-forwarded-proto'] = 'https, http';
req.protocol.should.equal('https');
})
2014-07-06 08:43:14 +00:00
describe('and X-Forwarded-Proto is empty', function(){
it('should return "http"', function(){
const req = request();
2014-07-06 08:43:14 +00:00
req.app.proxy = true;
req.req.socket = {};
req.header['x-forwarded-proto'] = '';
req.protocol.should.equal('http');
})
})
})
describe('and proxy is not trusted', function(){
it('should not be used', function(){
const req = request();
req.req.socket = {};
req.header['x-forwarded-proto'] = 'https, http';
req.protocol.should.equal('http');
})
})
})
2014-07-06 08:43:14 +00:00
})