diff --git a/packages/react-server-dom-webpack/src/__tests__/ReactFlightDOMForm-test.js b/packages/react-server-dom-webpack/src/__tests__/ReactFlightDOMForm-test.js index a039a80823be7..b86e3447540b2 100644 --- a/packages/react-server-dom-webpack/src/__tests__/ReactFlightDOMForm-test.js +++ b/packages/react-server-dom-webpack/src/__tests__/ReactFlightDOMForm-test.js @@ -17,6 +17,23 @@ global.ReadableStream = global.TextEncoder = require('util').TextEncoder; global.TextDecoder = require('util').TextDecoder; +// Polyfill stream methods on JSDOM. +global.Blob.prototype.stream = function () { + const impl = Object.getOwnPropertySymbols(this)[0]; + const buffer = this[impl]._buffer; + return new ReadableStream({ + start(c) { + c.enqueue(new Uint8Array(buffer)); + c.close(); + }, + }); +}; + +global.Blob.prototype.text = async function () { + const impl = Object.getOwnPropertySymbols(this)[0]; + return this[impl]._buffer.toString('utf8'); +}; + // Don't wait before processing work on the server. // TODO: we can replace this with FlightServer.act(). global.setTimeout = cb => cb(); @@ -975,10 +992,12 @@ describe('ReactFlightDOMForm', () => { function Form({action}) { const [errorMsg, dispatch] = useActionState(action, null); + let text; if (errorMsg) { blob = errorMsg; + text = React.use(blob.text()); } - return
; + return ; } const FormRef = await clientExports(Form); @@ -1008,21 +1027,19 @@ describe('ReactFlightDOMForm', () => { container.innerHTML = ''; const postbackRscStream = ReactServerDOMServer.renderToReadableStream( -