diff --git a/packages/react-native-renderer/src/ReactFabricHostConfig.js b/packages/react-native-renderer/src/ReactFabricHostConfig.js index c71a9050211cf..8ca9401597ddb 100644 --- a/packages/react-native-renderer/src/ReactFabricHostConfig.js +++ b/packages/react-native-renderer/src/ReactFabricHostConfig.js @@ -22,6 +22,8 @@ import type { import {mountSafeCallback_NOT_REALLY_SAFE} from './NativeMethodsMixinUtils'; import {create, diff} from './ReactNativeAttributePayload'; +import invariant from 'shared/invariant'; + import {dispatchEvent} from './ReactFabricEventEmitter'; import { @@ -262,11 +264,10 @@ export function createTextInstance( hostContext: HostContext, internalInstanceHandle: Object, ): TextInstance { - if (__DEV__) { - if (!hostContext.isInAParentText) { - console.error('Text strings must be rendered within a component.'); - } - } + invariant( + hostContext.isInAParentText, + 'Text strings must be rendered within a component.', + ); const tag = nextReactTag; nextReactTag += 2; diff --git a/packages/react-native-renderer/src/ReactNativeHostConfig.js b/packages/react-native-renderer/src/ReactNativeHostConfig.js index 63337a04df1af..205f8189b7a7c 100644 --- a/packages/react-native-renderer/src/ReactNativeHostConfig.js +++ b/packages/react-native-renderer/src/ReactNativeHostConfig.js @@ -147,11 +147,11 @@ export function createTextInstance( hostContext: HostContext, internalInstanceHandle: Object, ): TextInstance { - if (__DEV__) { - if (!hostContext.isInAParentText) { - console.error('Text strings must be rendered within a component.'); - } - } + invariant( + hostContext.isInAParentText, + 'Text strings must be rendered within a component.', + ); + const tag = allocateTag(); UIManager.createView( diff --git a/packages/react-native-renderer/src/__tests__/ReactFabric-test.internal.js b/packages/react-native-renderer/src/__tests__/ReactFabric-test.internal.js index 9f2851382af43..c7e4e3dee1b51 100644 --- a/packages/react-native-renderer/src/__tests__/ReactFabric-test.internal.js +++ b/packages/react-native-renderer/src/__tests__/ReactFabric-test.internal.js @@ -524,7 +524,7 @@ describe('ReactFabric', () => { }); }); - it('should console error for text not inside of a ancestor', () => { + it('should throw for text not inside of a ancestor', () => { const ScrollView = createReactNativeComponentClass('RCTScrollView', () => ({ validAttributes: {}, uiViewClassName: 'RCTScrollView', @@ -542,7 +542,7 @@ describe('ReactFabric', () => { act(() => { ReactFabric.render(this should warn, 11); }); - }).toErrorDev(['Text strings must be rendered within a component.']); + }).toThrow('Text strings must be rendered within a component.'); expect(() => { act(() => { @@ -553,7 +553,7 @@ describe('ReactFabric', () => { 11, ); }); - }).toErrorDev(['Text strings must be rendered within a component.']); + }).toThrow('Text strings must be rendered within a component.'); }); it('should not throw for text inside of an indirect ancestor', () => { diff --git a/packages/react-native-renderer/src/__tests__/ReactNativeMount-test.internal.js b/packages/react-native-renderer/src/__tests__/ReactNativeMount-test.internal.js index 4d1ffce09fe35..9026bef793767 100644 --- a/packages/react-native-renderer/src/__tests__/ReactNativeMount-test.internal.js +++ b/packages/react-native-renderer/src/__tests__/ReactNativeMount-test.internal.js @@ -473,7 +473,7 @@ describe('ReactNative', () => { ); }); - it('should console error for text not inside of a ancestor', () => { + it('should throw for text not inside of a ancestor', () => { const ScrollView = createReactNativeComponentClass('RCTScrollView', () => ({ validAttributes: {}, uiViewClassName: 'RCTScrollView', @@ -487,9 +487,9 @@ describe('ReactNative', () => { uiViewClassName: 'RCTView', })); - expect(() => - ReactNative.render(this should warn, 11), - ).toErrorDev(['Text strings must be rendered within a component.']); + expect(() => ReactNative.render(this should warn, 11)).toThrow( + 'Text strings must be rendered within a component.', + ); expect(() => ReactNative.render( @@ -498,7 +498,7 @@ describe('ReactNative', () => { , 11, ), - ).toErrorDev(['Text strings must be rendered within a component.']); + ).toThrow('Text strings must be rendered within a component.'); }); it('should not throw for text inside of an indirect ancestor', () => {