import { encodePageRef, parsePageRef, validatePageName } from "./page_ref.ts"; import { assertEquals, AssertionError, assertThrows, } from "$std/testing/asserts.ts"; Deno.test("Page utility functions", () => { // Base cases assertEquals(parsePageRef("foo"), { page: "foo" }); assertEquals(parsePageRef("[[foo]]"), { page: "foo" }); assertEquals(parsePageRef("foo@1"), { page: "foo", pos: 1 }); assertEquals(parsePageRef("foo$bar"), { page: "foo", anchor: "bar" }); assertEquals(parsePageRef("foo#My header"), { page: "foo", header: "My header", }); assertEquals(parsePageRef("foo$bar@1"), { page: "foo", anchor: "bar", pos: 1, }); // Meta page assertEquals(parsePageRef("^foo"), { page: "foo", meta: true }); // Edge cases assertEquals(parsePageRef(""), { page: "" }); assertEquals(parsePageRef("user@domain.com"), { page: "user@domain.com" }); // Encoding assertEquals(encodePageRef({ page: "foo" }), "foo"); assertEquals(encodePageRef({ page: "foo", pos: 10 }), "foo@10"); assertEquals(encodePageRef({ page: "foo", anchor: "bar" }), "foo$bar"); assertEquals(encodePageRef({ page: "foo", header: "bar" }), "foo#bar"); // Page name validation try { validatePageName("perfectly fine page name"); validatePageName("this is special case of a.conflicted.1234"); } 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, ); } });