import * as assert from 'node:assert/strict'; import { after, before, describe, it } from 'node:test'; import * as cheerio from 'cheerio'; import nodejs from '../dist/index.js'; import { loadFixture, waitServerListen } from './test-utils.js'; /** * @typedef {import('../../../astro/test/test-utils').Fixture} Fixture */ describe('Trailing slash', () => { /** @type {import('./test-utils').Fixture} */ let fixture; let server; describe('Always', async () => { describe('With base', async () => { before(async () => { process.env.ASTRO_NODE_AUTOSTART = 'disabled'; process.env.PRERENDER = true; fixture = await loadFixture({ root: './fixtures/trailing-slash/', base: '/some-base', output: 'static', trailingSlash: 'always', outDir: './dist/always-with-base', adapter: nodejs({ mode: 'standalone' }), }); await fixture.build(); const { startServer } = await fixture.loadAdapterEntryModule(); const res = startServer(); server = res.server; await waitServerListen(server.server); }); after(async () => { await server.stop(); await fixture.clean(); // biome-ignore lint/performance/noDelete: delete process.env.PRERENDER; }); it('Can render prerendered base route', async () => { const res = await fetch(`http://${server.host}:${server.port}`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'Index'); }); it('Can render prerendered route with redirect', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/some-base/one/'); }); it('Can render prerendered route with redirect and query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one?foo=bar`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/some-base/one/?foo=bar'); }); it('Can render prerendered route with query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one/?foo=bar`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Does not add trailing slash to subresource urls', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one.css`); const css = await res.text(); assert.equal(res.status, 200); assert.equal(css, 'h1 { color: red; }\n'); }); }); describe('Without base', async () => { before(async () => { process.env.ASTRO_NODE_AUTOSTART = 'disabled'; process.env.PRERENDER = true; fixture = await loadFixture({ root: './fixtures/trailing-slash/', output: 'static', trailingSlash: 'always', outDir: './dist/always-without-base', adapter: nodejs({ mode: 'standalone' }), }); await fixture.build(); const { startServer } = await fixture.loadAdapterEntryModule(); const res = startServer(); server = res.server; await waitServerListen(server.server); }); after(async () => { await server.stop(); await fixture.clean(); // biome-ignore lint/performance/noDelete: delete process.env.PRERENDER; }); it('Can render prerendered base route', async () => { const res = await fetch(`http://${server.host}:${server.port}`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'Index'); }); it('Can render prerendered route with redirect', async () => { const res = await fetch(`http://${server.host}:${server.port}/one`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/one/'); }); it('Can render prerendered route with redirect and query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/one?foo=bar`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/one/?foo=bar'); }); it('Can render prerendered route with query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/one/?foo=bar`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Does not add trailing slash to subresource urls', async () => { const res = await fetch(`http://${server.host}:${server.port}/one.css`); const css = await res.text(); assert.equal(res.status, 200); assert.equal(css, 'h1 { color: red; }\n'); }); }); }); describe('Never', async () => { describe('With base', async () => { before(async () => { process.env.ASTRO_NODE_AUTOSTART = 'disabled'; process.env.PRERENDER = true; fixture = await loadFixture({ root: './fixtures/trailing-slash/', base: '/some-base', output: 'static', trailingSlash: 'never', outDir: './dist/never-with-base', adapter: nodejs({ mode: 'standalone' }), }); await fixture.build(); const { startServer } = await fixture.loadAdapterEntryModule(); const res = startServer(); server = res.server; await waitServerListen(server.server); }); after(async () => { await server.stop(); await fixture.clean(); // biome-ignore lint/performance/noDelete: delete process.env.PRERENDER; }); it('Can render prerendered base route', async () => { const res = await fetch(`http://${server.host}:${server.port}`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'Index'); }); it('Can render prerendered route with redirect', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one/`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/some-base/one'); }); it('Can render prerendered route with redirect and query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one/?foo=bar`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/some-base/one?foo=bar'); }); it('Can render prerendered route with query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one?foo=bar`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); }); describe('Without base', async () => { before(async () => { process.env.ASTRO_NODE_AUTOSTART = 'disabled'; process.env.PRERENDER = true; fixture = await loadFixture({ root: './fixtures/trailing-slash/', output: 'static', trailingSlash: 'never', outDir: './dist/never-without-base', adapter: nodejs({ mode: 'standalone' }), }); await fixture.build(); const { startServer } = await fixture.loadAdapterEntryModule(); const res = startServer(); server = res.server; await waitServerListen(server.server); }); after(async () => { await server.stop(); await fixture.clean(); // biome-ignore lint/performance/noDelete: delete process.env.PRERENDER; }); it('Can render prerendered base route', async () => { const res = await fetch(`http://${server.host}:${server.port}`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'Index'); }); it('Can render prerendered route with redirect', async () => { const res = await fetch(`http://${server.host}:${server.port}/one/`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/one'); }); it('Can render prerendered route with redirect and query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/one/?foo=bar`, { redirect: 'manual', }); assert.equal(res.status, 301); assert.equal(res.headers.get('location'), '/one?foo=bar'); }); it('Can render prerendered route and query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/one?foo=bar`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); }); }); describe('Ignore', async () => { describe('With base', async () => { before(async () => { process.env.ASTRO_NODE_AUTOSTART = 'disabled'; process.env.PRERENDER = true; fixture = await loadFixture({ root: './fixtures/trailing-slash/', base: '/some-base', output: 'static', trailingSlash: 'ignore', outDir: './dist/ignore-with-base', adapter: nodejs({ mode: 'standalone' }), }); await fixture.build(); const { startServer } = await fixture.loadAdapterEntryModule(); const res = startServer(); server = res.server; await waitServerListen(server.server); }); after(async () => { await server.stop(); await fixture.clean(); // biome-ignore lint/performance/noDelete: delete process.env.PRERENDER; }); it('Can render prerendered base route', async () => { const res = await fetch(`http://${server.host}:${server.port}`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'Index'); }); it('Can render prerendered route with slash', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one/`, { redirect: 'manual', }); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Can render prerendered route without slash', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one`, { redirect: 'manual', }); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Can render prerendered route with slash and query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one/?foo=bar`, { redirect: 'manual', }); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Can render prerendered route without slash and with query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/some-base/one?foo=bar`, { redirect: 'manual', }); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); }); describe('Without base', async () => { before(async () => { process.env.ASTRO_NODE_AUTOSTART = 'disabled'; process.env.PRERENDER = true; fixture = await loadFixture({ root: './fixtures/trailing-slash/', output: 'static', trailingSlash: 'ignore', outDir: './dist/ignore-without-base', adapter: nodejs({ mode: 'standalone' }), }); await fixture.build(); const { startServer } = await fixture.loadAdapterEntryModule(); const res = startServer(); server = res.server; await waitServerListen(server.server); }); after(async () => { await server.stop(); await fixture.clean(); // biome-ignore lint/performance/noDelete: delete process.env.PRERENDER; }); it('Can render prerendered base route', async () => { const res = await fetch(`http://${server.host}:${server.port}`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'Index'); }); it('Can render prerendered route with slash', async () => { const res = await fetch(`http://${server.host}:${server.port}/one/`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Can render prerendered route without slash', async () => { const res = await fetch(`http://${server.host}:${server.port}/one`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Can render prerendered route with slash and query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/one/?foo=bar`, { redirect: 'manual', }); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); it('Can render prerendered route without slash and with query params', async () => { const res = await fetch(`http://${server.host}:${server.port}/one?foo=bar`); const html = await res.text(); const $ = cheerio.load(html); assert.equal(res.status, 200); assert.equal($('h1').text(), 'One'); }); }); }); }); n>
AgeCommit message (Expand)AuthorFilesLines
2023-10-09fix(AbortSignal/fetch) fix AbortSignal.timeout, fetch lock behavior and fetch...Gravatar Ciro Spaciari 29-61/+303
2023-10-09Fix npm tag for canary bun-types, againGravatar Ashcon Partovi 2-56/+10
2023-10-09Add Fedora build instructions to development.md (#6359)Gravatar otterDeveloper 1-0/+10
2023-10-09added commands (#6314)Gravatar babar 1-1/+2
2023-10-09Update README.md (#6291)Gravatar TPLJ 1-1/+1
2023-10-09docs: fixing a couple typos (#6331)Gravatar Michael Di Prisco 2-2/+2
2023-10-09fix: support uint8 exit code range (#6303)Gravatar Liz 2-2/+11
2023-10-09Fix array variables preview in debugger (#6379)Gravatar 2hu 1-1/+4
2023-10-07feat(KeyObject) (#5940)Gravatar Ciro Spaciari 106-67/+9342
2023-10-07Exclude more filesGravatar Jarred Sumner 1-1/+1
2023-10-07Exclude more filesGravatar Jarred Sumner 1-1/+2
2023-10-07Update settings.jsonGravatar Jarred Sumner 1-1/+2
2023-10-07Update settings.jsonGravatar Jarred Sumner 1-2/+3
2023-10-06fix a couple install testsGravatar Dylan Conway 1-8/+8
2023-10-06formatGravatar Dylan Conway 1-1/+2
2023-10-06Fix memory leak in fetch() (#6350)Gravatar Jarred Sumner 1-2/+0
2023-10-06[types] allow onLoad plugin callbacks to return undefined (#6346)Gravatar Silver 1-1/+1
2023-10-06docs: `file.stream()` is not a promise (#6337)Gravatar Paul Nodet 1-1/+1