Merge pull request #314 from dead-horse/tests
add more test case, fix req.idempotent
This commit is contained in:
commit
26e36de085
18 changed files with 247 additions and 8 deletions
|
@ -249,7 +249,7 @@ module.exports = {
|
||||||
|
|
||||||
get idempotent() {
|
get idempotent() {
|
||||||
var methods = ['GET', 'HEAD', 'PUT', 'DELETE', 'OPTIONS', 'TRACE'];
|
var methods = ['GET', 'HEAD', 'PUT', 'DELETE', 'OPTIONS', 'TRACE'];
|
||||||
return ~methods.indexOf(this.method);
|
return !!~methods.indexOf(this.method);
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -2,6 +2,14 @@
|
||||||
var context = require('../context');
|
var context = require('../context');
|
||||||
|
|
||||||
describe('ctx.fresh', function(){
|
describe('ctx.fresh', function(){
|
||||||
|
describe('the request method is not GET and HEAD', function (){
|
||||||
|
it('should return false', function (){
|
||||||
|
var ctx = context();
|
||||||
|
ctx.req.method = 'POST';
|
||||||
|
ctx.fresh.should.be.false;
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
describe('the response is non-2xx', function(){
|
describe('the response is non-2xx', function(){
|
||||||
it('should return false', function(){
|
it('should return false', function(){
|
||||||
var ctx = context();
|
var ctx = context();
|
||||||
|
@ -36,4 +44,4 @@ describe('ctx.fresh', function(){
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -5,8 +5,11 @@ describe('ctx.get(name)', function(){
|
||||||
it('should return the field value', function(){
|
it('should return the field value', function(){
|
||||||
var ctx = context();
|
var ctx = context();
|
||||||
ctx.req.headers.host = 'http://google.com';
|
ctx.req.headers.host = 'http://google.com';
|
||||||
|
ctx.req.headers.referer = 'http://google.com';
|
||||||
ctx.get('HOST').should.equal('http://google.com');
|
ctx.get('HOST').should.equal('http://google.com');
|
||||||
ctx.get('Host').should.equal('http://google.com');
|
ctx.get('Host').should.equal('http://google.com');
|
||||||
ctx.get('host').should.equal('http://google.com');
|
ctx.get('host').should.equal('http://google.com');
|
||||||
|
ctx.get('referer').should.equal('http://google.com');
|
||||||
|
ctx.get('referrer').should.equal('http://google.com');
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
|
|
||||||
|
var assert = require('assert');
|
||||||
var request = require('../context').request;
|
var request = require('../context').request;
|
||||||
|
|
||||||
describe('req.host', function(){
|
describe('req.host', function(){
|
||||||
|
@ -8,6 +9,13 @@ describe('req.host', function(){
|
||||||
req.host.should.equal('foo.com:3000');
|
req.host.should.equal('foo.com:3000');
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('with no host present', function(){
|
||||||
|
it('should return null', function(){
|
||||||
|
var req = request();
|
||||||
|
assert(null == req.host);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
describe('when X-Forwarded-Host is present', function(){
|
describe('when X-Forwarded-Host is present', function(){
|
||||||
describe('and proxy is not trusted', function(){
|
describe('and proxy is not trusted', function(){
|
||||||
it('should be ignored', function(){
|
it('should be ignored', function(){
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
|
|
||||||
|
var assert = require('assert');
|
||||||
var request = require('../context').request;
|
var request = require('../context').request;
|
||||||
|
|
||||||
describe('req.hostname', function(){
|
describe('req.hostname', function(){
|
||||||
|
@ -8,6 +9,13 @@ describe('req.hostname', function(){
|
||||||
req.hostname.should.equal('foo.com');
|
req.hostname.should.equal('foo.com');
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('with no host present', function(){
|
||||||
|
it('should return null', function(){
|
||||||
|
var req = request();
|
||||||
|
assert(null == req.hostname);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
describe('when X-Forwarded-Host is present', function(){
|
describe('when X-Forwarded-Host is present', function(){
|
||||||
describe('and proxy is not trusted', function(){
|
describe('and proxy is not trusted', function(){
|
||||||
it('should be ignored', function(){
|
it('should be ignored', function(){
|
||||||
|
|
23
test/request/idempotent.js
Normal file
23
test/request/idempotent.js
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
|
||||||
|
var request = require('../context').request;
|
||||||
|
|
||||||
|
describe('ctx.idempotent', function(){
|
||||||
|
describe('when the request method is idempotent', function (){
|
||||||
|
it('should return true', function (){
|
||||||
|
['GET', 'HEAD', 'PUT', 'DELETE', 'OPTIONS', 'TRACE'].forEach(check);
|
||||||
|
function check(method) {
|
||||||
|
var req = request();
|
||||||
|
req.method = method;
|
||||||
|
req.idempotent.should.equal(true);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('when the request method is not idempotent', function(){
|
||||||
|
it('should return false', function (){
|
||||||
|
var req = request();
|
||||||
|
req.method = 'POST';
|
||||||
|
req.idempotent.should.equal(false);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
29
test/request/inspect.js
Normal file
29
test/request/inspect.js
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
|
||||||
|
var assert = require('assert');
|
||||||
|
var request = require('../context').request;
|
||||||
|
|
||||||
|
describe('req.inspect()', function(){
|
||||||
|
describe('with no request.req present', function(){
|
||||||
|
it('should return null', function(){
|
||||||
|
var req = request();
|
||||||
|
req.method = 'GET';
|
||||||
|
delete req.req;
|
||||||
|
assert(null == req.inspect());
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return a json representation', function(){
|
||||||
|
var req = request();
|
||||||
|
req.method = 'GET';
|
||||||
|
req.url = 'example.com';
|
||||||
|
req.header.host = 'example.com';
|
||||||
|
|
||||||
|
req.inspect().should.eql({
|
||||||
|
method: 'GET',
|
||||||
|
url: 'example.com',
|
||||||
|
header: {
|
||||||
|
host: 'example.com'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})
|
||||||
|
})
|
22
test/request/ip.js
Normal file
22
test/request/ip.js
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
|
||||||
|
var request = require('../context').request;
|
||||||
|
|
||||||
|
describe('req.ip', function(){
|
||||||
|
describe('with req.ips present', function(){
|
||||||
|
it('should return req.ips[0]', function(){
|
||||||
|
var req = request();
|
||||||
|
req.app.proxy = true;
|
||||||
|
req.header['x-forwarded-for'] = '127.0.0.1';
|
||||||
|
req.socket.remoteAddress = '127.0.0.2';
|
||||||
|
req.ip.should.equal('127.0.0.1');
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('with no req.ips present', function(){
|
||||||
|
it('should return req.socket.removeAddress', function(){
|
||||||
|
var req = request();
|
||||||
|
req.socket.remoteAddress = '127.0.0.2';
|
||||||
|
req.ip.should.equal('127.0.0.2');
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
24
test/request/ips.js
Normal file
24
test/request/ips.js
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
|
||||||
|
var request = require('../context').request;
|
||||||
|
|
||||||
|
describe('req.ips', function(){
|
||||||
|
describe('when X-Forwarded-For is present', function(){
|
||||||
|
describe('and proxy is not trusted', function(){
|
||||||
|
it('should be ignored', function(){
|
||||||
|
var req = request();
|
||||||
|
req.app.proxy = false;
|
||||||
|
req.header['x-forwarded-for'] = '127.0.0.1,127.0.0.2';
|
||||||
|
req.ips.should.eql([]);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('and proxy is trusted', function(){
|
||||||
|
it('should be used', function(){
|
||||||
|
var req = request();
|
||||||
|
req.app.proxy = true;
|
||||||
|
req.header['x-forwarded-for'] = '127.0.0.1,127.0.0.2';
|
||||||
|
req.ips.should.eql(['127.0.0.1', '127.0.0.2']);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
|
@ -76,6 +76,11 @@ describe('ctx.is(type)', function(){
|
||||||
ctx.is('image/*', 'image/png').should.equal('image/png');
|
ctx.is('image/*', 'image/png').should.equal('image/png');
|
||||||
ctx.is('image/png', 'image/*').should.equal('image/png');
|
ctx.is('image/png', 'image/*').should.equal('image/png');
|
||||||
|
|
||||||
|
ctx.is(['text/*', 'image/*']).should.equal('image/png');
|
||||||
|
ctx.is(['image/*', 'text/*']).should.equal('image/png');
|
||||||
|
ctx.is(['image/*', 'image/png']).should.equal('image/png');
|
||||||
|
ctx.is(['image/png', 'image/*']).should.equal('image/png');
|
||||||
|
|
||||||
ctx.is('jpeg').should.be.false;
|
ctx.is('jpeg').should.be.false;
|
||||||
ctx.is('.jpeg').should.be.false;
|
ctx.is('.jpeg').should.be.false;
|
||||||
ctx.is('text/*', 'application/*').should.be.false;
|
ctx.is('text/*', 'application/*').should.be.false;
|
||||||
|
@ -94,4 +99,4 @@ describe('ctx.is(type)', function(){
|
||||||
ctx.is('urlencoded', 'json').should.equal('urlencoded');
|
ctx.is('urlencoded', 'json').should.equal('urlencoded');
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
16
test/request/length.js
Normal file
16
test/request/length.js
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
|
||||||
|
var assert = require('assert');
|
||||||
|
var request = require('../context').request;
|
||||||
|
|
||||||
|
describe('ctx.length', function(){
|
||||||
|
it('should return length in content-length', function(){
|
||||||
|
var req = request();
|
||||||
|
req.header['content-length'] = '10';
|
||||||
|
req.length.should.equal(10);
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('with no content-length present', function(){
|
||||||
|
var req = request();
|
||||||
|
assert(null == req.length);
|
||||||
|
})
|
||||||
|
})
|
|
@ -27,6 +27,16 @@ describe('req.protocol', function(){
|
||||||
req.header['x-forwarded-proto'] = 'https, http';
|
req.header['x-forwarded-proto'] = 'https, http';
|
||||||
req.protocol.should.equal('https');
|
req.protocol.should.equal('https');
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('and X-Forwarded-Proto is empty', function(){
|
||||||
|
it('should return "http"', function(){
|
||||||
|
var req = request();
|
||||||
|
req.app.proxy = true;
|
||||||
|
req.req.socket = {};
|
||||||
|
req.header['x-forwarded-proto'] = '';
|
||||||
|
req.protocol.should.equal('http');
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('and proxy is not trusted', function(){
|
describe('and proxy is not trusted', function(){
|
||||||
|
@ -38,4 +48,4 @@ describe('req.protocol', function(){
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
19
test/request/subdomains.js
Normal file
19
test/request/subdomains.js
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
|
||||||
|
var request = require('../context').request;
|
||||||
|
|
||||||
|
describe('req.subdomains', function(){
|
||||||
|
it('should return subdomain array', function(){
|
||||||
|
var req = request();
|
||||||
|
req.header.host = 'tobi.ferrets.example.com';
|
||||||
|
req.app.subdomainOffset = 2;
|
||||||
|
req.subdomains.should.eql(['ferrets', 'tobi']);
|
||||||
|
|
||||||
|
req.app.subdomainOffset = 3;
|
||||||
|
req.subdomains.should.eql(['tobi']);
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('with no host present', function(){
|
||||||
|
var req = request();
|
||||||
|
req.subdomains.should.eql([]);
|
||||||
|
})
|
||||||
|
})
|
16
test/request/type.js
Normal file
16
test/request/type.js
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
|
||||||
|
var assert = require('assert');
|
||||||
|
var request = require('../context').request;
|
||||||
|
|
||||||
|
describe('req.type', function(){
|
||||||
|
it('should return type void of parameters', function(){
|
||||||
|
var req = request();
|
||||||
|
req.header['content-type'] = 'text/html; charset=utf-8';
|
||||||
|
req.type.should.equal('text/html');
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('with no host present', function(){
|
||||||
|
var req = request();
|
||||||
|
assert(null == req.type);
|
||||||
|
})
|
||||||
|
})
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
var response = require('../context').response;
|
var response = require('../context').response;
|
||||||
|
|
||||||
describe('res.etag', function(){
|
describe('res.etag=', function(){
|
||||||
it('should not modify an etag with quotes', function(){
|
it('should not modify an etag with quotes', function(){
|
||||||
var res = response();
|
var res = response();
|
||||||
res.etag = '"asdf"';
|
res.etag = '"asdf"';
|
||||||
|
@ -19,4 +19,12 @@ describe('res.etag', function(){
|
||||||
res.etag = 'asdf';
|
res.etag = 'asdf';
|
||||||
res.header.etag.should.equal('"asdf"');
|
res.header.etag.should.equal('"asdf"');
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('res.etag', function(){
|
||||||
|
it('should return etag', function(){
|
||||||
|
var res = response();
|
||||||
|
res.etag = '"asdf"';
|
||||||
|
res.etag.should.equal('"asdf"');
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
29
test/response/inspect.js
Normal file
29
test/response/inspect.js
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
|
||||||
|
var assert = require('assert');
|
||||||
|
var response = require('../context').response;
|
||||||
|
|
||||||
|
describe('res.inspect()', function(){
|
||||||
|
describe('with no response.res present', function(){
|
||||||
|
it('should return null', function(){
|
||||||
|
var res = response();
|
||||||
|
res.body = 'hello';
|
||||||
|
delete res.res;
|
||||||
|
assert(null == res.inspect());
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return a json representation', function(){
|
||||||
|
var res = response();
|
||||||
|
res.body = 'hello';
|
||||||
|
|
||||||
|
res.inspect().should.eql({
|
||||||
|
body: 'hello',
|
||||||
|
status: 200,
|
||||||
|
string: 'OK',
|
||||||
|
header: {
|
||||||
|
'content-length': '5',
|
||||||
|
'content-type': 'text/plain; charset=utf-8'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})
|
||||||
|
})
|
|
@ -60,6 +60,11 @@ describe('response.is(type)', function(){
|
||||||
res.is('image/*', 'image/png').should.equal('image/png');
|
res.is('image/*', 'image/png').should.equal('image/png');
|
||||||
res.is('image/png', 'image/*').should.equal('image/png');
|
res.is('image/png', 'image/*').should.equal('image/png');
|
||||||
|
|
||||||
|
res.is(['text/*', 'image/*']).should.equal('image/png');
|
||||||
|
res.is(['image/*', 'text/*']).should.equal('image/png');
|
||||||
|
res.is(['image/*', 'image/png']).should.equal('image/png');
|
||||||
|
res.is(['image/png', 'image/*']).should.equal('image/png');
|
||||||
|
|
||||||
res.is('jpeg').should.be.false;
|
res.is('jpeg').should.be.false;
|
||||||
res.is('.jpeg').should.be.false;
|
res.is('.jpeg').should.be.false;
|
||||||
res.is('text/*', 'application/*').should.be.false;
|
res.is('text/*', 'application/*').should.be.false;
|
||||||
|
|
|
@ -13,6 +13,12 @@ describe('ctx.set(name, val)', function(){
|
||||||
ctx.set('x-foo', 5);
|
ctx.set('x-foo', 5);
|
||||||
ctx.response.header['x-foo'].should.equal('5');
|
ctx.response.header['x-foo'].should.equal('5');
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should set a field value of array', function(){
|
||||||
|
var ctx = context();
|
||||||
|
ctx.set('x-foo', ['foo', 'bar']);
|
||||||
|
ctx.response.header['x-foo'].should.eql([ 'foo', 'bar' ]);
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('ctx.set(object)', function(){
|
describe('ctx.set(object)', function(){
|
||||||
|
@ -27,4 +33,4 @@ describe('ctx.set(object)', function(){
|
||||||
ctx.response.header.foo.should.equal('1');
|
ctx.response.header.foo.should.equal('1');
|
||||||
ctx.response.header.bar.should.equal('2');
|
ctx.response.header.bar.should.equal('2');
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in a new issue