UNPKG

@fastify/reply-from

Version:

forward your HTTP request to another server, for fastify

61 lines (50 loc) 1.51 kB
'use strict' const { test } = require('node:test') const Fastify = require('fastify') const { request } = require('undici') const From = require('..') const https = require('node:https') const { Agent } = require('undici') const fs = require('node:fs') const path = require('node:path') const certs = { key: fs.readFileSync(path.join(__dirname, 'fixtures', 'fastify.key')), cert: fs.readFileSync(path.join(__dirname, 'fixtures', 'fastify.cert')) } test('https global agent is used, but not destroyed', async (t) => { https.globalAgent.destroy = () => { t.fail() } const instance = Fastify({ https: certs }) t.after(() => instance.close()) instance.get('/', (_request, reply) => { reply.from() }) const target = https.createServer(certs, (req, res) => { t.assert.ok('request proxied') t.assert.strictEqual(req.method, 'GET') t.assert.strictEqual(req.url, '/') res.statusCode = 200 res.end() }) t.after(() => target.close()) await new Promise(resolve => target.listen({ port: 0 }, resolve)) instance.register(From, { base: `https://localhost:${target.address().port}`, globalAgent: true, http: { } }) await new Promise(resolve => instance.listen({ port: 0 }, resolve)) const result = await request(`https://localhost:${instance.server.address().port}`, { dispatcher: new Agent({ connect: { rejectUnauthorized: false } }) }) t.assert.strictEqual(result.statusCode, 200) target.close() })