2024-01-25 16:17:31 +00:00
|
|
|
import * as assert from 'node:assert/strict';
|
2024-02-21 14:08:19 +00:00
|
|
|
import { after, before, describe, it } from 'node:test';
|
2023-04-04 15:48:28 +02:00
|
|
|
import nodejs from '../dist/index.js';
|
|
|
|
import { loadFixture } from './test-utils.js';
|
|
|
|
|
2023-11-28 00:33:10 +08:00
|
|
|
describe('Bad URLs', () => {
|
2023-04-04 15:48:28 +02:00
|
|
|
/** @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%',
|
|
|
|
];
|
|
|
|
|
2024-01-25 16:17:31 +00:00
|
|
|
const statusCodes = [400, 404, 500];
|
2023-04-04 15:48:28 +02:00
|
|
|
for (const weirdUrl of weirdURLs) {
|
|
|
|
const fetchResult = await fixture.fetch(weirdUrl);
|
2024-01-25 16:17:31 +00:00
|
|
|
assert.equal(
|
|
|
|
statusCodes.includes(fetchResult.status),
|
|
|
|
true,
|
2024-01-17 13:10:43 +00:00
|
|
|
`${weirdUrl} returned something else than 400, 404, or 500`
|
2023-04-04 15:48:28 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
const stillWork = await fixture.fetch('/');
|
|
|
|
const text = await stillWork.text();
|
2024-01-25 16:17:31 +00:00
|
|
|
assert.equal(text, '<!DOCTYPE html>Hello!');
|
2023-04-04 15:48:28 +02:00
|
|
|
});
|
|
|
|
});
|