Skip to content

Memory Leak When Using Synchronous Loading With Async Components #9229

Closed
@adrienbaron

Description

@adrienbaron

Version

2.5.21

Reproduction link

https://codesandbox.io/s/xlly27wy8z

Steps to reproduce

Same as: #8740

  • Load the reproduction link in Chrome
  • Open Chrome Dev Tools
  • Go to the memory tab
  • Click on the "Destroy" button
  • Take a "Heap Snapshot"
  • Filter to look for "Detached HTMLDivElement"
  • You should see 2 leaking HTMLDivElement

What is expected?

Context for loading the Async component should be cleared.

What is actually happening?

There are 2 components still attached to a context of an Async loading Component.
It is not cleared if the Async component is loaded synchronously.


This is the same issue as #8740. However the fix for it only fixes the case when loading is actually async. Synchronous async loading does not call the "forceRender" (2e472c5#diff-293f31f6a318619ad803b971ef0724a3R64) so the contexts array is not cleared.
I can try to fix it and submit a PR if needed.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions