mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
d6edc75408
* quality of life updates for `App` (#9579) * feat(app): writeResponse for node-based adapters * add changeset * Apply suggestions from code review Co-authored-by: Emanuele Stoppa <my.burning@gmail.com> * Apply suggestions from code review Co-authored-by: Emanuele Stoppa <my.burning@gmail.com> * add examples for NodeApp static methods * unexpose createOutgoingHttpHeaders from public api * move headers test to core * clientAddress test * cookies test * destructure renderOptions right at the start --------- Co-authored-by: Emanuele Stoppa <my.burning@gmail.com> * Fallback node standalone to localhost (#9545) * Fallback node standalone to localhost * Update .changeset/tame-squids-film.md * quality of life updates for the node adapter (#9582) * descriptive names for files and functions * update tests * add changeset * appease linter * Apply suggestions from code review Co-authored-by: Nate Moore <natemoo-re@users.noreply.github.com> * `server-entrypoint.js` -> `server.js` * prevent crash on stream error (from PR 9533) * Apply suggestions from code review Co-authored-by: Luiz Ferraz <luiz@lferraz.com> * `127.0.0.1` -> `localhost` * add changeset for fryuni's fix * Apply suggestions from code review * Apply suggestions from code review Co-authored-by: Emanuele Stoppa <my.burning@gmail.com> --------- Co-authored-by: Nate Moore <natemoo-re@users.noreply.github.com> Co-authored-by: Luiz Ferraz <luiz@lferraz.com> Co-authored-by: Emanuele Stoppa <my.burning@gmail.com> * chore(vercel): delete request response conversion logic (#9583) * refactor * add changeset * bump peer dependencies * unexpose symbols (#9683) * Update .changeset/tame-squids-film.md Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> --------- Co-authored-by: Arsh <69170106+lilnasy@users.noreply.github.com> Co-authored-by: Bjorn Lu <bjornlu.dev@gmail.com> Co-authored-by: Nate Moore <natemoo-re@users.noreply.github.com> Co-authored-by: Luiz Ferraz <luiz@lferraz.com> Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
271 lines
7.8 KiB
JavaScript
271 lines
7.8 KiB
JavaScript
import nodejs from '../dist/index.js';
|
|
import { loadFixture } from './test-utils.js';
|
|
import { expect } from 'chai';
|
|
import * as cheerio from 'cheerio';
|
|
|
|
/**
|
|
* @typedef {import('../../../astro/test/test-utils').Fixture} Fixture
|
|
*/
|
|
|
|
async function load() {
|
|
const mod = await import(`./fixtures/prerender/dist/server/entry.mjs?dropcache=${Date.now()}`);
|
|
return mod;
|
|
}
|
|
describe('Prerendering', () => {
|
|
/** @type {import('./test-utils').Fixture} */
|
|
let fixture;
|
|
let server;
|
|
|
|
describe('With base', async () => {
|
|
before(async () => {
|
|
process.env.PRERENDER = true;
|
|
|
|
fixture = await loadFixture({
|
|
base: '/some-base',
|
|
root: './fixtures/prerender/',
|
|
output: 'server',
|
|
adapter: nodejs({ mode: 'standalone' }),
|
|
});
|
|
await fixture.build();
|
|
const { startServer } = await load();
|
|
let res = startServer();
|
|
server = res.server;
|
|
});
|
|
|
|
after(async () => {
|
|
await server.stop();
|
|
await fixture.clean();
|
|
delete process.env.PRERENDER;
|
|
});
|
|
|
|
it('Can render SSR route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/one`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('One');
|
|
});
|
|
|
|
it('Can render prerendered route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/two`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
|
|
it('Can render prerendered route with redirect and query params', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/two?foo=bar`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
|
|
it('Can render prerendered route with query params', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/two/?foo=bar`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
|
|
it('Omitting the trailing slash results in a redirect that includes the base', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/two`, {
|
|
redirect: 'manual',
|
|
});
|
|
expect(res.status).to.equal(301);
|
|
expect(res.headers.get('location')).to.equal('/some-base/two/');
|
|
});
|
|
});
|
|
|
|
describe('Without base', async () => {
|
|
before(async () => {
|
|
process.env.PRERENDER = true;
|
|
|
|
fixture = await loadFixture({
|
|
root: './fixtures/prerender/',
|
|
output: 'server',
|
|
adapter: nodejs({ mode: 'standalone' }),
|
|
});
|
|
await fixture.build();
|
|
const { startServer } = await await load();
|
|
let res = startServer();
|
|
server = res.server;
|
|
});
|
|
|
|
after(async () => {
|
|
await server.stop();
|
|
await fixture.clean();
|
|
delete process.env.PRERENDER;
|
|
});
|
|
|
|
it('Can render SSR route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/one`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('One');
|
|
});
|
|
|
|
it('Can render prerendered route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/two`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
|
|
it('Can render prerendered route with redirect and query params', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/two?foo=bar`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
|
|
it('Can render prerendered route with query params', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/two/?foo=bar`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('Hybrid rendering', () => {
|
|
/** @type {import('./test-utils').Fixture} */
|
|
let fixture;
|
|
let server;
|
|
|
|
describe('With base', async () => {
|
|
before(async () => {
|
|
process.env.PRERENDER = false;
|
|
fixture = await loadFixture({
|
|
base: '/some-base',
|
|
root: './fixtures/prerender/',
|
|
output: 'hybrid',
|
|
adapter: nodejs({ mode: 'standalone' }),
|
|
});
|
|
await fixture.build();
|
|
const { startServer } = await await load();
|
|
let res = startServer();
|
|
server = res.server;
|
|
});
|
|
|
|
after(async () => {
|
|
await server.stop();
|
|
await fixture.clean();
|
|
delete process.env.PRERENDER;
|
|
});
|
|
|
|
it('Can render SSR route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/two`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
|
|
it('Can render prerendered route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/one`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('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`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('One');
|
|
});
|
|
|
|
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);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('One');
|
|
});
|
|
|
|
it('Omitting the trailing slash results in a redirect that includes the base', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/some-base/one`, {
|
|
redirect: 'manual',
|
|
});
|
|
expect(res.status).to.equal(301);
|
|
expect(res.headers.get('location')).to.equal('/some-base/one/');
|
|
});
|
|
});
|
|
|
|
describe('Without base', async () => {
|
|
before(async () => {
|
|
process.env.PRERENDER = false;
|
|
fixture = await loadFixture({
|
|
root: './fixtures/prerender/',
|
|
output: 'hybrid',
|
|
adapter: nodejs({ mode: 'standalone' }),
|
|
});
|
|
await fixture.build();
|
|
const { startServer } = await await load();
|
|
let res = startServer();
|
|
server = res.server;
|
|
});
|
|
|
|
after(async () => {
|
|
await server.stop();
|
|
await fixture.clean();
|
|
delete process.env.PRERENDER;
|
|
});
|
|
|
|
it('Can render SSR route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/two`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('Two');
|
|
});
|
|
|
|
it('Can render prerendered route', async () => {
|
|
const res = await fetch(`http://${server.host}:${server.port}/one`);
|
|
const html = await res.text();
|
|
const $ = cheerio.load(html);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('One');
|
|
});
|
|
|
|
it('Can render prerendered route with redirect 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);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('One');
|
|
});
|
|
|
|
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);
|
|
|
|
expect(res.status).to.equal(200);
|
|
expect($('h1').text()).to.equal('One');
|
|
});
|
|
});
|
|
});
|