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.
		
		
		
		
		
			
		
			
				
					395 lines
				
				9.0 KiB
			
		
		
			
		
	
	
					395 lines
				
				9.0 KiB
			| 
											3 years ago
										 | 'use strict' | ||
|  | 
 | ||
|  | const http = require('http') | ||
|  | const test = require('tap').test | ||
|  | const serializers = require('../lib/req') | ||
|  | const wrapRequestSerializer = require('../').wrapRequestSerializer | ||
|  | 
 | ||
|  | test('maps request', function (t) { | ||
|  |   t.plan(2) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     const serialized = serializers.mapHttpRequest(req) | ||
|  |     t.ok(serialized.req) | ||
|  |     t.ok(serialized.req.method) | ||
|  |     t.end() | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('does not return excessively long object', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(Object.keys(serialized).length, 6) | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.raw is available', function (t) { | ||
|  |   t.plan(2) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.foo = 'foo' | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.ok(serialized.raw) | ||
|  |     t.is(serialized.raw.foo, 'foo') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.raw will be obtained in from input request raw property if input request raw property is truthy', function (t) { | ||
|  |   t.plan(2) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.raw = { req: { foo: 'foo' }, res: {} } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.ok(serialized.raw) | ||
|  |     t.is(serialized.raw.req.foo, 'foo') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.id defaults to undefined', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.id, undefined) | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.id has a non-function value', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(typeof serialized.id === 'function', false) | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.id will be obtained from input request info.id when input request id does not exist', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.info = { id: 'test' } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.id, 'test') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.id has a non-function value with custom id function', function (t) { | ||
|  |   t.plan(2) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.id = function () { return 42 } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(typeof serialized.id === 'function', false) | ||
|  |     t.is(serialized.id, 42) | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.url will be obtained from input request req.path when input request url is an object', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.path = '/test' | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.url, '/test') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.url will be obtained from input request url.path when input request url is an object', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.url = { path: '/test' } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.url, '/test') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.url will be obtained from input request url when input request url is not an object', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.url = '/test' | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.url, '/test') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.url will be empty when input request path and url are not defined', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.url, '/') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.url will be obtained from input request originalUrl when available', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.originalUrl = '/test' | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.url, '/test') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('can wrap request serializers', function (t) { | ||
|  |   t.plan(3) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   const serailizer = wrapRequestSerializer(function (req) { | ||
|  |     t.ok(req.method) | ||
|  |     t.is(req.method, 'GET') | ||
|  |     delete req.method | ||
|  |     return req | ||
|  |   }) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     const serialized = serailizer(req) | ||
|  |     t.notOk(serialized.method) | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.remoteAddress will be obtained from request socket.remoteAddress as fallback', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.socket = { remoteAddress: 'http://localhost' } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.remoteAddress, 'http://localhost') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.remoteAddress will be obtained from request info.remoteAddress if available', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.info = { remoteAddress: 'http://localhost' } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.remoteAddress, 'http://localhost') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.remotePort will be obtained from request socket.remotePort as fallback', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.socket = { remotePort: 3000 } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.remotePort, 3000) | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.remotePort will be obtained from request info.remotePort if available', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.info = { remotePort: 3000 } | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.remotePort, 3000) | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.query is available', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.originalUrl = '/test' | ||
|  |     req.query = '/foo?bar=foobar&bar=foo' | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.query, '/foo?bar=foobar&bar=foo') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) | ||
|  | 
 | ||
|  | test('req.params is available', function (t) { | ||
|  |   t.plan(1) | ||
|  | 
 | ||
|  |   const server = http.createServer(handler) | ||
|  |   server.unref() | ||
|  |   server.listen(0, () => { | ||
|  |     http.get(server.address(), () => {}) | ||
|  |   }) | ||
|  | 
 | ||
|  |   t.tearDown(() => server.close()) | ||
|  | 
 | ||
|  |   function handler (req, res) { | ||
|  |     req.originalUrl = '/test' | ||
|  |     req.params = '/foo/bar' | ||
|  |     const serialized = serializers.reqSerializer(req) | ||
|  |     t.is(serialized.params, '/foo/bar') | ||
|  |     res.end() | ||
|  |   } | ||
|  | }) |