import { describe, it, expect } from "bun:test"; import { gcTick } from "./gc"; var setTimeoutAsync = (fn, delay) => { return new Promise((resolve, reject) => { setTimeout(() => { try { resolve(fn()); } catch (e) { reject(e); } }, delay); }); }; describe("HTMLRewriter", () => { it("HTMLRewriter: async replacement", async () => { await gcTick(); const res = new HTMLRewriter() .on("div", { async element(element) { await setTimeoutAsync(() => { element.setInnerContent("replace", { html: true }); }, 5); }, }) .transform(new Response("
example.com
")); await gcTick(); expect(await res.text()).toBe("
replace
"); await gcTick(); }); it("supports element handlers", async () => { var rewriter = new HTMLRewriter(); rewriter.on("div", { element(element) { element.setInnerContent("it worked!", { html: true }); }, }); var input = new Response("
hello
"); var output = rewriter.transform(input); expect(await output.text()).toBe("
it worked!
"); }); it("(from file) supports element handlers", async () => { var rewriter = new HTMLRewriter(); rewriter.on("div", { element(element) { element.setInnerContent("it worked!", { html: true }); }, }); await Bun.write("/tmp/html-rewriter.txt.js", "
hello
"); var input = new Response(Bun.file("/tmp/html-rewriter.txt.js")); var output = rewriter.transform(input); expect(await output.text()).toBe("
it worked!
"); }); it("supports attribute iterator", async () => { var rewriter = new HTMLRewriter(); var expected = [ ["first", ""], ["second", "alrihgt"], ["third", "123"], ["fourth", "5"], ["fifth", "helloooo"], ]; rewriter.on("div", { element(element2) { for (let attr of element2.attributes) { const stack = expected.shift(); expect(stack[0]).toBe(attr[0]); expect(stack[1]).toBe(attr[1]); } }, }); var input = new Response( '
hello
' ); var output = rewriter.transform(input); expect(await output.text()).toBe( '
hello
' ); expect(expected.length).toBe(0); }); it("handles element specific mutations", async () => { // prepend/append let res = new HTMLRewriter() .on("p", { element(element) { element.prepend("prepend"); element.prepend("prepend html", { html: true }); element.append("append"); element.append("append html", { html: true }); }, }) .transform(new Response("

test

")); expect(await res.text()).toBe( [ "

", "prepend html", "<span>prepend</span>", "test", "<span>append</span>", "append html", "

", ].join("") ); // setInnerContent res = new HTMLRewriter() .on("p", { element(element) { element.setInnerContent("replace"); }, }) .transform(new Response("

test

")); expect(await res.text()).toBe("

<span>replace</span>

"); res = new HTMLRewriter() .on("p", { element(element) { element.setInnerContent("replace", { html: true }); }, }) .transform(new Response("

test

")); expect(await res.text()).toBe("

replace

"); // removeAndKeepContent res = new HTMLRewriter() .on("p", { element(element) { element.removeAndKeepContent(); }, }) .transform(new Response("

test

")); expect(await res.text()).toBe("test"); }); it("handles element class properties", async () => { class Handler { constructor(content) { this.content = content; } // noinspection JSUnusedGlobalSymbols element(element) { element.setInnerContent(this.content); } } const res = new HTMLRewriter() .on("p", new Handler("new")) .transform(new Response("

test

")); expect(await res.text()).toBe("

new

"); }); const commentsMutationsInput = "

"; const commentsMutationsExpected = { beforeAfter: [ "

", "<span>before</span>", "before html", "", "after html", "<span>after</span>", "

", ].join(""), replace: "

<span>replace</span>

", replaceHtml: "

replace

", remove: "

", }; const commentPropertiesMacro = async (func) => { const res = func(new HTMLRewriter(), (comment) => { expect(comment.removed).toBe(false); expect(comment.text).toBe("test"); comment.text = "new"; expect(comment.text).toBe("new"); }).transform(new Response("

")); expect(await res.text()).toBe("

"); }; it("HTMLRewriter: handles comment properties", () => commentPropertiesMacro((rw, comments) => { rw.on("p", { comments }); return rw; })); it("selector tests", async () => { const checkSelector = async (selector, input, expected) => { const res = new HTMLRewriter() .on(selector, { element(element) { element.setInnerContent("new"); }, }) .transform(new Response(input)); expect(await res.text()).toBe(expected); }; await checkSelector("*", "

1

2

", "

new

new

"); await checkSelector("p", "

1

2

", "

1

new

"); await checkSelector( "p:nth-child(2)", "

1

2

3

", "

1

new

3

" ); await checkSelector( "p:first-child", "

1

2

3

", "

new

2

3

" ); await checkSelector( "p:nth-of-type(2)", "

1

2

3

4

5

", "

1

2

new

4

5

" ); await checkSelector( "p:first-of-type", "

1

2

3

", "

1

new

3

" ); await checkSelector( "p:not(:first-child)", "

1

2

3

", "

1

new

new

" ); await checkSelector( "p.red", '

1

2

', '

new

2

' ); await checkSelector( "h1#header", '

1

2

', '

new

2

' ); await checkSelector( "p[data-test]", "

1

2

", "

new

2

" ); await checkSelector( 'p[data-test="one"]', '

1

2

', '

new

2

' ); await checkSelector( 'p[data-test="one" i]', '

1

2

3

', '

new

new

3

' ); await checkSelector( 'p[data-test="one" s]', '

1

2

3

', '

new

2

3

' ); await checkSelector( 'p[data-test~="two"]', '

1

2

3

', '

new

new

3

' ); await checkSelector( 'p[data-test^="a"]', '

1

2

3

', '

new

new

3

' ); await checkSelector( 'p[data-test$="1"]', '

1

2

3

', '

new

2

new

' ); await checkSelector( 'p[data-test*="b"]', '

1

2

3

', '

new

new

3

' ); await checkSelector( 'p[data-test|="a"]', '

1

2

3

', '

new

new

3

' ); await checkSelector( "div span", "

1

23
", "

new

new3
" ); await checkSelector( "div > span", "

1

23
", "

1

new3
" ); }); }); Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
path: root/docs/dev/css.md (unfollow)
AgeCommit message (Collapse)AuthorFilesLines
2023-09-05feat(runtime): Implement `fs.watchFile` (#4467)Gravatar dave caruso 17-12/+1309
* really lame prototype * uses threads but badly * it works i guess * unwatchFile but lame * it works * test * a * aomitcs * fix unwatching race condition * use hasPendingActivity and GC stuff better * test * revert this
2023-09-05fix(node:net): emit close event on connection error (#4336)Gravatar dave caruso 3-11/+24
* emit close event on connection error * re-review * add test
2023-09-05fix(fetch) always use readable stream if it is available (#4503)Gravatar Ciro Spaciari 2-27/+82
* always use readable stream if it is available * use bun sleep * fix tests * rm uws dep
2023-09-05fix SSL proxy tunneling on fetch (#4510)Gravatar Ciro Spaciari 2-17/+76
2023-09-05fix(install): ensure all lockfile structs do not have undefined padding (#4401)Gravatar dave caruso 5-2/+113
* padding sucks * this assertion is already done elsewhere * remove test. will be covered alex's pr i believe? * fix webkit submodule * fix uws submodule
2023-09-05fix checkout/build failure due to `src/deps/uws` (#4505)Gravatar Alex Lam S.L 5-15/+10
2023-09-05fix ipv6 localhost fetch (#4498)Gravatar Dylan Conway 2-2/+31
* `node` null for localhost getaddrinfo * more test
2023-09-05minor rebuild diffs (#4486)Gravatar Alex Lam S.L 4-4999/+4999
2023-09-05fix dup syscall on Windows (#4496)Gravatar Jason 2-3/+3
2023-09-04no need to chmod (#4490)Gravatar Dylan Conway 1-2/+0
2023-09-04fix zlib deflate on fetch (#4483)Gravatar Ciro Spaciari 3-8/+47
* fix zlib deflate on fetch * mention issue on test * more tests * oops
2023-09-04chore: fix typo (#4476)Gravatar Ai Hoshino 1-1/+1
Close: #4377
2023-09-04fix(HTMLRewriter) buffer response before transform (#4418)Gravatar Ciro Spaciari 18-5941/+6655
* html rewriter response buffering * pipe the data when marked as used * fix empty response * add some fetch tests * deinit parent stream * fix decompression * keep byte_reader alive * update builds * remove nonsense * was not nonsense after all * protect tmp ret value from GC, fix readable strong ref deinit/init * fmt * if we detach the stream we cannot update the fetch stream * detach checking source * more tests, progress with javascript and Direct sink * drop support for pure readable stream for now * more fixes --------- Co-authored-by: Jarred Sumner <jarred@jarredsumner.com>
2023-09-03initialize JSC for macros from cliGravatar Dylan Conway 1-0/+4
2023-09-03fix(syscall): fix handling syscall errno (#4461)Gravatar Ai Hoshino 2-1/+22
* fix(syscall): fix handling syscall errno Close: #4198 * remove unused code * add more tests * remove unused code
2023-09-02workaround a zig bug (#4440)Gravatar dave caruso 1-3/+4
2023-09-01docs: fix http simple example log statement (#4320)Gravatar Karl Böhlmark 1-1/+1
Co-authored-by: Karl Böhlmark <karl.bohlmark@netinsight.net>
2023-09-01Fix typo (#4445)Gravatar Jorge Jiménez 1-1/+1
Replace `key: [Bun.file('./key1.pem'), Bun.file('./key2.pem']` with `key: [Bun.file('./key1.pem'), Bun.file('./key2.pem')]`
2023-09-01keep export star as (#4451)Gravatar Dylan Conway 1-14/+0
2023-09-01bun-vscode 0.0.8Gravatar Colin McDonnell 3-41/+39
2023-09-01Update commandsGravatar Colin McDonnell 3-4/+6
2023-09-01fix `Bun.serve` with tls and `Bun.file` (#4450)Gravatar Dylan Conway 3-14/+40
* check sendfile ctx * add test * undo blob check * undo undo and add assert
2023-09-01exclusive maxGravatar Dylan Conway 1-1/+1
2023-09-01Fix debug console from appears on startGravatar Ashcon Partovi 2-2/+5
2023-09-01Add configuration options to extensionGravatar Ashcon Partovi 5-5/+137
2023-09-01Fix run button starting cwd at /Gravatar Ashcon Partovi 1-0/+2
2023-09-01fix(runtime): fix dns_resolver crash (#4435)Gravatar dave caruso 3-17/+19
* fix incorrect c pointer * format * lets go * random other test case fixed * hanassagi patch * Update dns_resolver.zig * Revert "Update dns_resolver.zig" This reverts commit 53eb338048583a338e7c01d2b351f1c679db3e15. * See if the tests pass --------- Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> Co-authored-by: Jarred Sumner <jarred@jarredsumner.com>
2023-09-01Fix background colorGravatar Ashcon Partovi 1-2/+3
2023-09-01Allow older versions of VSCodeGravatar Ashcon Partovi 2-6/+5
2023-09-01Fix README for extensionGravatar Ashcon Partovi 2-7/+12
2023-09-01Update VSCode extensionGravatar Ashcon Partovi 1-3/+4
2023-09-01Fix breakpoint on entry for extensionGravatar Ashcon Partovi 5-18/+15
2023-09-01Add Bun.canReload event to inspectorGravatar Ashcon Partovi 2-0/+17
2023-08-31JavaScript Debug Terminal == Bun TerminalGravatar Ashcon Partovi 1-0/+32
2023-08-31fix(runtime): `fs.cp` edge cases (#4439)Gravatar dave caruso 2-8/+44
* yippee * enable cpSync tests * much better * that doesnt actually do anything * lose
2023-08-31only set initial debugger breakpoint once (#4441)Gravatar Dylan Conway 1-2/+11
* unset `set_breakpoint_on_first_line` on reload * move to `module_loader.zig`
2023-08-31Make breakpoints faster in VSCode extensionGravatar Ashcon Partovi 1-241/+327
2023-08-31`bun install` correctly join dependency URLs (#4421)Gravatar Julian 6-64/+243
* use WTF to join registry strings * show dependency error messages, better join error We actually report errors when enqueuing dependencies now. I also made the join URLs error message read better. It'd be cleaner to handle it all in one place, but there's currently no way to propagate the data up. * starting on registry URL tests * added more registry URL tests * [install] prevent optional/peer deps from failing builds Couldn't get the peer dependency test to work, but the code is there. * ran prettier * changed error note to use realname, updated tests * ran prettier again...
2023-08-31get name if not provided in `FormData.append` (#4434)Gravatar Dylan Conway 4-5/+45
* get file name from blob if not provided * add test * another test * format
2023-08-31Fix vscode debug terminalGravatar Ashcon Partovi 1-21/+0