import { describe, it, expect } from "bun:test"; import { gcTick } from "./gc"; import { escapeHTML } from "bun"; describe("escapeHTML", () => { // The matrix of cases we need to test for: // 1. Works with short strings // 2. Works with long strings // 3. Works with latin1 strings // 4. Works with utf16 strings // 5. Works when the text to escape is somewhere in the middle // 6. Works when the text to escape is in the beginning // 7. Works when the text to escape is in the end // 8. Returns the same string when there's no need to escape it("works", () => { expect(escapeHTML("absolutely nothing to do here")).toBe( "absolutely nothing to do here" ); expect(escapeHTML("")).toBe( "<script>alert(1)</script>" ); expect(escapeHTML("<")).toBe("<"); expect(escapeHTML(">")).toBe(">"); expect(escapeHTML("&")).toBe("&"); expect(escapeHTML("'")).toBe("'"); expect(escapeHTML('"')).toBe("""); expect(escapeHTML("\n")).toBe("\n"); expect(escapeHTML("\r")).toBe("\r"); expect(escapeHTML("\t")).toBe("\t"); expect(escapeHTML("\f")).toBe("\f"); expect(escapeHTML("\v")).toBe("\v"); expect(escapeHTML("\b")).toBe("\b"); expect(escapeHTML("\u00A0")).toBe("\u00A0"); expect(escapeHTML("" + "lalala")).toBe( "lalala<script>alert(1)</script>lalala" ); expect(escapeHTML("" + "lalala")).toBe( "<script>alert(1)</script>lalala" ); expect(escapeHTML("lalala" + "")).toBe( "lalala" + "<script>alert(1)</script>" ); expect(escapeHTML("What does 😊 mean?")).toBe("What does 😊 mean?"); const output = escapeHTML("What does 😊 mean in text?")).toBe( "<div>What does 😊 mean in text?" ); expect( escapeHTML( ("lalala" + "" + "lalala").repeat(900) ) ).toBe("lalala<script>alert(1)</script>lalala".repeat(900)); expect( escapeHTML(("" + "lalala").repeat(900)) ).toBe("<script>alert(1)</script>lalala".repeat(900)); expect( escapeHTML(("lalala" + "").repeat(900)) ).toBe(("lalala" + "<script>alert(1)</script>").repeat(900)); // the positions of the unicode codepoint are important // our simd code for U16 is at 8 bytes, so we need to especially check the boundaries expect( escapeHTML("😊lalala" + "" + "lalala") ).toBe("😊lalala<script>alert(1)</script>lalala"); expect(escapeHTML("" + "lalala")).toBe( "<script>😊alert(1)</script>lalala" ); expect(escapeHTML("" + "lalala")).toBe( "<script>alert(1)😊</script>lalala" ); expect(escapeHTML("" + "😊lalala")).toBe( "<script>alert(1)</script>😊lalala" ); expect(escapeHTML("" + "lal😊ala")).toBe( "<script>alert(1)</script>lal😊ala" ); expect( escapeHTML("" + "lal😊ala".repeat(10)) ).toBe("<script>alert(1)</script>" + "lal😊ala".repeat(10)); for (let i = 1; i < 10; i++) expect(escapeHTML("" + "la😊".repeat(i))).toBe( "<script>alert(1)</script>" + "la😊".repeat(i) ); expect(escapeHTML("la😊" + "")).toBe( "la😊" + "<script>alert(1)</script>" ); expect( escapeHTML(("lalala" + "😊").repeat(1)) ).toBe(("lalala" + "<script>alert(1)</script>😊").repeat(1)); expect(escapeHTML("😊".repeat(100))).toBe("😊".repeat(100)); expect(escapeHTML("😊<".repeat(100))).toBe("😊<".repeat(100)); expect(escapeHTML("<😊>".repeat(100))).toBe("<😊>".repeat(100)); expect(escapeHTML("😊")).toBe("😊"); expect(escapeHTML("😊😊")).toBe("😊😊"); expect(escapeHTML("😊lo")).toBe("😊lo"); expect(escapeHTML("lo😊")).toBe("lo😊"); expect(escapeHTML(" ".repeat(32) + "😊")).toBe(" ".repeat(32) + "😊"); expect(escapeHTML(" ".repeat(32) + "😊😊")).toBe(" ".repeat(32) + "😊😊"); expect(escapeHTML(" ".repeat(32) + "😊lo")).toBe(" ".repeat(32) + "😊lo"); expect(escapeHTML(" ".repeat(32) + "lo😊")).toBe(" ".repeat(32) + "lo😊"); }); }); ption value='feat/npm'>feat/npm Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
path: root/bench/snippets/tcp-echo.bun.ts (unfollow)
AgeCommit message (Expand)AuthorFilesLines
2022-11-27Add tests for latin1 supplemental charsGravatar Jarred Sumner 1-13/+56
2022-11-27fix hanging testGravatar Jarred Sumner 1-8/+13
2022-11-27don't start NetworkThread unless necessaryGravatar Jarred Sumner 2-3/+2
2022-11-27Fix `make headers`Gravatar Jarred Sumner 3-1/+4
2022-11-27fix extra indentGravatar Jarred Sumner 1-0/+2
2022-11-27[console.log] Fix printing latin1 supplement characters at runtimeGravatar Jarred Sumner 6-37/+83
2022-11-27[console.log] Improve Object formatting and error handlingGravatar Jarred Sumner 3-182/+399
2022-11-27`[console.log]` log Proxy objectsGravatar Jarred Sumner 1-0/+7
2022-11-27[console.log] Treat `GlobalObject` like `Object`Gravatar Jarred Sumner 1-1/+1
2022-11-27[console.log] Treat `ArrayBuffer` like `Uint8Array`Gravatar Jarred Sumner 1-0/+1
2022-11-27[console.log] Fix logging `Symbol` valuesGravatar Jarred Sumner 1-3/+2
2022-11-27Now that utf16 is fast we can just count the length instead of re-allocatingGravatar Jarred Sumner 1-5/+1
2022-11-27Remove extra indentGravatar Jarred Sumner 1-2/+0
2022-11-27Fix strangeness with Bun.env keysGravatar Jarred Sumner 1-9/+10
2022-11-27Fix crash in Headers.prototype.countGravatar Jarred Sumner 1-2/+5
2022-11-27Fix crash in OnigurumaRegExp gettersGravatar Jarred Sumner 1-0/+6
2022-11-26Fix build issueGravatar Jarred Sumner 2-15/+17
2022-11-26[bun:sqlite] Fix bug with latin1 supplemental charactersGravatar Jarred Sumner 2-2/+31
2022-11-26prettier?Gravatar Jarred Sumner 1-336/+339
2022-11-26Update mimallocGravatar Jarred Sumner 1-0/+0
2022-11-26Update string_immutable.zigGravatar Jarred Sumner 1-1/+1
2022-11-26Faster UTF16 -> UTF8 and UTF8 -> UTF16 (#1552)Gravatar Jarred Sumner 14-6/+31329
2022-11-26Make HTTP status text more consistent with other HTTP serversGravatar Jarred Sumner 2-2/+153