You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
263 lines
6.5 KiB
263 lines
6.5 KiB
'use strict'
|
|
|
|
const { test } = require('tap')
|
|
|
|
const Request = require('../../lib/request')
|
|
|
|
test('Regular request', t => {
|
|
t.plan(15)
|
|
const headers = {
|
|
host: 'hostname'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
const request = new Request('id', 'params', req, 'query', 'log')
|
|
t.type(request, Request)
|
|
t.equal(request.id, 'id')
|
|
t.equal(request.params, 'params')
|
|
t.same(request.raw, req)
|
|
t.equal(request.query, 'query')
|
|
t.equal(request.headers, headers)
|
|
t.equal(request.log, 'log')
|
|
t.equal(request.ip, 'ip')
|
|
t.equal(request.ips, undefined)
|
|
t.equal(request.hostname, 'hostname')
|
|
t.equal(request.body, null)
|
|
t.equal(request.method, 'GET')
|
|
t.equal(request.url, '/')
|
|
t.equal(request.protocol, 'http')
|
|
t.same(request.socket, req.socket)
|
|
})
|
|
|
|
test('Regular request - hostname from authority', t => {
|
|
t.plan(2)
|
|
const headers = {
|
|
':authority': 'authority'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
|
|
const request = new Request('id', 'params', req, 'query', 'log')
|
|
t.type(request, Request)
|
|
t.equal(request.hostname, 'authority')
|
|
})
|
|
|
|
test('Regular request - host header has precedence over authority', t => {
|
|
t.plan(2)
|
|
const headers = {
|
|
host: 'hostname',
|
|
':authority': 'authority'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
const request = new Request('id', 'params', req, 'query', 'log')
|
|
t.type(request, Request)
|
|
t.equal(request.hostname, 'hostname')
|
|
})
|
|
|
|
test('Request with trust proxy', t => {
|
|
t.plan(15)
|
|
const headers = {
|
|
'x-forwarded-for': '2.2.2.2, 1.1.1.1',
|
|
'x-forwarded-host': 'example.com'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.type(request, TpRequest)
|
|
t.equal(request.id, 'id')
|
|
t.equal(request.params, 'params')
|
|
t.same(request.raw, req)
|
|
t.equal(request.query, 'query')
|
|
t.equal(request.headers, headers)
|
|
t.equal(request.log, 'log')
|
|
t.equal(request.ip, '2.2.2.2')
|
|
t.same(request.ips, ['ip', '1.1.1.1', '2.2.2.2'])
|
|
t.equal(request.hostname, 'example.com')
|
|
t.equal(request.body, null)
|
|
t.equal(request.method, 'GET')
|
|
t.equal(request.url, '/')
|
|
t.equal(request.protocol, 'http')
|
|
t.same(request.socket, req.socket)
|
|
})
|
|
|
|
test('Request with trust proxy, encrypted', t => {
|
|
t.plan(2)
|
|
const headers = {
|
|
'x-forwarded-for': '2.2.2.2, 1.1.1.1',
|
|
'x-forwarded-host': 'example.com'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip', encrypted: true },
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.type(request, TpRequest)
|
|
t.equal(request.protocol, 'https')
|
|
})
|
|
|
|
test('Request with trust proxy - no x-forwarded-host header', t => {
|
|
t.plan(2)
|
|
const headers = {
|
|
'x-forwarded-for': '2.2.2.2, 1.1.1.1',
|
|
host: 'hostname'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.type(request, TpRequest)
|
|
t.equal(request.hostname, 'hostname')
|
|
})
|
|
|
|
test('Request with trust proxy - no x-forwarded-host header and fallback to authority', t => {
|
|
t.plan(2)
|
|
const headers = {
|
|
'x-forwarded-for': '2.2.2.2, 1.1.1.1',
|
|
':authority': 'authority'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.type(request, TpRequest)
|
|
t.equal(request.hostname, 'authority')
|
|
})
|
|
|
|
test('Request with trust proxy - x-forwarded-host header has precedence over host', t => {
|
|
t.plan(2)
|
|
const headers = {
|
|
'x-forwarded-for': ' 2.2.2.2, 1.1.1.1',
|
|
'x-forwarded-host': 'example.com',
|
|
host: 'hostname'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.type(request, TpRequest)
|
|
t.equal(request.hostname, 'example.com')
|
|
})
|
|
|
|
test('Request with trust proxy - handles multiple entries in x-forwarded-host/proto', t => {
|
|
t.plan(3)
|
|
const headers = {
|
|
'x-forwarded-host': 'example2.com, example.com',
|
|
'x-forwarded-proto': 'http, https'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.type(request, TpRequest)
|
|
t.equal(request.hostname, 'example.com')
|
|
t.equal(request.protocol, 'https')
|
|
})
|
|
|
|
test('Request with trust proxy - plain', t => {
|
|
t.plan(1)
|
|
const headers = {
|
|
'x-forwarded-for': '2.2.2.2, 1.1.1.1',
|
|
'x-forwarded-host': 'example.com'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: { remoteAddress: 'ip' },
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.same(request.protocol, 'http')
|
|
})
|
|
|
|
test('Request with undefined socket', t => {
|
|
t.plan(15)
|
|
const headers = {
|
|
host: 'hostname'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: undefined,
|
|
headers
|
|
}
|
|
const request = new Request('id', 'params', req, 'query', 'log')
|
|
t.type(request, Request)
|
|
t.equal(request.id, 'id')
|
|
t.equal(request.params, 'params')
|
|
t.same(request.raw, req)
|
|
t.equal(request.query, 'query')
|
|
t.equal(request.headers, headers)
|
|
t.equal(request.log, 'log')
|
|
t.equal(request.ip, undefined)
|
|
t.equal(request.ips, undefined)
|
|
t.equal(request.hostname, 'hostname')
|
|
t.equal(request.body, null)
|
|
t.equal(request.method, 'GET')
|
|
t.equal(request.url, '/')
|
|
t.equal(request.protocol, undefined)
|
|
t.same(request.socket, req.socket)
|
|
})
|
|
|
|
test('Request with trust proxy and undefined socket', t => {
|
|
t.plan(1)
|
|
const headers = {
|
|
'x-forwarded-for': '2.2.2.2, 1.1.1.1',
|
|
'x-forwarded-host': 'example.com'
|
|
}
|
|
const req = {
|
|
method: 'GET',
|
|
url: '/',
|
|
socket: undefined,
|
|
headers
|
|
}
|
|
|
|
const TpRequest = Request.buildRequest(Request, true)
|
|
const request = new TpRequest('id', 'params', req, 'query', 'log')
|
|
t.same(request.protocol, undefined)
|
|
})
|