diff options
author | 2024-04-03 18:57:23 +0530 | |
---|---|---|
committer | 2024-04-03 18:57:23 +0530 | |
commit | 68817f7a0036ec6e42a3c39d16c9adbdd460ae9a (patch) | |
tree | 890ad052d252eecd19b05791c693f309824e9388 /packages/integrations/node/test/url.test.js | |
parent | 0310a1f3f3ea9e67a8d4753f4779e33037a0533c (diff) | |
download | astro-68817f7a0036ec6e42a3c39d16c9adbdd460ae9a.tar.gz astro-68817f7a0036ec6e42a3c39d16c9adbdd460ae9a.tar.zst astro-68817f7a0036ec6e42a3c39d16c9adbdd460ae9a.zip |
fix(app/node): include `x-forwarded-port` header in url (#10666)
* fix(app/node): include `x-forwarded-port` header in url
* add changeset
* add test
Diffstat (limited to 'packages/integrations/node/test/url.test.js')
-rw-r--r-- | packages/integrations/node/test/url.test.js | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/packages/integrations/node/test/url.test.js b/packages/integrations/node/test/url.test.js new file mode 100644 index 000000000..39d466527 --- /dev/null +++ b/packages/integrations/node/test/url.test.js @@ -0,0 +1,95 @@ +import * as assert from 'node:assert/strict'; +import { before, describe, it } from 'node:test'; +import { TLSSocket } from 'node:tls'; +import nodejs from '../dist/index.js'; +import { createRequestAndResponse, loadFixture } from './test-utils.js'; +import * as cheerio from 'cheerio'; + +describe('URL', () => { + /** @type {import('./test-utils.js').Fixture} */ + let fixture; + + before(async () => { + fixture = await loadFixture({ + root: './fixtures/url/', + output: 'server', + adapter: nodejs({ mode: 'standalone' }), + }); + await fixture.build(); + }); + + it('return http when non-secure', async () => { + const { handler } = await import('./fixtures/url/dist/server/entry.mjs'); + let { req, res, text } = createRequestAndResponse({ + url: '/', + }); + + handler(req, res); + req.send(); + + const html = await text(); + assert.equal(html.includes('http:'), true); + }); + + it('return https when secure', async () => { + const { handler } = await import('./fixtures/url/dist/server/entry.mjs'); + let { req, res, text } = createRequestAndResponse({ + socket: new TLSSocket(), + url: '/', + }); + + handler(req, res); + req.send(); + + const html = await text(); + assert.equal(html.includes('https:'), true); + }); + + it('return http when the X-Forwarded-Proto header is set to http', async () => { + const { handler } = await import('./fixtures/url/dist/server/entry.mjs'); + let { req, res, text } = createRequestAndResponse({ + headers: { 'X-Forwarded-Proto': 'http' }, + url: '/', + }); + + handler(req, res); + req.send(); + + const html = await text(); + assert.equal(html.includes('http:'), true); + }); + + it('return https when the X-Forwarded-Proto header is set to https', async () => { + const { handler } = await import('./fixtures/url/dist/server/entry.mjs'); + let { req, res, text } = createRequestAndResponse({ + headers: { 'X-Forwarded-Proto': 'https' }, + url: '/', + }); + + handler(req, res); + req.send(); + + const html = await text(); + assert.equal(html.includes('https:'), true); + }); + + it('includes forwarded host and port in the url', async () => { + const { handler } = await import('./fixtures/url/dist/server/entry.mjs'); + let { req, res, text } = createRequestAndResponse({ + headers: { + 'X-Forwarded-Proto': 'https', + 'X-Forwarded-Host': 'abc.xyz', + 'X-Forwarded-Port': '444' + }, + url: '/', + }); + + handler(req, res); + req.send(); + + const html = await text(); + const $ = cheerio.load(html); + + assert.equal($('body').text(), "https://abc.xyz:444/"); + }); +}); |