diff --git a/test/compat/async.test.jsx b/test/compat/async.test.jsx index 0ca7835..62a347d 100644 --- a/test/compat/async.test.jsx +++ b/test/compat/async.test.jsx @@ -254,6 +254,48 @@ describe('Async renderToString', () => { expect(rendered).to.equal(expected); }); + it('should render JSX with multiple suspended direct children within a single suspense boundary that resolve one-after-another', async () => { + const { + Suspender: SuspenderOne, + suspended: suspendedOne + } = createSuspender(); + const { + Suspender: SuspenderTwo, + suspended: suspendedTwo + } = createSuspender(); + const { + Suspender: SuspenderThree, + suspended: suspendedThree + } = createSuspender(); + + const promise = renderToStringAsync( + + ); + + const expected = ``; + + suspendedOne.promise.then(() => { void suspendedTwo.resolve();}); + suspendedTwo.promise.then(() => { void suspendedThree.resolve();}); + + suspendedOne.resolve(); + + const rendered = await promise; + + expect(rendered).to.equal(expected); + }); + it('should rethrow error thrown after suspending', async () => { const { suspended, getResolved } = createSuspender();