From b8f91e6649ccbd9e3bcb6b5907bb20e411ee2074 Mon Sep 17 00:00:00 2001 From: Sunil Pai Date: Wed, 3 Jul 2019 03:04:22 +0100 Subject: [PATCH] [fail] reset IsThisRendererActing correctly (#16042) * [fail] reset IsThisRendererActing correctly I missed this in https://github.com/facebook/react/pull/16039. I'd pointed at the wrong previous state, corrupting it in further use. This PR fixes that, and adds a test to make sure it doesn't happen again. * warn for unacted effects only in strict mode --- fixtures/dom/src/index.test.js | 15 +++++++++++++++ .../react-dom/src/test-utils/ReactTestUtilsAct.js | 2 +- .../react-noop-renderer/src/createReactNoop.js | 2 +- .../react-reconciler/src/ReactFiberWorkLoop.js | 5 +---- .../src/ReactTestRendererAct.js | 2 +- 5 files changed, 19 insertions(+), 7 deletions(-) diff --git a/fixtures/dom/src/index.test.js b/fixtures/dom/src/index.test.js index fe3ec883fa909..365afe5752ab4 100644 --- a/fixtures/dom/src/index.test.js +++ b/fixtures/dom/src/index.test.js @@ -37,6 +37,21 @@ it("doesn't warn when you use the right act + renderer: test", () => { }); }); +it('resets correctly across renderers', () => { + function Effecty() { + React.useEffect(() => {}, []); + return null; + } + TestUtils.act(() => { + TestRenderer.act(() => {}); + expect(() => { + TestRenderer.create(); + }).toWarnDev(["It looks like you're using the wrong act()"], { + withoutStack: true, + }); + }); +}); + it('warns when using createRoot() + .render', () => { const root = ReactDOM.unstable_createRoot(document.createElement('div')); expect(() => { diff --git a/packages/react-dom/src/test-utils/ReactTestUtilsAct.js b/packages/react-dom/src/test-utils/ReactTestUtilsAct.js index 791d4878c13d7..b0775cc3bce05 100644 --- a/packages/react-dom/src/test-utils/ReactTestUtilsAct.js +++ b/packages/react-dom/src/test-utils/ReactTestUtilsAct.js @@ -91,7 +91,7 @@ function act(callback: () => Thenable) { actingUpdatesScopeDepth++; if (__DEV__) { previousIsSomeRendererActing = IsSomeRendererActing.current; - previousIsThisRendererActing = IsSomeRendererActing.current; + previousIsThisRendererActing = IsThisRendererActing.current; IsSomeRendererActing.current = true; IsThisRendererActing.current = true; } diff --git a/packages/react-noop-renderer/src/createReactNoop.js b/packages/react-noop-renderer/src/createReactNoop.js index 4dcae01cbc076..5033283025e2c 100644 --- a/packages/react-noop-renderer/src/createReactNoop.js +++ b/packages/react-noop-renderer/src/createReactNoop.js @@ -620,7 +620,7 @@ function createReactNoop(reconciler: Function, useMutation: boolean) { actingUpdatesScopeDepth++; if (__DEV__) { previousIsSomeRendererActing = IsSomeRendererActing.current; - previousIsThisRendererActing = IsSomeRendererActing.current; + previousIsThisRendererActing = IsThisRendererActing.current; IsSomeRendererActing.current = true; IsThisRendererActing.current = true; } diff --git a/packages/react-reconciler/src/ReactFiberWorkLoop.js b/packages/react-reconciler/src/ReactFiberWorkLoop.js index bdd43849c3042..7efa1bd243565 100644 --- a/packages/react-reconciler/src/ReactFiberWorkLoop.js +++ b/packages/react-reconciler/src/ReactFiberWorkLoop.js @@ -2454,10 +2454,7 @@ export function warnIfNotCurrentlyActingEffectsInDEV(fiber: Fiber): void { if (__DEV__) { if ( warnsIfNotActing === true && - (fiber.mode & StrictMode || - fiber.mode & ProfileMode || - fiber.mode & BatchedMode || - fiber.mode & ConcurrentMode) && + (fiber.mode & StrictMode) !== NoMode && IsSomeRendererActing.current === false && IsThisRendererActing.current === false ) { diff --git a/packages/react-test-renderer/src/ReactTestRendererAct.js b/packages/react-test-renderer/src/ReactTestRendererAct.js index 63aa64251b37b..de6a76a06c155 100644 --- a/packages/react-test-renderer/src/ReactTestRendererAct.js +++ b/packages/react-test-renderer/src/ReactTestRendererAct.js @@ -72,7 +72,7 @@ function act(callback: () => Thenable) { actingUpdatesScopeDepth++; if (__DEV__) { previousIsSomeRendererActing = IsSomeRendererActing.current; - previousIsThisRendererActing = IsSomeRendererActing.current; + previousIsThisRendererActing = IsThisRendererActing.current; IsSomeRendererActing.current = true; IsThisRendererActing.current = true; }