summaryrefslogtreecommitdiff
path: root/packages/integrations/node/test/node-middleware.test.js
diff options
context:
space:
mode:
authorGravatar Alexander Niebuhr <alexander@nbhr.io> 2024-08-29 07:50:22 +0200
committerGravatar Alexander Niebuhr <alexander@nbhr.io> 2024-08-29 07:51:04 +0200
commit29f97307e38f91e777c8d9be5d4d84bd006e992e (patch)
treefd678596b1a821a046ba15cd550289a9a85f62a1 /packages/integrations/node/test/node-middleware.test.js
parent93a1db68cd9cf3bb2a4d9f7a8af13cbd881eb701 (diff)
parent3cea76e35c7633b0069dca45e9cb7b14a492ec64 (diff)
downloadastro-29f97307e38f91e777c8d9be5d4d84bd006e992e.tar.gz
astro-29f97307e38f91e777c8d9be5d4d84bd006e992e.tar.zst
astro-29f97307e38f91e777c8d9be5d4d84bd006e992e.zip
Merge branch 'node' into main
Diffstat (limited to 'packages/integrations/node/test/node-middleware.test.js')
-rw-r--r--packages/integrations/node/test/node-middleware.test.js88
1 files changed, 88 insertions, 0 deletions
diff --git a/packages/integrations/node/test/node-middleware.test.js b/packages/integrations/node/test/node-middleware.test.js
new file mode 100644
index 000000000..d1b016a51
--- /dev/null
+++ b/packages/integrations/node/test/node-middleware.test.js
@@ -0,0 +1,88 @@
+import * as assert from 'node:assert/strict';
+import { after, before, describe, it } from 'node:test';
+import * as cheerio from 'cheerio';
+import express from 'express';
+import nodejs from '../dist/index.js';
+import { loadFixture, waitServerListen } from './test-utils.js';
+
+/**
+ * @typedef {import('../../../astro/test/test-utils').Fixture} Fixture
+ */
+
+describe('behavior from middleware, standalone', () => {
+ /** @type {import('./test-utils').Fixture} */
+ let fixture;
+ let server;
+
+ before(async () => {
+ process.env.PRERENDER = false;
+ fixture = await loadFixture({
+ root: './fixtures/node-middleware/',
+ output: 'server',
+ adapter: nodejs({ mode: 'standalone' }),
+ });
+ await fixture.build();
+ const { startServer } = await fixture.loadAdapterEntryModule();
+ let res = startServer();
+ server = res.server;
+ await waitServerListen(server.server);
+ });
+
+ after(async () => {
+ await server.stop();
+ await fixture.clean();
+ delete process.env.PRERENDER;
+ });
+
+ describe('404', async () => {
+ it('when mode is standalone', async () => {
+ const res = await fetch(`http://${server.host}:${server.port}/error-page`);
+
+ assert.equal(res.status, 404);
+
+ const html = await res.text();
+ const $ = cheerio.load(html);
+
+ const body = $('body');
+ assert.equal(body.text().includes('Page does not exist'), true);
+ });
+ });
+});
+
+describe('behavior from middleware, middleware', () => {
+ /** @type {import('./test-utils').Fixture} */
+ let fixture;
+ let server;
+
+ before(async () => {
+ process.env.PRERENDER = false;
+ fixture = await loadFixture({
+ root: './fixtures/node-middleware/',
+ output: 'server',
+ adapter: nodejs({ mode: 'middleware' }),
+ });
+ await fixture.build();
+ const { handler } = await fixture.loadAdapterEntryModule();
+ const app = express();
+ app.use(handler);
+ server = app.listen(8888);
+ });
+
+ after(async () => {
+ server.close();
+ await fixture.clean();
+ delete process.env.PRERENDER;
+ });
+
+ it('when mode is standalone', async () => {
+ const res = await fetch(`http://localhost:8888/ssr`);
+
+ assert.equal(res.status, 200);
+
+ const html = await res.text();
+ const $ = cheerio.load(html);
+
+ const body = $('body');
+ assert.equal(body.text().includes("Here's a random number"), true);
+ });
+});