From 481b4f3c6602d9cdab1f8c3c884edb938099c603 Mon Sep 17 00:00:00 2001 From: Ryan Christian <33403762+rschristian@users.noreply.github.com> Date: Wed, 24 Jul 2024 00:41:29 -0500 Subject: [PATCH] fix: Support `dangerouslySetInnerHTML={undefined}` with `renderToStringAsync` (#381) --- .changeset/chilly-ladybugs-think.md | 5 ++++ src/index.js | 4 ++- test/compat/async.test.jsx | 43 +++++++++++++++++++++++++++++ test/render.test.jsx | 30 +++++++++++++------- 4 files changed, 71 insertions(+), 11 deletions(-) create mode 100644 .changeset/chilly-ladybugs-think.md diff --git a/.changeset/chilly-ladybugs-think.md b/.changeset/chilly-ladybugs-think.md new file mode 100644 index 00000000..94172cfc --- /dev/null +++ b/.changeset/chilly-ladybugs-think.md @@ -0,0 +1,5 @@ +--- +'preact-render-to-string': patch +--- + +Support `dangerouslySetInnerHTML={undefined}` with `renderToStringAsync` diff --git a/src/index.js b/src/index.js index 743f25aa..ab4146fc 100644 --- a/src/index.js +++ b/src/index.js @@ -125,7 +125,9 @@ export async function renderToStringAsync(vnode, context) { // Resolving nested Promises with a maximum depth of 25 while ( - resolved.some((element) => typeof element.then === 'function') && + resolved.some( + (element) => element && typeof element.then === 'function' + ) && count++ < 25 ) { resolved = (await Promise.all(resolved)).flat(); diff --git a/test/compat/async.test.jsx b/test/compat/async.test.jsx index 968c12b1..12e9ac5a 100644 --- a/test/compat/async.test.jsx +++ b/test/compat/async.test.jsx @@ -226,4 +226,47 @@ describe('Async renderToString', () => { expect(rendered).to.equal(`
2
`); }); + + describe('dangerouslySetInnerHTML', () => { + it('should support dangerouslySetInnerHTML', async () => { + // some invalid HTML to make sure we're being flakey: + let html = 'asdf some text '; + let rendered = await renderToStringAsync( +
+ ); + expect(rendered).to.equal(`
${html}
`); + }); + + it('should accept undefined dangerouslySetInnerHTML', async () => { + const Test = () => ( + +
hi
+
+ + ); + + const rendered = await renderToStringAsync(); + expect(rendered).to.equal('
hi
'); + }); + + it('should accept null __html', async () => { + const Test = () => ( + +
hi
+
+ + ); + const rendered = await renderToStringAsync(); + expect(rendered).to.equal('
hi
'); + }); + + it('should override children', async () => { + let rendered = await renderToStringAsync( +
+ bar +
+ ); + expect(rendered).to.equal('
foo
'); + }); + }); }); diff --git a/test/render.test.jsx b/test/render.test.jsx index 134bdb0d..db418c2b 100644 --- a/test/render.test.jsx +++ b/test/render.test.jsx @@ -387,16 +387,6 @@ describe('render', () => { ); }); - it('should accept nullish __html', () => { - const Test = (props) => ( - -
hi
-
- - ); - expect(render()).to.equal('
hi
'); - }); - it('should apply defaultProps', () => { const Test = (props) =>
; Test.defaultProps = { @@ -835,6 +825,26 @@ describe('render', () => { expect(rendered).to.equal(`
${html}
`); }); + it('should accept undefined dangerouslySetInnerHTML', () => { + const Test = () => ( + +
hi
+
+ + ); + expect(render()).to.equal('
hi
'); + }); + + it('should accept null __html', () => { + const Test = () => ( + +
hi
+
+ + ); + expect(render()).to.equal('
hi
'); + }); + it('should override children', () => { let rendered = render(