Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Test: JS Heap Snapshots viewer #199239

Closed
2 tasks done
connor4312 opened this issue Nov 27, 2023 · 3 comments
Closed
2 tasks done

Test: JS Heap Snapshots viewer #199239

connor4312 opened this issue Nov 27, 2023 · 3 comments

Comments

@connor4312
Copy link
Member

connor4312 commented Nov 27, 2023

Refs: #191920

Complexity: 3

Create Issue


This month I added a custom editor to allow viewing JavaScript heap snapshots.

  1. Debug any JavaScript, and run Take Performance Profile > Heap Snapshot. That will collect a .heapsnapshot file into your workspace folder. (Doing this in browsers is fairly fast, but Node is slow and can take several moments)
  2. Open the file. Poke around the table view and check that things are sane and work as they should. The numbers should match the same file opened in the Memory tab in Chrome (not Edge, Edge tweaks Chrome's calculation)
  3. Click on the "graph" button beside a node and see that it opens a graph of its retaininers. You will be prompted to install the flame chart visualizer if not installed, as it contains the heavier-weight graphing components.
  4. Check that graph navigation is sane and works well. You can change the distance of displayed retaininers, but be warned that high numbers may take increasing amounts of time to chart, especially for Node.js profiles.
@aiday-mar
Copy link
Contributor

aiday-mar commented Nov 28, 2023

Loving the graphing functionality :)

@connor4312
Copy link
Member Author

Thank you for the thorough testing :)

@IanButterworth
Copy link

The julia language Profile stdlib provides a way to record .heapsnapshot files that can be viewed in chrome devtools, but they hang indefinitely in this viewer and print the following error

2023-12-30 19:27:38.621 [info] ExtensionService#_doActivateExtension ms-vscode.vscode-js-profile-table, startup: false, activationEvent: 'onCustomEditor:jsProfileVisualizer.heapsnapshot.table'
2023-12-30 19:27:38.772 [error] UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "invalid profile JSON".

Is there any way to get any further debug information?

Here is a zipped example 81416_881767189633791.heapsnapshot.zip

I thought I wouldn't open a dedicated issue until we can rule out the issue being on the julia side

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

4 participants