From 29876097088c125de4512f9b845eaac0e32001cd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebastian=20Markb=C3=A5ge?= Date: Mon, 19 Feb 2024 11:50:04 -0500 Subject: [PATCH] Recover from SSR error in Flight fixture (#28368) If an error happens before the shell, we need to handle it. In this case we choose the strategy of rendering a blank document and client rendering the app. Which will intentionally have a hydration mismatch. --- fixtures/flight/server/global.js | 13 ++++++++++++- fixtures/flight/server/region.js | 9 ++------- 2 files changed, 14 insertions(+), 8 deletions(-) diff --git a/fixtures/flight/server/global.js b/fixtures/flight/server/global.js index 6e284e78d55ee..779270e16f44e 100644 --- a/fixtures/flight/server/global.js +++ b/fixtures/flight/server/global.js @@ -174,8 +174,19 @@ app.all('/', async function (req, res, next) { const {pipe} = renderToPipeableStream(React.createElement(Root), { bootstrapScripts: mainJSChunks, formState: formState, + onShellReady() { + pipe(res); + }, + onShellError(error) { + const {pipe: pipeError} = renderToPipeableStream( + React.createElement('html', null, React.createElement('body')), + { + bootstrapScripts: mainJSChunks, + } + ); + pipeError(res); + }, }); - pipe(res); } catch (e) { console.error(`Failed to SSR: ${e.stack}`); res.statusCode = 500; diff --git a/fixtures/flight/server/region.js b/fixtures/flight/server/region.js index e89f113b7cad6..3a12d4e118cd8 100644 --- a/fixtures/flight/server/region.js +++ b/fixtures/flight/server/region.js @@ -103,13 +103,8 @@ app.get('/', async function (req, res) { }); app.post('/', bodyParser.text(), async function (req, res) { - const { - renderToPipeableStream, - decodeReply, - decodeReplyFromBusboy, - decodeAction, - decodeFormState, - } = await import('react-server-dom-webpack/server'); + const {decodeReply, decodeReplyFromBusboy, decodeAction, decodeFormState} = + await import('react-server-dom-webpack/server'); const serverReference = req.get('rsc-action'); if (serverReference) { // This is the client-side case