summaryrefslogtreecommitdiff
path: root/packages/integrations/node/test/bad-urls.test.js
diff options
context:
space:
mode:
authorGravatar Alexander Niebuhr <alexander@nbhr.io> 2024-08-29 20:05:48 +0200
committerGravatar GitHub <noreply@github.com> 2024-08-29 20:05:48 +0200
commitf5663e40ace3db796de60cadaed7cd6e35c96717 (patch)
treea1ad2fbcf5d49448e8dbf3d351a7800937b7f3a8 /packages/integrations/node/test/bad-urls.test.js
parent93a1db68cd9cf3bb2a4d9f7a8af13cbd881eb701 (diff)
parent61ea0cb7b878c53aa0585ffafd394e3fcda41924 (diff)
downloadastro-f5663e40ace3db796de60cadaed7cd6e35c96717.tar.gz
astro-f5663e40ace3db796de60cadaed7cd6e35c96717.tar.zst
astro-f5663e40ace3db796de60cadaed7cd6e35c96717.zip
Merge `vercel` and `node` into next #367
chore: move `vercel` & `node` to next branch
Diffstat (limited to 'packages/integrations/node/test/bad-urls.test.js')
-rw-r--r--packages/integrations/node/test/bad-urls.test.js49
1 files changed, 49 insertions, 0 deletions
diff --git a/packages/integrations/node/test/bad-urls.test.js b/packages/integrations/node/test/bad-urls.test.js
new file mode 100644
index 000000000..cdc0158ff
--- /dev/null
+++ b/packages/integrations/node/test/bad-urls.test.js
@@ -0,0 +1,49 @@
+import * as assert from 'node:assert/strict';
+import { after, before, describe, it } from 'node:test';
+import nodejs from '../dist/index.js';
+import { loadFixture } from './test-utils.js';
+
+describe('Bad URLs', () => {
+ /** @type {import('./test-utils').Fixture} */
+ let fixture;
+ let devPreview;
+
+ before(async () => {
+ fixture = await loadFixture({
+ root: './fixtures/bad-urls/',
+ output: 'server',
+ adapter: nodejs({ mode: 'standalone' }),
+ });
+ await fixture.build();
+ devPreview = await fixture.preview();
+ });
+
+ after(async () => {
+ await devPreview.stop();
+ });
+
+ it('Does not crash on bad urls', async () => {
+ const weirdURLs = [
+ '/\\xfs.bxss.me%3Fastrojs.com/hello-world',
+ '/asdasdasd@ax_zX=.zxczasđŸ„%/Ășadasd000%/',
+ '%',
+ '%80',
+ '%c',
+ '%c0%80',
+ '%20foobar%',
+ ];
+
+ const statusCodes = [400, 404, 500];
+ for (const weirdUrl of weirdURLs) {
+ const fetchResult = await fixture.fetch(weirdUrl);
+ assert.equal(
+ statusCodes.includes(fetchResult.status),
+ true,
+ `${weirdUrl} returned something else than 400, 404, or 500`
+ );
+ }
+ const stillWork = await fixture.fetch('/');
+ const text = await stillWork.text();
+ assert.equal(text, '<!DOCTYPE html>Hello!');
+ });
+});