From 9e947d11ddf4af7a5980b954e1f6d751e01ecf24 Mon Sep 17 00:00:00 2001 From: Andrew Clark Date: Thu, 8 Nov 2018 11:00:08 -0800 Subject: [PATCH] [Synchronous Suspense] Don't delete children of suspended component Vestigial behavior that should have been removed in #13823. Found using the Suspense fuzz tester in #14147. --- .../react-reconciler/src/ReactFiberUnwindWork.js | 12 +----------- .../ReactSuspenseWithNoopRenderer-test.internal.js | 3 +++ 2 files changed, 4 insertions(+), 11 deletions(-) diff --git a/packages/react-reconciler/src/ReactFiberUnwindWork.js b/packages/react-reconciler/src/ReactFiberUnwindWork.js index 6fb2e080687e5..a27bae884aa21 100644 --- a/packages/react-reconciler/src/ReactFiberUnwindWork.js +++ b/packages/react-reconciler/src/ReactFiberUnwindWork.js @@ -238,20 +238,10 @@ function throwException( if ((workInProgress.mode & ConcurrentMode) === NoEffect) { workInProgress.effectTag |= DidCapture; - // Unmount the source fiber's children - const nextChildren = null; - reconcileChildren( - sourceFiber.alternate, - sourceFiber, - nextChildren, - renderExpirationTime, - ); - sourceFiber.effectTag &= ~Incomplete; - // We're going to commit this fiber even though it didn't complete. // But we shouldn't call any lifecycle methods or callbacks. Remove // all lifecycle effect tags. - sourceFiber.effectTag &= ~LifecycleEffectMask; + sourceFiber.effectTag &= ~(LifecycleEffectMask | Incomplete); if (sourceFiber.tag === ClassComponent) { const current = sourceFiber.alternate; diff --git a/packages/react-reconciler/src/__tests__/ReactSuspenseWithNoopRenderer-test.internal.js b/packages/react-reconciler/src/__tests__/ReactSuspenseWithNoopRenderer-test.internal.js index de4b75337ef3f..9580c425a47b0 100644 --- a/packages/react-reconciler/src/__tests__/ReactSuspenseWithNoopRenderer-test.internal.js +++ b/packages/react-reconciler/src/__tests__/ReactSuspenseWithNoopRenderer-test.internal.js @@ -937,6 +937,7 @@ describe('ReactSuspenseWithNoopRenderer', () => { ]); expect(ReactNoop.getChildrenAsJSX()).toEqual( +