diff options
author | 2024-04-03 18:57:23 +0530 | |
---|---|---|
committer | 2024-04-03 18:57:23 +0530 | |
commit | 55ddb2ba4889480f776a8d29b9dcd531b9f5ab3e (patch) | |
tree | b93439a13afd0a184d09fc55de27f6f0c3ad1de0 /packages/integrations/node/test/url.test.js | |
parent | 317d18ef8c9cf4fd13647518e3fd352774a86481 (diff) | |
download | astro-55ddb2ba4889480f776a8d29b9dcd531b9f5ab3e.tar.gz astro-55ddb2ba4889480f776a8d29b9dcd531b9f5ab3e.tar.zst astro-55ddb2ba4889480f776a8d29b9dcd531b9f5ab3e.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/"); + }); +}); |