Fix up validatePageName routine (#912)
* Fix up validatePageName routine File extensions can contain numbers too. My main motivation was to enable myself hosting `woff2` files right from my space, like I do for `ttf` files. Also added some tests. * Fix up typo and add more numeric samples * Add missing semicolons (sorry, I'm not really js/ts programmer) * Make linter happypull/917/head
parent
1e58d220eb
commit
09e7f1f906
|
@ -1,5 +1,5 @@
|
||||||
import { encodePageRef, parsePageRef } from "./page_ref.ts";
|
import { encodePageRef, parsePageRef, validatePageName } from "./page_ref.ts";
|
||||||
import { assertEquals } from "$std/testing/asserts.ts";
|
import { assertEquals, assertThrows, AssertionError } from "$std/testing/asserts.ts";
|
||||||
|
|
||||||
Deno.test("Page utility functions", () => {
|
Deno.test("Page utility functions", () => {
|
||||||
// Base cases
|
// Base cases
|
||||||
|
@ -26,4 +26,24 @@ Deno.test("Page utility functions", () => {
|
||||||
assertEquals(encodePageRef({ page: "foo", pos: 10 }), "foo@10");
|
assertEquals(encodePageRef({ page: "foo", pos: 10 }), "foo@10");
|
||||||
assertEquals(encodePageRef({ page: "foo", anchor: "bar" }), "foo$bar");
|
assertEquals(encodePageRef({ page: "foo", anchor: "bar" }), "foo$bar");
|
||||||
assertEquals(encodePageRef({ page: "foo", header: "bar" }), "foo#bar");
|
assertEquals(encodePageRef({ page: "foo", header: "bar" }), "foo#bar");
|
||||||
|
|
||||||
|
// Page name validation
|
||||||
|
|
||||||
|
try {
|
||||||
|
validatePageName("perfectly fine page name");
|
||||||
|
} catch (error) {
|
||||||
|
throw new AssertionError(`Something is very wrong with the validatePageName function: ${error}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
assertThrows(() => validatePageName(""), Error);
|
||||||
|
assertThrows(() => validatePageName(".hidden"), Error);
|
||||||
|
assertThrows(() => validatePageName(".."), Error);
|
||||||
|
|
||||||
|
for (const extension of ["md", "txt", "exe", "cc", "ts"]) {
|
||||||
|
assertThrows(() => validatePageName(`extensions-are-not-welcome.${extension}`), Error);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (const extension of ["db2", "woff2", "sqlite3", "42", "0"]) {
|
||||||
|
assertThrows(() => validatePageName(`extensions-can-contain-numbers-too.${extension}`), Error);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -6,7 +6,7 @@ export function validatePageName(name: string) {
|
||||||
if (name.startsWith(".")) {
|
if (name.startsWith(".")) {
|
||||||
throw new Error("Page name cannot start with a '.'");
|
throw new Error("Page name cannot start with a '.'");
|
||||||
}
|
}
|
||||||
if (/\.[a-zA-Z]+$/.test(name)) {
|
if (/\.[a-zA-Z0-9]+$/.test(name)) {
|
||||||
throw new Error("Page name can not end with a file extension");
|
throw new Error("Page name can not end with a file extension");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue