From 87e735a96196b52ae546cffb77cd705de91953ce Mon Sep 17 00:00:00 2001 From: Noah Lemen Date: Thu, 1 Feb 2024 14:49:30 -0500 Subject: [PATCH] convert ReactElement-test from renderIntoDocument (#28161) ## Summary refactors ReactElement-test to use `createRoot` instead of `renderIntoDocument`, which uses `ReactDOM.render` under the hood ## How did you test this change? `yarn test ReactElement` --- .../react/src/__tests__/ReactElement-test.js | 46 ++++++++++++------- 1 file changed, 29 insertions(+), 17 deletions(-) diff --git a/packages/react/src/__tests__/ReactElement-test.js b/packages/react/src/__tests__/ReactElement-test.js index a7ff7d9747374..05aab3c326db7 100644 --- a/packages/react/src/__tests__/ReactElement-test.js +++ b/packages/react/src/__tests__/ReactElement-test.js @@ -13,7 +13,6 @@ let act; let React; let ReactDOMClient; -let ReactTestUtils; describe('ReactElement', () => { let ComponentClass; @@ -25,7 +24,6 @@ describe('ReactElement', () => { React = require('react'); ReactDOMClient = require('react-dom/client'); - ReactTestUtils = require('react-dom/test-utils'); // NOTE: We're explicitly not using JSX here. This is intended to test // classic JS without JSX. ComponentClass = class extends React.Component { @@ -223,19 +221,21 @@ describe('ReactElement', () => { expect(element.props).toEqual({foo: '56'}); }); - it('preserves the owner on the element', () => { + it('preserves the owner on the element', async () => { let element; + let instance; class Wrapper extends React.Component { + componentDidMount() { + instance = this; + } render() { element = React.createElement(ComponentClass); return element; } } - - const instance = ReactTestUtils.renderIntoDocument( - React.createElement(Wrapper), - ); + const root = ReactDOMClient.createRoot(document.createElement('div')); + await act(() => root.render(React.createElement(Wrapper))); expect(element._owner.stateNode).toBe(instance); }); @@ -327,23 +327,28 @@ describe('ReactElement', () => { // NOTE: We're explicitly not using JSX here. This is intended to test // classic JS without JSX. - it('should normalize props with default values', () => { + it('should normalize props with default values', async () => { + let instance; class Component extends React.Component { + componentDidMount() { + instance = this; + } render() { return React.createElement('span', null, this.props.prop); } } Component.defaultProps = {prop: 'testKey'}; - const instance = ReactTestUtils.renderIntoDocument( - React.createElement(Component), - ); + const root = ReactDOMClient.createRoot(document.createElement('div')); + await act(() => { + root.render(React.createElement(Component)); + }); expect(instance.props.prop).toBe('testKey'); - const inst2 = ReactTestUtils.renderIntoDocument( - React.createElement(Component, {prop: null}), - ); - expect(inst2.props.prop).toBe(null); + await act(() => { + root.render(React.createElement(Component, {prop: null})); + }); + expect(instance.props.prop).toBe(null); }); it('throws when changing a prop (in dev) after element creation', async () => { @@ -410,13 +415,20 @@ describe('ReactElement', () => { } }); - it('does not warn for NaN props', () => { + it('does not warn for NaN props', async () => { + let test; class Test extends React.Component { + componentDidMount() { + test = this; + } render() { return
; } } - const test = ReactTestUtils.renderIntoDocument(); + const root = ReactDOMClient.createRoot(document.createElement('div')); + await act(() => { + root.render(); + }); expect(test.props.value).toBeNaN(); }); });