UNPKG

@fastify/reply-from

Version:

forward your HTTP request to another server, for fastify

144 lines (124 loc) 4.26 kB
'use strict' const t = require('node:test') const assert = require('node:assert') const Fastify = require('fastify') const { request } = require('undici') const From = require('..') const http = require('node:http') const split = require('split2') const target = http.createServer((req, res) => { assert.ok('request proxied') assert.strictEqual(req.method, 'GET') assert.strictEqual(req.url, '/') assert.strictEqual(req.headers.connection, 'keep-alive') res.statusCode = 205 res.setHeader('Content-Type', 'text/plain') res.setHeader('x-my-header', 'hello!') res.end('hello world') }) t.test('use a custom instance of \'undici\'', async t => { t.plan(3) t.after(() => target.close()) await new Promise((resolve, reject) => target.listen({ port: 0 }, err => err ? reject(err) : resolve())) await t.test('disableRequestLogging is set to true', async t => { const logStream = split(JSON.parse) const instance = Fastify({ logger: { level: 'info', stream: logStream } }) t.after(() => instance.close()) instance.register(From, { base: `http://localhost:${target.address().port}`, disableRequestLogging: true }) instance.get('/', (_request, reply) => { reply.from() }) logStream.on('data', (log) => { if ( log.level === 30 && ( !log.msg.match('response received') || !log.msg.match('fetching from remote server') ) ) { t.assert.ok('request log message does not logged') } }) await new Promise(resolve => instance.listen({ port: 0 }, resolve)) const result = await request(`http://localhost:${instance.server.address().port}`) t.assert.strictEqual(result.headers['content-type'], 'text/plain') t.assert.strictEqual(result.headers['x-my-header'], 'hello!') t.assert.strictEqual(result.statusCode, 205) t.assert.strictEqual(await result.body.text(), 'hello world') }) await t.test('disableRequestLogging is set to false', async t => { const logStream = split(JSON.parse) const instance = Fastify({ logger: { level: 'info', stream: logStream } }) t.after(() => instance.close()) instance.register(From, { base: `http://localhost:${target.address().port}`, disableRequestLogging: false }) instance.get('/', (_request, reply) => { reply.from() }) logStream.on('data', (log) => { if ( log.level === 30 && ( log.msg.match('response received') || log.msg.match('fetching from remote server') ) ) { t.assert.ok('request log message does not logged') } }) await new Promise(resolve => instance.listen({ port: 0 }, resolve)) const result = await request(`http://localhost:${instance.server.address().port}`) t.assert.strictEqual(result.headers['content-type'], 'text/plain') t.assert.strictEqual(result.headers['x-my-header'], 'hello!') t.assert.strictEqual(result.statusCode, 205) t.assert.strictEqual(await result.body.text(), 'hello world') }) await t.test('disableRequestLogging is not defined', async t => { const logStream = split(JSON.parse) const instance = Fastify({ logger: { level: 'info', stream: logStream } }) t.after(() => instance.close()) instance.register(From, { base: `http://localhost:${target.address().port}` }) instance.get('/', (_request, reply) => { reply.from() }) logStream.on('data', (log) => { if ( log.level === 30 && ( log.msg.match('response received') || log.msg.match('fetching from remote server') ) ) { t.assert.ok('request log message does not logged') } }) await new Promise(resolve => instance.listen({ port: 0 }, resolve)) const result = await request(`http://localhost:${instance.server.address().port}`) t.assert.strictEqual(result.headers['content-type'], 'text/plain') t.assert.strictEqual(result.headers['x-my-header'], 'hello!') t.assert.strictEqual(result.statusCode, 205) t.assert.strictEqual(await result.body.text(), 'hello world') }) })