Skip to content

test: stabilize flaky Playwright tests#10817

Draft
DrJKL wants to merge 4 commits intomainfrom
drjkl/test/the-active-ingredient-is-selenium
Draft

test: stabilize flaky Playwright tests#10817
DrJKL wants to merge 4 commits intomainfrom
drjkl/test/the-active-ingredient-is-selenium

Conversation

@DrJKL
Copy link
Copy Markdown
Contributor

@DrJKL DrJKL commented Apr 2, 2026

Stabilize flaky Playwright tests by improving test reliability.

This PR aims to identify and fix flaky e2e tests.

┆Issue is synchronized with this Notion page by Unito

@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 2, 2026

🎨 Storybook: ✅ Built — View Storybook

Details

⏰ Completed at: 04/02/2026, 04:40:26 AM UTC

Links

@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 2, 2026

📦 Bundle: 5.11 MB gzip 🟢 -174 B

Details

Summary

  • Raw size: 23.5 MB baseline 23.5 MB — ⚪ 0 B
  • Gzip: 5.11 MB baseline 5.11 MB — 🟢 -174 B
  • Brotli: 3.95 MB baseline 3.95 MB — 🟢 -45 B
  • Bundles: 250 current • 250 baseline • 114 added / 114 removed

Category Glance
Vendor & Third-Party ⚪ 0 B (9.8 MB) · Other ⚪ 0 B (8.44 MB) · Data & Services ⚪ 0 B (2.97 MB) · Graph Workspace ⚪ 0 B (1.2 MB) · Panels & Settings ⚪ 0 B (484 kB) · Utilities & Hooks ⚪ 0 B (338 kB) · + 5 more

App Entry Points — 22.3 kB (baseline 22.3 kB) • ⚪ 0 B

Main entry bundles and manifests

File Before After Δ Raw Δ Gzip Δ Brotli
assets/index-BZS2_1T_.js (removed) 22.3 kB 🟢 -22.3 kB 🟢 -7.95 kB 🟢 -6.79 kB
assets/index-CMHRpcd_.js (new) 22.3 kB 🔴 +22.3 kB 🔴 +7.95 kB 🔴 +6.83 kB

Status: 1 added / 1 removed

Graph Workspace — 1.2 MB (baseline 1.2 MB) • ⚪ 0 B

Graph editor runtime, canvas, workflow orchestration

File Before After Δ Raw Δ Gzip Δ Brotli
assets/GraphView-bI5cAbkw.js (new) 1.2 MB 🔴 +1.2 MB 🔴 +256 kB 🔴 +193 kB
assets/GraphView-C_a5WZax.js (removed) 1.2 MB 🟢 -1.2 MB 🟢 -256 kB 🟢 -193 kB

Status: 1 added / 1 removed

Views & Navigation — 76.6 kB (baseline 76.6 kB) • ⚪ 0 B

Top-level views, pages, and routed surfaces

File Before After Δ Raw Δ Gzip Δ Brotli
assets/CloudSurveyView-C7Xr5uQb.js (removed) 15.7 kB 🟢 -15.7 kB 🟢 -3.4 kB 🟢 -2.9 kB
assets/CloudSurveyView-Dx7xIiL2.js (new) 15.7 kB 🔴 +15.7 kB 🔴 +3.4 kB 🔴 +2.9 kB
assets/CloudLoginView-2KNjWN71.js (new) 12 kB 🔴 +12 kB 🔴 +3.36 kB 🔴 +2.97 kB
assets/CloudLoginView-Cu2uaLFN.js (removed) 12 kB 🟢 -12 kB 🟢 -3.36 kB 🟢 -2.96 kB
assets/CloudSignupView-Cg1NGub1.js (removed) 9.78 kB 🟢 -9.78 kB 🟢 -2.85 kB 🟢 -2.5 kB
assets/CloudSignupView-mbFC_eZ6.js (new) 9.78 kB 🔴 +9.78 kB 🔴 +2.85 kB 🔴 +2.51 kB
assets/UserCheckView-C0nHPOJH.js (removed) 9.04 kB 🟢 -9.04 kB 🟢 -2.33 kB 🟢 -2.03 kB
assets/UserCheckView-DrbDz7f7.js (new) 9.04 kB 🔴 +9.04 kB 🔴 +2.33 kB 🔴 +2.03 kB
assets/CloudLayoutView-CwvCD7Dr.js (new) 7.54 kB 🔴 +7.54 kB 🔴 +2.35 kB 🔴 +2.04 kB
assets/CloudLayoutView-YtKOkN9X.js (removed) 7.54 kB 🟢 -7.54 kB 🟢 -2.36 kB 🟢 -2.05 kB
assets/CloudForgotPasswordView-Bzfv0-0A.js (new) 5.94 kB 🔴 +5.94 kB 🔴 +2.09 kB 🔴 +1.85 kB
assets/CloudForgotPasswordView-DbGlaD65.js (removed) 5.94 kB 🟢 -5.94 kB 🟢 -2.09 kB 🟢 -1.87 kB
assets/CloudAuthTimeoutView-ChhQ4KDP.js (removed) 5.31 kB 🟢 -5.31 kB 🟢 -1.93 kB 🟢 -1.69 kB
assets/CloudAuthTimeoutView-pCq3HYuK.js (new) 5.31 kB 🔴 +5.31 kB 🔴 +1.93 kB 🔴 +1.69 kB
assets/CloudSubscriptionRedirectView-CGxgzBlr.js (new) 5.08 kB 🔴 +5.08 kB 🔴 +1.91 kB 🔴 +1.69 kB
assets/CloudSubscriptionRedirectView-DQ2oJagK.js (removed) 5.08 kB 🟢 -5.08 kB 🟢 -1.91 kB 🟢 -1.69 kB
assets/UserSelectView-352uOvsg.js (new) 4.71 kB 🔴 +4.71 kB 🔴 +1.74 kB 🔴 +1.54 kB
assets/UserSelectView-CM3XU9bu.js (removed) 4.71 kB 🟢 -4.71 kB 🟢 -1.74 kB 🟢 -1.55 kB

Status: 9 added / 9 removed / 2 unchanged

Panels & Settings — 484 kB (baseline 484 kB) • ⚪ 0 B

Configuration panels, inspectors, and settings screens

File Before After Δ Raw Δ Gzip Δ Brotli
assets/KeybindingPanel-DokKYJCj.js (new) 46.6 kB 🔴 +46.6 kB 🔴 +9.52 kB 🔴 +8.46 kB
assets/KeybindingPanel-eyDufHNb.js (removed) 46.6 kB 🟢 -46.6 kB 🟢 -9.52 kB 🟢 -8.47 kB
assets/SecretsPanel-B07a0SuX.js (new) 22.4 kB 🔴 +22.4 kB 🔴 +5.43 kB 🔴 +4.78 kB
assets/SecretsPanel-BTdXN5QH.js (removed) 22.4 kB 🟢 -22.4 kB 🟢 -5.43 kB 🟢 -4.77 kB
assets/LegacyCreditsPanel-BXku284O.js (new) 21.5 kB 🔴 +21.5 kB 🔴 +5.81 kB 🔴 +5.14 kB
assets/LegacyCreditsPanel-Cx7X8Ugl.js (removed) 21.5 kB 🟢 -21.5 kB 🟢 -5.81 kB 🟢 -5.13 kB
assets/SubscriptionPanel-4wX47fIO.js (new) 19.7 kB 🔴 +19.7 kB 🔴 +5.01 kB 🔴 +4.41 kB
assets/SubscriptionPanel-k8153Ye7.js (removed) 19.7 kB 🟢 -19.7 kB 🟢 -5.01 kB 🟢 -4.41 kB
assets/AboutPanel-CIsBSAy0.js (new) 12 kB 🔴 +12 kB 🔴 +3.33 kB 🔴 +2.98 kB
assets/AboutPanel-D2sQvHna.js (removed) 12 kB 🟢 -12 kB 🟢 -3.33 kB 🟢 -2.98 kB
assets/ExtensionPanel-3He-wyM1.js (removed) 9.78 kB 🟢 -9.78 kB 🟢 -2.82 kB 🟢 -2.51 kB
assets/ExtensionPanel-Ce5mirXN.js (new) 9.78 kB 🔴 +9.78 kB 🔴 +2.82 kB 🔴 +2.51 kB
assets/ServerConfigPanel-cHV1Rvj4.js (new) 6.85 kB 🔴 +6.85 kB 🔴 +2.27 kB 🔴 +2.03 kB
assets/ServerConfigPanel-CXPxxrBH.js (removed) 6.85 kB 🟢 -6.85 kB 🟢 -2.27 kB 🟢 -2.03 kB
assets/UserPanel-D9PjKgPR.js (new) 6.56 kB 🔴 +6.56 kB 🔴 +2.15 kB 🔴 +1.88 kB
assets/UserPanel-Dk0bULKO.js (removed) 6.56 kB 🟢 -6.56 kB 🟢 -2.15 kB 🟢 -1.88 kB
assets/cloudRemoteConfig-C4ToNorZ.js (removed) 1.85 kB 🟢 -1.85 kB 🟢 -901 B 🟢 -791 B
assets/cloudRemoteConfig-C80E_ykq.js (new) 1.85 kB 🔴 +1.85 kB 🔴 +900 B 🔴 +777 B
assets/refreshRemoteConfig-C3eKsC_H.js (new) 1.45 kB 🔴 +1.45 kB 🔴 +647 B 🔴 +554 B
assets/refreshRemoteConfig-eHXPUPHU.js (removed) 1.45 kB 🟢 -1.45 kB 🟢 -647 B 🟢 -546 B

Status: 10 added / 10 removed / 12 unchanged

User & Accounts — 17.1 kB (baseline 17.1 kB) • ⚪ 0 B

Authentication, profile, and account management bundles

File Before After Δ Raw Δ Gzip Δ Brotli
assets/auth-A_tZp1__.js (new) 3.57 kB 🔴 +3.57 kB 🔴 +1.26 kB 🔴 +1.07 kB
assets/auth-GWqgT04T.js (removed) 3.57 kB 🟢 -3.57 kB 🟢 -1.26 kB 🟢 -1.07 kB
assets/SignUpForm-CLtpQ9vB.js (removed) 3.16 kB 🟢 -3.16 kB 🟢 -1.29 kB 🟢 -1.14 kB
assets/SignUpForm-ojwrDcQ8.js (new) 3.16 kB 🔴 +3.16 kB 🔴 +1.29 kB 🔴 +1.14 kB
assets/UpdatePasswordContent-1DTDtQuA.js (new) 2.66 kB 🔴 +2.66 kB 🔴 +1.19 kB 🔴 +1.06 kB
assets/UpdatePasswordContent-BF_WeHlL.js (removed) 2.66 kB 🟢 -2.66 kB 🟢 -1.19 kB 🟢 -1.05 kB
assets/authStore-Dt3w8-RF.js (removed) 989 B 🟢 -989 B 🟢 -484 B 🟢 -433 B
assets/authStore-SYqVHmwu.js (new) 989 B 🔴 +989 B 🔴 +481 B 🔴 +434 B
assets/auth-BmWkLNAX.js (removed) 348 B 🟢 -348 B 🟢 -218 B 🟢 -192 B
assets/auth-BTZdKXCX.js (new) 348 B 🔴 +348 B 🔴 +216 B 🔴 +195 B

Status: 5 added / 5 removed / 2 unchanged

Editors & Dialogs — 109 kB (baseline 109 kB) • ⚪ 0 B

Modals, dialogs, drawers, and in-app editors

File Before After Δ Raw Δ Gzip Δ Brotli
assets/useShareDialog-3lM1zS1z.js (removed) 108 kB 🟢 -108 kB 🟢 -22.4 kB 🟢 -18.9 kB
assets/useShareDialog-D4PegEjf.js (new) 108 kB 🔴 +108 kB 🔴 +22.4 kB 🔴 +18.9 kB
assets/useSubscriptionDialog-CK5_fqoP.js (new) 969 B 🔴 +969 B 🔴 +472 B 🔴 +416 B
assets/useSubscriptionDialog-DvAjUHeh.js (removed) 969 B 🟢 -969 B 🟢 -476 B 🟢 -416 B

Status: 2 added / 2 removed

UI Components — 60.3 kB (baseline 60.3 kB) • ⚪ 0 B

Reusable component library chunks

File Before After Δ Raw Δ Gzip Δ Brotli
assets/ComfyQueueButton-BkNMbIfW.js (new) 13.5 kB 🔴 +13.5 kB 🔴 +3.79 kB 🔴 +3.37 kB
assets/ComfyQueueButton-DnT41h4y.js (removed) 13.5 kB 🟢 -13.5 kB 🟢 -3.79 kB 🟢 -3.38 kB
assets/useTerminalTabs-BW8CGnIa.js (removed) 10.7 kB 🟢 -10.7 kB 🟢 -3.6 kB 🟢 -3.17 kB
assets/useTerminalTabs-DFEhefGn.js (new) 10.7 kB 🔴 +10.7 kB 🔴 +3.6 kB 🔴 +3.17 kB
assets/SubscribeButton-_lUPJoSy.js (removed) 2.42 kB 🟢 -2.42 kB 🟢 -1.04 kB 🟢 -914 B
assets/SubscribeButton-B22gspbQ.js (new) 2.42 kB 🔴 +2.42 kB 🔴 +1.04 kB 🔴 +915 B
assets/cloudFeedbackTopbarButton-C-XPHAZs.js (removed) 1.66 kB 🟢 -1.66 kB 🟢 -842 B 🟢 -748 B
assets/cloudFeedbackTopbarButton-Ddh0MkVW.js (new) 1.66 kB 🔴 +1.66 kB 🔴 +840 B 🔴 +751 B
assets/ComfyQueueButton-CQhrKSzu.js (removed) 1.03 kB 🟢 -1.03 kB 🟢 -490 B 🟢 -436 B
assets/ComfyQueueButton-eajZrAn7.js (new) 1.03 kB 🔴 +1.03 kB 🔴 +486 B 🔴 +441 B

Status: 5 added / 5 removed / 8 unchanged

Data & Services — 2.97 MB (baseline 2.97 MB) • ⚪ 0 B

Stores, services, APIs, and repositories

File Before After Δ Raw Δ Gzip Δ Brotli
assets/dialogService-AjVAkfXG.js (removed) 1.94 MB 🟢 -1.94 MB 🟢 -445 kB 🟢 -338 kB
assets/dialogService-Bhe31R-S.js (new) 1.94 MB 🔴 +1.94 MB 🔴 +445 kB 🔴 +338 kB
assets/api-c0t4JQdU.js (removed) 885 kB 🟢 -885 kB 🟢 -211 kB 🟢 -167 kB
assets/api-xMroLaCA.js (new) 885 kB 🔴 +885 kB 🔴 +211 kB 🔴 +167 kB
assets/load3dService-CrlQdqyx.js (removed) 92.5 kB 🟢 -92.5 kB 🟢 -19.7 kB 🟢 -16.9 kB
assets/load3dService-DoXh8iYE.js (new) 92.5 kB 🔴 +92.5 kB 🔴 +19.7 kB 🔴 +16.9 kB
assets/workflowShareService-C4yDSmQb.js (removed) 16.6 kB 🟢 -16.6 kB 🟢 -4.88 kB 🟢 -4.32 kB
assets/workflowShareService-etuNrIiA.js (new) 16.6 kB 🔴 +16.6 kB 🔴 +4.88 kB 🔴 +4.33 kB
assets/keybindingService-B-31PR71.js (new) 13.8 kB 🔴 +13.8 kB 🔴 +3.67 kB 🔴 +3.22 kB
assets/keybindingService-Cj9g4aOb.js (removed) 13.8 kB 🟢 -13.8 kB 🟢 -3.67 kB 🟢 -3.22 kB
assets/releaseStore-C9ph3hhU.js (removed) 8.12 kB 🟢 -8.12 kB 🟢 -2.28 kB 🟢 -2 kB
assets/releaseStore-qruVqc2s.js (new) 8.12 kB 🔴 +8.12 kB 🔴 +2.28 kB 🔴 +2 kB
assets/userStore-BsixZlKT.js (removed) 2.24 kB 🟢 -2.24 kB 🟢 -867 B 🟢 -760 B
assets/userStore-D--Xmkky.js (new) 2.24 kB 🔴 +2.24 kB 🔴 +868 B 🔴 +767 B
assets/audioService-C3uEdD3D.js (removed) 1.8 kB 🟢 -1.8 kB 🟢 -877 B 🟢 -762 B
assets/audioService-DTSPM1ov.js (new) 1.8 kB 🔴 +1.8 kB 🔴 +874 B 🔴 +755 B
assets/releaseStore-55PLwz5J.js (new) 993 B 🔴 +993 B 🔴 +478 B 🔴 +429 B
assets/releaseStore-CITlbCFq.js (removed) 993 B 🟢 -993 B 🟢 -480 B 🟢 -427 B
assets/workflowDraftStore-BXLDz4m_.js (removed) 969 B 🟢 -969 B 🟢 -474 B 🟢 -424 B
assets/workflowDraftStore-C-B5sd32.js (new) 969 B 🔴 +969 B 🔴 +471 B 🔴 +423 B
assets/dialogService-BBk7BKDC.js (new) 958 B 🔴 +958 B 🔴 +464 B 🔴 +418 B
assets/dialogService-hDtzEvpe.js (removed) 958 B 🟢 -958 B 🟢 -467 B 🟢 -419 B
assets/settingStore-CI8l6Es6.js (new) 956 B 🔴 +956 B 🔴 +467 B 🔴 +415 B
assets/settingStore-Dwb_XVL9.js (removed) 956 B 🟢 -956 B 🟢 -471 B 🟢 -417 B
assets/assetsStore-9fZRwmZS.js (new) 955 B 🔴 +955 B 🔴 +467 B 🔴 +417 B
assets/assetsStore-CzJYVyR-.js (removed) 955 B 🟢 -955 B 🟢 -471 B 🟢 -420 B

Status: 13 added / 13 removed / 4 unchanged

Utilities & Hooks — 338 kB (baseline 338 kB) • ⚪ 0 B

Helpers, composables, and utility bundles

File Before After Δ Raw Δ Gzip Δ Brotli
assets/useConflictDetection-DAw5XwV-.js (removed) 232 kB 🟢 -232 kB 🟢 -51.3 kB 🟢 -41.8 kB
assets/useConflictDetection-vIyhllHV.js (new) 232 kB 🔴 +232 kB 🔴 +51.3 kB 🔴 +41.8 kB
assets/useLoad3dViewer-CDHz4km1.js (new) 18.7 kB 🔴 +18.7 kB 🔴 +4.43 kB 🔴 +3.88 kB
assets/useLoad3dViewer-ErwXqVaN.js (removed) 18.7 kB 🟢 -18.7 kB 🟢 -4.43 kB 🟢 -3.87 kB
assets/useLoad3d-CAzvyLYb.js (removed) 15 kB 🟢 -15 kB 🟢 -3.79 kB 🟢 -3.36 kB
assets/useLoad3d-CTv6QAil.js (new) 15 kB 🔴 +15 kB 🔴 +3.79 kB 🔴 +3.35 kB
assets/useFeatureFlags-C3q6q6rB.js (new) 5.78 kB 🔴 +5.78 kB 🔴 +1.75 kB 🔴 +1.48 kB
assets/useFeatureFlags-uG604frg.js (removed) 5.78 kB 🟢 -5.78 kB 🟢 -1.75 kB 🟢 -1.48 kB
assets/useCopyToClipboard-CD929RbG.js (new) 5.29 kB 🔴 +5.29 kB 🔴 +1.86 kB 🔴 +1.58 kB
assets/useCopyToClipboard-DPMxf62X.js (removed) 5.29 kB 🟢 -5.29 kB 🟢 -1.86 kB 🟢 -1.57 kB
assets/useWorkspaceUI-BBYoKasN.js (new) 3.34 kB 🔴 +3.34 kB 🔴 +980 B 🔴 +813 B
assets/useWorkspaceUI-Cvx-xzC6.js (removed) 3.34 kB 🟢 -3.34 kB 🟢 -982 B 🟢 -815 B
assets/subscriptionCheckoutUtil-BBJccxXM.js (new) 2.97 kB 🔴 +2.97 kB 🔴 +1.31 kB 🔴 +1.14 kB
assets/subscriptionCheckoutUtil-CeHIIhsy.js (removed) 2.97 kB 🟢 -2.97 kB 🟢 -1.31 kB 🟢 -1.14 kB
assets/assetPreviewUtil-C-JQYkHK.js (removed) 2.27 kB 🟢 -2.27 kB 🟢 -961 B 🟢 -838 B
assets/assetPreviewUtil-D6uCc9Oz.js (new) 2.27 kB 🔴 +2.27 kB 🔴 +957 B 🔴 +834 B
assets/useUpstreamValue-4HvUtqYS.js (new) 2.08 kB 🔴 +2.08 kB 🔴 +804 B 🔴 +720 B
assets/useUpstreamValue-BZI4FwvP.js (removed) 2.08 kB 🟢 -2.08 kB 🟢 -804 B 🟢 -715 B
assets/useLoad3d-Cb-_1cmQ.js (removed) 1.13 kB 🟢 -1.13 kB 🟢 -541 B 🟢 -481 B
assets/useLoad3d-CuiYA3Rg.js (new) 1.13 kB 🔴 +1.13 kB 🔴 +536 B 🔴 +483 B
assets/useLoad3dViewer-1-M-ZLu0.js (removed) 1.07 kB 🟢 -1.07 kB 🟢 -506 B 🟢 -454 B
assets/useLoad3dViewer-JaFS3j_J.js (new) 1.07 kB 🔴 +1.07 kB 🔴 +502 B 🔴 +453 B
assets/useCurrentUser-DnI4TEkr.js (new) 955 B 🔴 +955 B 🔴 +467 B 🔴 +417 B
assets/useCurrentUser-ZmxgJl9M.js (removed) 955 B 🟢 -955 B 🟢 -471 B 🟢 -417 B
assets/useWorkspaceSwitch-BWUC8wm_.js (removed) 747 B 🟢 -747 B 🟢 -388 B 🟢 -333 B
assets/useWorkspaceSwitch-GkFOYYEW.js (new) 747 B 🔴 +747 B 🔴 +386 B 🔴 +332 B

Status: 13 added / 13 removed / 13 unchanged

Vendor & Third-Party — 9.8 MB (baseline 9.8 MB) • ⚪ 0 B

External libraries and shared vendor chunks

Status: 16 unchanged

Other — 8.44 MB (baseline 8.44 MB) • ⚪ 0 B

Bundles that do not match a named category

File Before After Δ Raw Δ Gzip Δ Brotli
assets/core-C8TN-0Pv.js (removed) 76.8 kB 🟢 -76.8 kB 🟢 -19.9 kB 🟢 -16.9 kB
assets/core-DtsTgDZ_.js (new) 76.8 kB 🔴 +76.8 kB 🔴 +19.9 kB 🔴 +16.9 kB
assets/groupNode-CsUSzYC2.js (removed) 74 kB 🟢 -74 kB 🟢 -18.5 kB 🟢 -16.3 kB
assets/groupNode-D9Oo1_U5.js (new) 74 kB 🔴 +74 kB 🔴 +18.5 kB 🔴 +16.3 kB
assets/WidgetSelect-B1IaVYIg.js (new) 64.6 kB 🔴 +64.6 kB 🔴 +14.1 kB 🔴 +12.2 kB
assets/WidgetSelect-Bb0k3hSF.js (removed) 64.6 kB 🟢 -64.6 kB 🟢 -14.1 kB 🟢 -12.2 kB
assets/SubscriptionRequiredDialogContentWorkspace-CgHPkbhO.js (new) 48.9 kB 🔴 +48.9 kB 🔴 +9.29 kB 🔴 +7.97 kB
assets/SubscriptionRequiredDialogContentWorkspace-DgQ7Y0oP.js (removed) 48.9 kB 🟢 -48.9 kB 🟢 -9.29 kB 🟢 -7.95 kB
assets/WidgetPainter-BnFc-SRL.js (removed) 33.3 kB 🟢 -33.3 kB 🟢 -8.11 kB 🟢 -7.2 kB
assets/WidgetPainter-BPttR7yB.js (new) 33.3 kB 🔴 +33.3 kB 🔴 +8.11 kB 🔴 +7.19 kB
assets/Load3DControls-B2lm_PRG.js (new) 32.1 kB 🔴 +32.1 kB 🔴 +5.47 kB 🔴 +4.75 kB
assets/Load3DControls-CBSbu7hl.js (removed) 32.1 kB 🟢 -32.1 kB 🟢 -5.47 kB 🟢 -4.75 kB
assets/WorkspacePanelContent--8Bi-BIq.js (new) 29.9 kB 🔴 +29.9 kB 🔴 +6.32 kB 🔴 +5.55 kB
assets/WorkspacePanelContent-DQjc2bzh.js (removed) 29.9 kB 🟢 -29.9 kB 🟢 -6.32 kB 🟢 -5.55 kB
assets/SubscriptionRequiredDialogContent-Ck4xIwBd.js (removed) 28.2 kB 🟢 -28.2 kB 🟢 -7.16 kB 🟢 -6.3 kB
assets/SubscriptionRequiredDialogContent-iIPlvCrq.js (new) 28.2 kB 🔴 +28.2 kB 🔴 +7.17 kB 🔴 +6.3 kB
assets/Load3dViewerContent-CGtLI8QT.js (new) 24.5 kB 🔴 +24.5 kB 🔴 +5.33 kB 🔴 +4.65 kB
assets/Load3dViewerContent-DANsE9XS.js (removed) 24.5 kB 🟢 -24.5 kB 🟢 -5.33 kB 🟢 -4.64 kB
assets/WidgetImageCrop-C-3mCMn0.js (removed) 23.3 kB 🟢 -23.3 kB 🟢 -5.83 kB 🟢 -5.13 kB
assets/WidgetImageCrop-DWOxmPu1.js (new) 23.3 kB 🔴 +23.3 kB 🔴 +5.82 kB 🔴 +5.13 kB
assets/SubscriptionPanelContentWorkspace-0k8FlurV.js (new) 22.2 kB 🔴 +22.2 kB 🔴 +5.18 kB 🔴 +4.55 kB
assets/SubscriptionPanelContentWorkspace-CXpEjPbW.js (removed) 22.2 kB 🟢 -22.2 kB 🟢 -5.18 kB 🟢 -4.57 kB
assets/SignInContent-D0Zea-iR.js (new) 20.4 kB 🔴 +20.4 kB 🔴 +5.29 kB 🔴 +4.61 kB
assets/SignInContent-Dmyl4Wse.js (removed) 20.4 kB 🟢 -20.4 kB 🟢 -5.29 kB 🟢 -4.63 kB
assets/CurrentUserPopoverWorkspace-BHFPdh4b.js (removed) 20.4 kB 🟢 -20.4 kB 🟢 -4.83 kB 🟢 -4.32 kB
assets/CurrentUserPopoverWorkspace-DjLy4Ght.js (new) 20.4 kB 🔴 +20.4 kB 🔴 +4.83 kB 🔴 +4.33 kB
assets/WidgetInputNumber-BxSHKdIz.js (new) 19.1 kB 🔴 +19.1 kB 🔴 +4.84 kB 🔴 +4.29 kB
assets/WidgetInputNumber-CySFVyW8.js (removed) 19.1 kB 🟢 -19.1 kB 🟢 -4.84 kB 🟢 -4.3 kB
assets/WidgetRecordAudio-BWnMvHSE.js (new) 18.1 kB 🔴 +18.1 kB 🔴 +5.18 kB 🔴 +4.64 kB
assets/WidgetRecordAudio-DXA8Jmoq.js (removed) 18.1 kB 🟢 -18.1 kB 🟢 -5.18 kB 🟢 -4.64 kB
assets/Load3D-DrQ39Ub6.js (new) 16.9 kB 🔴 +16.9 kB 🔴 +4.12 kB 🔴 +3.59 kB
assets/Load3D-uq9yuomV.js (removed) 16.9 kB 🟢 -16.9 kB 🟢 -4.12 kB 🟢 -3.6 kB
assets/load3d-C9d_Teis.js (removed) 15 kB 🟢 -15 kB 🟢 -4.32 kB 🟢 -3.73 kB
assets/load3d-UU8JtafS.js (new) 15 kB 🔴 +15 kB 🔴 +4.31 kB 🔴 +3.74 kB
assets/WaveAudioPlayer-Bow-Lu3N.js (new) 13.4 kB 🔴 +13.4 kB 🔴 +3.69 kB 🔴 +3.22 kB
assets/WaveAudioPlayer-R3OFvCck.js (removed) 13.4 kB 🟢 -13.4 kB 🟢 -3.69 kB 🟢 -3.22 kB
assets/WidgetCurve-CmSDxj2S.js (removed) 12 kB 🟢 -12 kB 🟢 -3.85 kB 🟢 -3.48 kB
assets/WidgetCurve-Cxb3EP1I.js (new) 12 kB 🔴 +12 kB 🔴 +3.85 kB 🔴 +3.48 kB
assets/TeamWorkspacesDialogContent-B20msUAq.js (removed) 11.1 kB 🟢 -11.1 kB 🟢 -3.33 kB 🟢 -2.97 kB
assets/TeamWorkspacesDialogContent-DKThlBPt.js (new) 11.1 kB 🔴 +11.1 kB 🔴 +3.33 kB 🔴 +2.97 kB
assets/nodeTemplates-OI7UKvl2.js (new) 9.58 kB 🔴 +9.58 kB 🔴 +3.37 kB 🔴 +2.97 kB
assets/nodeTemplates-OsSwqofo.js (removed) 9.58 kB 🟢 -9.58 kB 🟢 -3.37 kB 🟢 -2.97 kB
assets/InviteMemberDialogContent-bCKtEhzt.js (removed) 7.77 kB 🟢 -7.77 kB 🟢 -2.45 kB 🟢 -2.15 kB
assets/InviteMemberDialogContent-nEaZ5D2w.js (new) 7.77 kB 🔴 +7.77 kB 🔴 +2.45 kB 🔴 +2.15 kB
assets/Load3DConfiguration-B0EaxCaQ.js (removed) 6.6 kB 🟢 -6.6 kB 🟢 -2.04 kB 🟢 -1.78 kB
assets/Load3DConfiguration-DaDvomxf.js (new) 6.6 kB 🔴 +6.6 kB 🔴 +2.04 kB 🔴 +1.78 kB
assets/onboardingCloudRoutes-B3GIVxoR.js (new) 6.53 kB 🔴 +6.53 kB 🔴 +2.04 kB 🔴 +1.77 kB
assets/onboardingCloudRoutes-BGL7dF4w.js (removed) 6.53 kB 🟢 -6.53 kB 🟢 -2.04 kB 🟢 -1.77 kB
assets/WidgetWithControl-6pGdAyhk.js (removed) 5.99 kB 🟢 -5.99 kB 🟢 -2.39 kB 🟢 -2.13 kB
assets/WidgetWithControl-C0hWNcvD.js (new) 5.99 kB 🔴 +5.99 kB 🔴 +2.38 kB 🔴 +2.11 kB
assets/CreateWorkspaceDialogContent-CfuZo6Ic.js (new) 5.95 kB 🔴 +5.95 kB 🔴 +2.15 kB 🔴 +1.89 kB
assets/CreateWorkspaceDialogContent-GOS6NgU7.js (removed) 5.95 kB 🟢 -5.95 kB 🟢 -2.15 kB 🟢 -1.87 kB
assets/FreeTierDialogContent-edsnllXJ.js (removed) 5.82 kB 🟢 -5.82 kB 🟢 -2.04 kB 🟢 -1.81 kB
assets/FreeTierDialogContent-Tp9aL_gP.js (new) 5.82 kB 🔴 +5.82 kB 🔴 +2.04 kB 🔴 +1.8 kB
assets/EditWorkspaceDialogContent-BKbH4by0.js (new) 5.75 kB 🔴 +5.75 kB 🔴 +2.11 kB 🔴 +1.84 kB
assets/EditWorkspaceDialogContent-DCnLIHPL.js (removed) 5.75 kB 🟢 -5.75 kB 🟢 -2.11 kB 🟢 -1.84 kB
assets/WidgetTextarea-BmDWGElw.js (removed) 5.53 kB 🟢 -5.53 kB 🟢 -2.17 kB 🟢 -1.93 kB
assets/WidgetTextarea-Ceb5Fw5F.js (new) 5.53 kB 🔴 +5.53 kB 🔴 +2.17 kB 🔴 +1.93 kB
assets/Preview3d-CPxEN9Gj.js (new) 5.36 kB 🔴 +5.36 kB 🔴 +1.79 kB 🔴 +1.56 kB
assets/Preview3d-Dlfz31wy.js (removed) 5.36 kB 🟢 -5.36 kB 🟢 -1.79 kB 🟢 -1.56 kB
assets/ValueControlPopover-BtiYhlNe.js (new) 5.33 kB 🔴 +5.33 kB 🔴 +1.92 kB 🔴 +1.72 kB
assets/ValueControlPopover-Q89YaBsJ.js (removed) 5.33 kB 🟢 -5.33 kB 🟢 -1.93 kB 🟢 -1.72 kB
assets/CancelSubscriptionDialogContent-CJAHjYl8.js (removed) 5.22 kB 🟢 -5.22 kB 🟢 -1.95 kB 🟢 -1.7 kB
assets/CancelSubscriptionDialogContent-CzUarjLF.js (new) 5.22 kB 🔴 +5.22 kB 🔴 +1.94 kB 🔴 +1.7 kB
assets/DeleteWorkspaceDialogContent-DGGISYqX.js (new) 4.65 kB 🔴 +4.65 kB 🔴 +1.79 kB 🔴 +1.55 kB
assets/DeleteWorkspaceDialogContent-k8agjupZ.js (removed) 4.65 kB 🟢 -4.65 kB 🟢 -1.79 kB 🟢 -1.55 kB
assets/LeaveWorkspaceDialogContent-BdEPA98C.js (removed) 4.48 kB 🟢 -4.48 kB 🟢 -1.73 kB 🟢 -1.5 kB
assets/LeaveWorkspaceDialogContent-D5SJdiYc.js (new) 4.48 kB 🔴 +4.48 kB 🔴 +1.73 kB 🔴 +1.5 kB
assets/RemoveMemberDialogContent-CSn0RoA3.js (removed) 4.46 kB 🟢 -4.46 kB 🟢 -1.69 kB 🟢 -1.47 kB
assets/RemoveMemberDialogContent-DcBYZScq.js (new) 4.46 kB 🔴 +4.46 kB 🔴 +1.69 kB 🔴 +1.47 kB
assets/tierBenefits-CuezNCnC.js (new) 4.45 kB 🔴 +4.45 kB 🔴 +1.58 kB 🔴 +1.37 kB
assets/tierBenefits-DxCK7Xcl.js (removed) 4.45 kB 🟢 -4.45 kB 🟢 -1.58 kB 🟢 -1.36 kB
assets/RevokeInviteDialogContent-B4t48lN6.js (new) 4.37 kB 🔴 +4.37 kB 🔴 +1.7 kB 🔴 +1.48 kB
assets/RevokeInviteDialogContent-DiW7AMSs.js (removed) 4.37 kB 🟢 -4.37 kB 🟢 -1.7 kB 🟢 -1.49 kB
assets/InviteMemberUpsellDialogContent-2ae6_HGL.js (new) 4.27 kB 🔴 +4.27 kB 🔴 +1.56 kB 🔴 +1.37 kB
assets/InviteMemberUpsellDialogContent-BdqoZO40.js (removed) 4.27 kB 🟢 -4.27 kB 🟢 -1.56 kB 🟢 -1.37 kB
assets/cloudSessionCookie-BPBB2vA4.js (removed) 4.12 kB 🟢 -4.12 kB 🟢 -1.49 kB 🟢 -1.31 kB
assets/cloudSessionCookie-C-c6THKy.js (new) 4.12 kB 🔴 +4.12 kB 🔴 +1.48 kB 🔴 +1.29 kB
assets/saveMesh-CHjJsiD4.js (new) 3.92 kB 🔴 +3.92 kB 🔴 +1.68 kB 🔴 +1.48 kB
assets/saveMesh-WZ6oiiid.js (removed) 3.92 kB 🟢 -3.92 kB 🟢 -1.68 kB 🟢 -1.48 kB
assets/Media3DTop-BijZBDXm.js (new) 3.85 kB 🔴 +3.85 kB 🔴 +1.62 kB 🔴 +1.43 kB
assets/Media3DTop-CzG6bjLU.js (removed) 3.85 kB 🟢 -3.85 kB 🟢 -1.62 kB 🟢 -1.43 kB
assets/GlobalToast-BypL53cG.js (removed) 3.05 kB 🟢 -3.05 kB 🟢 -1.26 kB 🟢 -1.07 kB
assets/GlobalToast-Cda9i4K1.js (new) 3.05 kB 🔴 +3.05 kB 🔴 +1.26 kB 🔴 +1.07 kB
assets/SubscribeToRun--nu3dtMZ.js (new) 2.13 kB 🔴 +2.13 kB 🔴 +981 B 🔴 +871 B
assets/SubscribeToRun-DnZdU5Jz.js (removed) 2.13 kB 🟢 -2.13 kB 🟢 -984 B 🟢 -881 B
assets/MediaAudioTop-CHIenYzS.js (new) 2.02 kB 🔴 +2.02 kB 🔴 +981 B 🔴 +838 B
assets/MediaAudioTop-tXl0obhc.js (removed) 2.02 kB 🟢 -2.02 kB 🟢 -982 B 🟢 -831 B
assets/CloudRunButtonWrapper-BRQ4xLZW.js (removed) 1.99 kB 🟢 -1.99 kB 🟢 -908 B 🟢 -802 B
assets/CloudRunButtonWrapper-YH3G4zv5.js (new) 1.99 kB 🔴 +1.99 kB 🔴 +907 B 🔴 +811 B
assets/graphHasMissingNodes-C807aSYM.js (new) 1.83 kB 🔴 +1.83 kB 🔴 +862 B 🔴 +754 B
assets/graphHasMissingNodes-DQejG0Qy.js (removed) 1.83 kB 🟢 -1.83 kB 🟢 -860 B 🟢 -753 B
assets/cloudBadges-Ba6b5IZ0.js (removed) 1.77 kB 🟢 -1.77 kB 🟢 -889 B 🟢 -775 B
assets/cloudBadges-BGoLqnB5.js (new) 1.77 kB 🔴 +1.77 kB 🔴 +889 B 🔴 +778 B
assets/cloudSubscription-CKojFkBT.js (new) 1.68 kB 🔴 +1.68 kB 🔴 +811 B 🔴 +708 B
assets/cloudSubscription-f6FYoWlw.js (removed) 1.68 kB 🟢 -1.68 kB 🟢 -812 B 🟢 -705 B
assets/previousFullPath-BVh0UJug.js (new) 1.53 kB 🔴 +1.53 kB 🔴 +695 B 🔴 +598 B
assets/previousFullPath-C5uurzR6.js (removed) 1.53 kB 🟢 -1.53 kB 🟢 -694 B 🟢 -607 B
assets/Load3D-DmwA-wwt.js (removed) 1.34 kB 🟢 -1.34 kB 🟢 -612 B 🟢 -546 B
assets/Load3D-lLc5tNHJ.js (new) 1.34 kB 🔴 +1.34 kB 🔴 +611 B 🔴 +543 B
assets/nightlyBadges-BgRZir_S.js (new) 1.29 kB 🔴 +1.29 kB 🔴 +654 B 🔴 +584 B
assets/nightlyBadges-ChiT474A.js (removed) 1.29 kB 🟢 -1.29 kB 🟢 -657 B 🟢 -579 B
assets/Load3dViewerContent-iM5MGFcB.js (new) 1.23 kB 🔴 +1.23 kB 🔴 +562 B 🔴 +499 B
assets/Load3dViewerContent-URjipvnh.js (removed) 1.23 kB 🟢 -1.23 kB 🟢 -565 B 🟢 -499 B
assets/SubscriptionPanelContentWorkspace-CnDYHj5q.js (removed) 1.15 kB 🟢 -1.15 kB 🟢 -535 B 🟢 -466 B
assets/SubscriptionPanelContentWorkspace-jyofSzVX.js (new) 1.15 kB 🔴 +1.15 kB 🔴 +531 B 🔴 +468 B
assets/WidgetLegacy-DF9UgzlM.js (removed) 978 B 🟢 -978 B 🟢 -481 B 🟢 -423 B
assets/WidgetLegacy-DYfa9t2m.js (new) 978 B 🔴 +978 B 🔴 +478 B 🔴 +423 B
assets/changeTracker-BBpTrdtT.js (removed) 952 B 🟢 -952 B 🟢 -471 B 🟢 -417 B
assets/changeTracker-D45Uxlip.js (new) 952 B 🔴 +952 B 🔴 +467 B 🔴 +414 B

Status: 55 added / 55 removed / 79 unchanged

⚡ Performance Report

canvas-idle: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 60.8 MB heap
canvas-mouse-sweep: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 56.4 MB heap
canvas-zoom-sweep: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 64.0 MB heap
dom-widget-clipping: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 46.9 MB heap
large-graph-idle: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 53.3 MB heap
large-graph-pan: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 66.2 MB heap
large-graph-zoom: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 61.5 MB heap
minimap-idle: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 54.2 MB heap
subgraph-dom-widget-clipping: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 47.1 MB heap
subgraph-idle: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 60.1 MB heap
subgraph-mouse-sweep: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 52.3 MB heap
viewport-pan-sweep: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 76.9 MB heap
vue-large-graph-idle: · 58.1 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 159.0 MB heap
vue-large-graph-pan: · 58.1 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 162.9 MB heap
workflow-execution: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 46.9 MB heap

⚠️ 2 regressions detected

Metric Baseline PR (median) Δ Sig
subgraph-mouse-sweep: style recalc duration 52ms 51ms -3% ⚠️ z=2.5
subgraph-mouse-sweep: task duration 1009ms 912ms -10% ⚠️ z=2.1
All metrics
Metric Baseline PR (median) Δ Sig
canvas-idle: avg frame time 17ms 17ms +0% z=-0.9
canvas-idle: p95 frame time 17ms 17ms +0%
canvas-idle: layout duration 0ms 0ms +0%
canvas-idle: style recalc duration 10ms 9ms -12% z=-2.3
canvas-idle: layout count 0 0 +0%
canvas-idle: style recalc count 10 9 -10% z=-3.8
canvas-idle: task duration 383ms 365ms -5% z=-1.0
canvas-idle: script duration 28ms 18ms -35% z=-3.2
canvas-idle: TBT 0ms 0ms +0%
canvas-idle: heap used 61.1 MB 60.8 MB -1%
canvas-idle: DOM nodes 20 18 -10% z=-3.6
canvas-idle: event listeners 6 6 +0% z=-1.2
canvas-mouse-sweep: avg frame time 17ms 17ms +0% z=-1.5
canvas-mouse-sweep: p95 frame time 17ms 17ms +0%
canvas-mouse-sweep: layout duration 4ms 4ms +3% z=0.9
canvas-mouse-sweep: style recalc duration 47ms 46ms -3% z=1.0
canvas-mouse-sweep: layout count 12 12 +0%
canvas-mouse-sweep: style recalc count 82 83 +1% z=1.8
canvas-mouse-sweep: task duration 997ms 971ms -3% z=1.8
canvas-mouse-sweep: script duration 138ms 138ms -0% z=0.4
canvas-mouse-sweep: TBT 0ms 0ms +0%
canvas-mouse-sweep: heap used 63.8 MB 56.4 MB -12%
canvas-mouse-sweep: DOM nodes 65 65 +0% z=1.0
canvas-mouse-sweep: event listeners 6 6 +0% z=-0.6
canvas-zoom-sweep: avg frame time 17ms 17ms +0% z=0.5
canvas-zoom-sweep: p95 frame time 17ms 17ms +0%
canvas-zoom-sweep: layout duration 1ms 1ms -1% z=0.1
canvas-zoom-sweep: style recalc duration 19ms 19ms -3% z=-0.2
canvas-zoom-sweep: layout count 6 6 +0%
canvas-zoom-sweep: style recalc count 31 32 +3% z=1.6
canvas-zoom-sweep: task duration 369ms 327ms -12% z=-0.0
canvas-zoom-sweep: script duration 34ms 28ms -16% z=0.4
canvas-zoom-sweep: TBT 0ms 0ms +0%
canvas-zoom-sweep: heap used 64.0 MB 64.0 MB -0%
canvas-zoom-sweep: DOM nodes 79 78 -1% z=-1.6
canvas-zoom-sweep: event listeners 19 19 +0% z=-0.9
dom-widget-clipping: avg frame time 17ms 17ms +0% z=0.1
dom-widget-clipping: p95 frame time 17ms 17ms +0%
dom-widget-clipping: layout duration 0ms 0ms +0%
dom-widget-clipping: style recalc duration 10ms 10ms -3% z=0.3
dom-widget-clipping: layout count 0 0 +0%
dom-widget-clipping: style recalc count 13 13 +0% z=-0.2
dom-widget-clipping: task duration 370ms 362ms -2% z=-0.2
dom-widget-clipping: script duration 65ms 70ms +8% z=0.7
dom-widget-clipping: TBT 0ms 0ms +0%
dom-widget-clipping: heap used 46.8 MB 46.9 MB +0%
dom-widget-clipping: DOM nodes 22 22 +0% z=-0.1
dom-widget-clipping: event listeners 2 2 +0% variance too high
large-graph-idle: avg frame time 17ms 17ms +0% z=-0.2
large-graph-idle: p95 frame time 17ms 17ms +0%
large-graph-idle: layout duration 0ms 0ms +0%
large-graph-idle: style recalc duration 10ms 12ms +17% z=-0.7
large-graph-idle: layout count 0 0 +0%
large-graph-idle: style recalc count 10 11 +10% z=-1.9
large-graph-idle: task duration 680ms 561ms -17% z=0.4
large-graph-idle: script duration 118ms 105ms -11% z=0.3
large-graph-idle: TBT 0ms 0ms +0%
large-graph-idle: heap used 53.1 MB 53.3 MB +0%
large-graph-idle: DOM nodes -258 -255 -1% z=-309.4
large-graph-idle: event listeners -127 -125 -2% z=-24.8
large-graph-pan: avg frame time 17ms 17ms +0% z=0.3
large-graph-pan: p95 frame time 17ms 17ms +1%
large-graph-pan: layout duration 0ms 0ms +0%
large-graph-pan: style recalc duration 19ms 17ms -10% z=-0.1
large-graph-pan: layout count 0 0 +0%
large-graph-pan: style recalc count 69 69 +0% z=-0.9
large-graph-pan: task duration 1232ms 1130ms -8% z=1.1
large-graph-pan: script duration 422ms 403ms -5% z=-0.3
large-graph-pan: TBT 0ms 0ms +0%
large-graph-pan: heap used 68.1 MB 66.2 MB -3%
large-graph-pan: DOM nodes -262 -261 -0% z=-169.7
large-graph-pan: event listeners -127 -127 +0% z=-159.3
large-graph-zoom: avg frame time 17ms 17ms +0%
large-graph-zoom: p95 frame time 17ms 17ms +0%
large-graph-zoom: layout duration 9ms 7ms -20%
large-graph-zoom: style recalc duration 20ms 17ms -14%
large-graph-zoom: layout count 60 60 +0%
large-graph-zoom: style recalc count 66 66 +0%
large-graph-zoom: task duration 1498ms 1351ms -10%
large-graph-zoom: script duration 550ms 504ms -8%
large-graph-zoom: TBT 0ms 0ms +0%
large-graph-zoom: heap used 61.5 MB 61.5 MB -0%
large-graph-zoom: DOM nodes -266 -262 -2%
large-graph-zoom: event listeners -123 -123 +0%
minimap-idle: avg frame time 17ms 17ms +0% z=0.1
minimap-idle: p95 frame time 17ms 17ms +1%
minimap-idle: layout duration 0ms 0ms +0%
minimap-idle: style recalc duration 8ms 10ms +24% z=0.8
minimap-idle: layout count 0 0 +0%
minimap-idle: style recalc count 9 9 +0% z=-0.8
minimap-idle: task duration 636ms 578ms -9% z=1.1
minimap-idle: script duration 103ms 103ms +0% z=0.5
minimap-idle: TBT 0ms 0ms +0%
minimap-idle: heap used 54.5 MB 54.2 MB -1%
minimap-idle: DOM nodes -262 -262 +0% z=-205.6
minimap-idle: event listeners -127 -127 +0% z=-199.3
subgraph-dom-widget-clipping: avg frame time 17ms 17ms +0% z=0.1
subgraph-dom-widget-clipping: p95 frame time 17ms 17ms -1%
subgraph-dom-widget-clipping: layout duration 0ms 0ms +0%
subgraph-dom-widget-clipping: style recalc duration 14ms 13ms -6% z=0.2
subgraph-dom-widget-clipping: layout count 0 0 +0%
subgraph-dom-widget-clipping: style recalc count 48 48 +0% z=0.1
subgraph-dom-widget-clipping: task duration 389ms 376ms -3% z=-0.1
subgraph-dom-widget-clipping: script duration 135ms 131ms -3% z=0.4
subgraph-dom-widget-clipping: TBT 0ms 0ms +0%
subgraph-dom-widget-clipping: heap used 47.2 MB 47.1 MB -0%
subgraph-dom-widget-clipping: DOM nodes 22 22 +0% z=-0.2
subgraph-dom-widget-clipping: event listeners 8 8 +0% z=-1.4
subgraph-idle: avg frame time 17ms 17ms +0% z=0.4
subgraph-idle: p95 frame time 17ms 17ms +1%
subgraph-idle: layout duration 0ms 0ms +0%
subgraph-idle: style recalc duration 10ms 11ms +8% z=0.9
subgraph-idle: layout count 0 0 +0%
subgraph-idle: style recalc count 10 11 +10% z=0.2
subgraph-idle: task duration 421ms 372ms -12% z=0.1
subgraph-idle: script duration 23ms 21ms -8% z=0.4
subgraph-idle: TBT 0ms 0ms +0%
subgraph-idle: heap used 60.1 MB 60.1 MB -0%
subgraph-idle: DOM nodes 20 22 +10% z=0.1
subgraph-idle: event listeners 6 6 +0% variance too high
subgraph-mouse-sweep: avg frame time 17ms 17ms +0% z=0.4
subgraph-mouse-sweep: p95 frame time 17ms 17ms +1%
subgraph-mouse-sweep: layout duration 5ms 5ms -11% z=-0.3
subgraph-mouse-sweep: style recalc duration 52ms 51ms -3% ⚠️ z=2.5
subgraph-mouse-sweep: layout count 16 16 +0%
subgraph-mouse-sweep: style recalc count 88 87 -1% z=3.6
subgraph-mouse-sweep: task duration 1009ms 912ms -10% ⚠️ z=2.1
subgraph-mouse-sweep: script duration 114ms 100ms -12% z=-0.1
subgraph-mouse-sweep: TBT 0ms 0ms +0%
subgraph-mouse-sweep: heap used 52.1 MB 52.3 MB +0%
subgraph-mouse-sweep: DOM nodes 74 73 -1% z=2.7
subgraph-mouse-sweep: event listeners 6 6 +0% variance too high
viewport-pan-sweep: avg frame time 17ms 17ms +0%
viewport-pan-sweep: p95 frame time 17ms 17ms +0%
viewport-pan-sweep: layout duration 0ms 0ms +0%
viewport-pan-sweep: style recalc duration 53ms 44ms -16%
viewport-pan-sweep: layout count 0 0 +0%
viewport-pan-sweep: style recalc count 251 251 +0%
viewport-pan-sweep: task duration 4166ms 3972ms -5%
viewport-pan-sweep: script duration 1327ms 1386ms +4%
viewport-pan-sweep: TBT 0ms 0ms +0%
viewport-pan-sweep: heap used 75.5 MB 76.9 MB +2%
viewport-pan-sweep: DOM nodes -255 -257 +1%
viewport-pan-sweep: event listeners -111 -111 +0%
vue-large-graph-idle: avg frame time 17ms 17ms -0%
vue-large-graph-idle: p95 frame time 17ms 17ms +1%
vue-large-graph-idle: layout duration 0ms 0ms +0%
vue-large-graph-idle: style recalc duration 0ms 0ms +0%
vue-large-graph-idle: layout count 0 0 +0%
vue-large-graph-idle: style recalc count 0 0 +0%
vue-large-graph-idle: task duration 13793ms 12327ms -11%
vue-large-graph-idle: script duration 602ms 605ms +1%
vue-large-graph-idle: TBT 0ms 0ms +0%
vue-large-graph-idle: heap used 157.7 MB 159.0 MB +1%
vue-large-graph-idle: DOM nodes -8331 -8331 +0%
vue-large-graph-idle: event listeners -16460 -16466 +0%
vue-large-graph-pan: avg frame time 18ms 17ms -3%
vue-large-graph-pan: p95 frame time 17ms 17ms +0%
vue-large-graph-pan: layout duration 0ms 0ms +0%
vue-large-graph-pan: style recalc duration 19ms 15ms -23%
vue-large-graph-pan: layout count 0 0 +0%
vue-large-graph-pan: style recalc count 83 67 -19%
vue-large-graph-pan: task duration 15933ms 14644ms -8%
vue-large-graph-pan: script duration 915ms 920ms +1%
vue-large-graph-pan: TBT 0ms 0ms +0%
vue-large-graph-pan: heap used 164.0 MB 162.9 MB -1%
vue-large-graph-pan: DOM nodes -8333 -8331 -0%
vue-large-graph-pan: event listeners -16457 -16458 +0%
workflow-execution: avg frame time 17ms 17ms -0% z=-0.4
workflow-execution: p95 frame time 17ms 17ms +0%
workflow-execution: layout duration 2ms 2ms +1% z=0.8
workflow-execution: style recalc duration 23ms 26ms +16% z=0.9
workflow-execution: layout count 4 5 +25% z=0.1
workflow-execution: style recalc count 16 17 +6% z=-0.4
workflow-execution: task duration 113ms 130ms +16% z=0.7
workflow-execution: script duration 25ms 30ms +18% z=0.3
workflow-execution: TBT 0ms 0ms +0%
workflow-execution: heap used 46.2 MB 46.9 MB +2%
workflow-execution: DOM nodes 154 156 +1% z=-0.7
workflow-execution: event listeners 71 71 +0% z=4.4
Historical variance (last 15 runs)
Metric μ σ CV
canvas-idle: avg frame time 17ms 0ms 0.0%
canvas-idle: layout duration 0ms 0ms 0.0%
canvas-idle: style recalc duration 11ms 1ms 8.2%
canvas-idle: layout count 0 0 0.0%
canvas-idle: style recalc count 11 1 5.0%
canvas-idle: task duration 395ms 31ms 7.9%
canvas-idle: script duration 25ms 2ms 8.8%
canvas-idle: TBT 0ms 0ms 0.0%
canvas-idle: DOM nodes 23 1 5.6%
canvas-idle: event listeners 12 5 40.9%
canvas-mouse-sweep: avg frame time 17ms 0ms 0.0%
canvas-mouse-sweep: layout duration 4ms 0ms 5.4%
canvas-mouse-sweep: style recalc duration 43ms 3ms 7.4%
canvas-mouse-sweep: layout count 12 0 0.0%
canvas-mouse-sweep: style recalc count 79 2 3.0%
canvas-mouse-sweep: task duration 865ms 58ms 6.7%
canvas-mouse-sweep: script duration 136ms 6ms 4.8%
canvas-mouse-sweep: TBT 0ms 0ms 0.0%
canvas-mouse-sweep: DOM nodes 62 3 4.2%
canvas-mouse-sweep: event listeners 8 4 49.4%
canvas-zoom-sweep: avg frame time 17ms 0ms 0.0%
canvas-zoom-sweep: layout duration 1ms 0ms 7.0%
canvas-zoom-sweep: style recalc duration 19ms 2ms 8.0%
canvas-zoom-sweep: layout count 6 0 0.0%
canvas-zoom-sweep: style recalc count 31 0 1.5%
canvas-zoom-sweep: task duration 327ms 23ms 7.1%
canvas-zoom-sweep: script duration 27ms 3ms 11.1%
canvas-zoom-sweep: TBT 0ms 0ms 0.0%
canvas-zoom-sweep: DOM nodes 79 1 1.0%
canvas-zoom-sweep: event listeners 24 5 21.8%
dom-widget-clipping: avg frame time 17ms 0ms 0.0%
dom-widget-clipping: layout duration 0ms 0ms 0.0%
dom-widget-clipping: style recalc duration 10ms 1ms 8.0%
dom-widget-clipping: layout count 0 0 0.0%
dom-widget-clipping: style recalc count 13 0 3.8%
dom-widget-clipping: task duration 365ms 16ms 4.5%
dom-widget-clipping: script duration 68ms 3ms 4.8%
dom-widget-clipping: TBT 0ms 0ms 0.0%
dom-widget-clipping: DOM nodes 22 1 6.4%
dom-widget-clipping: event listeners 8 6 81.2%
large-graph-idle: avg frame time 17ms 0ms 0.0%
large-graph-idle: layout duration 0ms 0ms 0.0%
large-graph-idle: style recalc duration 12ms 1ms 8.6%
large-graph-idle: layout count 0 0 0.0%
large-graph-idle: style recalc count 12 0 2.7%
large-graph-idle: task duration 542ms 54ms 10.0%
large-graph-idle: script duration 102ms 11ms 10.3%
large-graph-idle: TBT 0ms 0ms 0.0%
large-graph-idle: DOM nodes 25 1 3.7%
large-graph-idle: event listeners 26 6 23.2%
large-graph-pan: avg frame time 17ms 0ms 0.0%
large-graph-pan: layout duration 0ms 0ms 0.0%
large-graph-pan: style recalc duration 17ms 1ms 4.6%
large-graph-pan: layout count 0 0 0.0%
large-graph-pan: style recalc count 70 1 0.9%
large-graph-pan: task duration 1082ms 43ms 4.0%
large-graph-pan: script duration 408ms 20ms 4.8%
large-graph-pan: TBT 0ms 0ms 0.0%
large-graph-pan: DOM nodes 19 2 8.7%
large-graph-pan: event listeners 5 1 16.8%
minimap-idle: avg frame time 17ms 0ms 0.0%
minimap-idle: layout duration 0ms 0ms 0.0%
minimap-idle: style recalc duration 10ms 1ms 8.6%
minimap-idle: layout count 0 0 0.0%
minimap-idle: style recalc count 10 1 7.1%
minimap-idle: task duration 527ms 47ms 9.0%
minimap-idle: script duration 98ms 10ms 10.1%
minimap-idle: TBT 0ms 0ms 0.0%
minimap-idle: DOM nodes 19 1 7.1%
minimap-idle: event listeners 5 1 14.4%
subgraph-dom-widget-clipping: avg frame time 17ms 0ms 0.0%
subgraph-dom-widget-clipping: layout duration 0ms 0ms 0.0%
subgraph-dom-widget-clipping: style recalc duration 13ms 1ms 7.4%
subgraph-dom-widget-clipping: layout count 0 0 0.0%
subgraph-dom-widget-clipping: style recalc count 48 1 1.2%
subgraph-dom-widget-clipping: task duration 378ms 18ms 4.9%
subgraph-dom-widget-clipping: script duration 128ms 6ms 4.9%
subgraph-dom-widget-clipping: TBT 0ms 0ms 0.0%
subgraph-dom-widget-clipping: DOM nodes 22 1 5.0%
subgraph-dom-widget-clipping: event listeners 16 6 36.0%
subgraph-idle: avg frame time 17ms 0ms 0.0%
subgraph-idle: layout duration 0ms 0ms 0.0%
subgraph-idle: style recalc duration 10ms 1ms 7.5%
subgraph-idle: layout count 0 0 0.0%
subgraph-idle: style recalc count 11 1 6.0%
subgraph-idle: task duration 370ms 31ms 8.5%
subgraph-idle: script duration 20ms 3ms 13.2%
subgraph-idle: TBT 0ms 0ms 0.0%
subgraph-idle: DOM nodes 22 1 6.9%
subgraph-idle: event listeners 10 7 64.5%
subgraph-mouse-sweep: avg frame time 17ms 0ms 0.0%
subgraph-mouse-sweep: layout duration 5ms 0ms 6.8%
subgraph-mouse-sweep: style recalc duration 42ms 3ms 7.8%
subgraph-mouse-sweep: layout count 16 0 0.0%
subgraph-mouse-sweep: style recalc count 80 2 2.4%
subgraph-mouse-sweep: task duration 766ms 69ms 9.0%
subgraph-mouse-sweep: script duration 101ms 7ms 6.5%
subgraph-mouse-sweep: TBT 0ms 0ms 0.0%
subgraph-mouse-sweep: DOM nodes 67 2 3.3%
subgraph-mouse-sweep: event listeners 8 4 52.6%
workflow-execution: avg frame time 17ms 0ms 0.0%
workflow-execution: layout duration 2ms 0ms 9.4%
workflow-execution: style recalc duration 24ms 2ms 9.1%
workflow-execution: layout count 5 1 11.0%
workflow-execution: style recalc count 18 2 11.5%
workflow-execution: task duration 123ms 11ms 8.8%
workflow-execution: script duration 29ms 3ms 10.2%
workflow-execution: TBT 0ms 0ms 0.0%
workflow-execution: DOM nodes 161 7 4.4%
workflow-execution: event listeners 52 4 8.4%
Trend (last 15 commits on main)
Metric Trend Dir Latest
canvas-idle: avg frame time ▆▃▆▁▆▃▆█▆▆▄▃▃▄▃ ➡️ 17ms
canvas-idle: p95 frame time ➡️ NaNms
canvas-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-idle: style recalc duration ▇▇▆▆▃█▄▃▄▃▇▄▁▆▇ ➡️ 11ms
canvas-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
canvas-idle: style recalc count █▃▅▂▅▆▃▁▂▁▂▅▆▅▆ ➡️ 12
canvas-idle: task duration ▃▃▃▆▂▃▃▅▆▂█▃▁▃▃ ➡️ 391ms
canvas-idle: script duration ▄▃▅▇▂▅▃▆▇▅█▄▁▅▆ ➡️ 27ms
canvas-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-idle: heap used ➡️ NaN MB
canvas-idle: DOM nodes █▇▆▅▃▇▃▁▂▂▅▆▆▆▇ ➡️ 24
canvas-idle: event listeners ▅█▅▄▁▅▁▁▁▄▅▅▁▅▄ 📉 11
canvas-mouse-sweep: avg frame time ▆█▆▃▁▃▁▆▆▁▃▆▆▃▃ ➡️ 17ms
canvas-mouse-sweep: p95 frame time ➡️ NaNms
canvas-mouse-sweep: layout duration ▁▃▂▄▁▂▁▃▆▂█▇▆▄▃ ➡️ 4ms
canvas-mouse-sweep: style recalc duration ▄▄▂▄▁▂▃▃▅▄█▆▂▄▄ ➡️ 43ms
canvas-mouse-sweep: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 12
canvas-mouse-sweep: style recalc count █▅▄▃▂▂▁▄▄▅▆▅▂▇▄ ➡️ 79
canvas-mouse-sweep: task duration █▆▄▂▂▃▂▄▄▅█▆▁▆▄ ➡️ 868ms
canvas-mouse-sweep: script duration ▄▅▄▆▄▆▆▆▅▅█▆▁▅▆ ➡️ 139ms
canvas-mouse-sweep: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-mouse-sweep: heap used ➡️ NaN MB
canvas-mouse-sweep: DOM nodes █▅▃▃▁▂▂▃▂▄▆▅▃▅▅ ➡️ 64
canvas-mouse-sweep: event listeners █▁▁▁▁▁▇▁▁▁██▇▁█ 📈 13
canvas-zoom-sweep: avg frame time ▅▅█▄▅▁▁▁▅▁▁▅▄▅▁ ➡️ 17ms
canvas-zoom-sweep: p95 frame time ➡️ NaNms
canvas-zoom-sweep: layout duration ▆▅▅▄▁▁█▅▃▅▇▆▁▂▆ ➡️ 1ms
canvas-zoom-sweep: style recalc duration ▆▅▄▆▅▃█▆▇▅▇▄▁▃▅ ➡️ 20ms
canvas-zoom-sweep: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 6
canvas-zoom-sweep: style recalc count ▁▁▃▄▆▃▆█▄▄▆▁▆▁▆ ➡️ 32
canvas-zoom-sweep: task duration ▄▂▁▇▂▂▄▅▆▃█▄▁▁▅ ➡️ 338ms
canvas-zoom-sweep: script duration ▃▃▂▇▂▂▅▇▆▅█▄▁▂▆ ➡️ 30ms
canvas-zoom-sweep: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-zoom-sweep: heap used ➡️ NaN MB
canvas-zoom-sweep: DOM nodes ▄▃▁▅█▁▃▆▄▅▅▃▃▄▃ ➡️ 79
canvas-zoom-sweep: event listeners ▁▁▂▅█▂▁▅▁▅▅▄▁▅▁ ➡️ 19
dom-widget-clipping: avg frame time ▂▄▅▅▂▄█▇▅▇▇▅▅▁▇ ➡️ 17ms
dom-widget-clipping: p95 frame time ➡️ NaNms
dom-widget-clipping: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
dom-widget-clipping: style recalc duration ▆▆▂▆▄▃██▄▁▆▇▆▃▅ ➡️ 10ms
dom-widget-clipping: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
dom-widget-clipping: style recalc count ▇█▅█▅▄█▇▇▁▇▄▇▂▅ ➡️ 13
dom-widget-clipping: task duration ▃▃▁▅▄▃▅▆▅▂▇█▁▅▅ ➡️ 371ms
dom-widget-clipping: script duration ▅▄▄▆▆▅▇▇▆▃█▇▁▇▇ ➡️ 71ms
dom-widget-clipping: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
dom-widget-clipping: heap used ➡️ NaN MB
dom-widget-clipping: DOM nodes ▇▇▄▇▅▄█▇▅▁▅▄▇▃▄ ➡️ 21
dom-widget-clipping: event listeners ▅▅▅▅▁▅██▁▁▁▁█▁▁ 📉 2
large-graph-idle: avg frame time ▅▅▅▅▅▂▁▂▄▅▄▂▂▅█ ➡️ 17ms
large-graph-idle: p95 frame time ➡️ NaNms
large-graph-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-idle: style recalc duration ▅▅▅▆▄▅▃▄▅▅▆█▁▄▆ ➡️ 13ms
large-graph-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
large-graph-idle: style recalc count █▆█▃▃▁▃▆▃▆▆▃▆██ ➡️ 12
large-graph-idle: task duration ▂▃▂▆▂▃▃▇▅▃██▁▂▅ ➡️ 569ms
large-graph-idle: script duration ▄▅▄▆▄▅▅▇▆▅█▆▁▃▆ ➡️ 110ms
large-graph-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-idle: heap used ➡️ NaN MB
large-graph-idle: DOM nodes ▆█▅▂▅▃▁▂▃▅▅▆▂▆▅ ➡️ 25
large-graph-idle: event listeners ███▇██▄▁▄▇▇█▂█▇ ➡️ 29
large-graph-pan: avg frame time ▆▃▃▆█▃▁█▆▆▆▆█▁▆ ➡️ 17ms
large-graph-pan: p95 frame time ➡️ NaNms
large-graph-pan: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-pan: style recalc duration ▃▂▄▄▁▅▂▂▁▄▄█▃▁▂ ➡️ 17ms
large-graph-pan: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
large-graph-pan: style recalc count ▆▃█▂▃▂▂▂▁▇▅▃█▆▃ ➡️ 69
large-graph-pan: task duration ▄▃▄▆▄▄▄▆▄▄█▆▁▂▅ ➡️ 1100ms
large-graph-pan: script duration ▅▄▅▆▆▅▄▆▄▅█▄▁▄▅ ➡️ 413ms
large-graph-pan: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-pan: heap used ➡️ NaN MB
large-graph-pan: DOM nodes ▅▃▆▂▄▁▃▁▁▅▁▂█▅▂ ➡️ 18
large-graph-pan: event listeners █▆█▁▁▆▁▁▃▆▁▃██▃ ➡️ 5
minimap-idle: avg frame time ▃▆▆▃█▁█▆▆▃▃▆█▆█ ➡️ 17ms
minimap-idle: p95 frame time ➡️ NaNms
minimap-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
minimap-idle: style recalc duration ▄█▁█▅▅█▅▅▃▅▁▁▄▆ ➡️ 10ms
minimap-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
minimap-idle: style recalc count ▃▅▂▄█▃▆▁▂▅▂▁▅▆▃ ➡️ 9
minimap-idle: task duration ▃▄▁▅▁▃▄▅▇▃█▅▁▁▅ ➡️ 547ms
minimap-idle: script duration ▄▆▃▇▃▅▆▆▇▅█▅▁▃▆ ➡️ 106ms
minimap-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
minimap-idle: heap used ➡️ NaN MB
minimap-idle: DOM nodes ▃▅▂▄█▃▆▁▂▅▂▁▅▆▃ ➡️ 19
minimap-idle: event listeners ▃▃▆▁▁▁▃▁▁▆▁▃█▆▁ ➡️ 4
subgraph-dom-widget-clipping: avg frame time ▅▄▄▄▄▄█▄▄▄▃▁▆▃▃ ➡️ 17ms
subgraph-dom-widget-clipping: p95 frame time ➡️ NaNms
subgraph-dom-widget-clipping: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-dom-widget-clipping: style recalc duration ▂▄▃▅▅▃▂▅▇▃▄█▁▄▆ ➡️ 14ms
subgraph-dom-widget-clipping: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
subgraph-dom-widget-clipping: style recalc count ▇█▆▃▆▃▁▆█▇▃▆▇█▅ ➡️ 48
subgraph-dom-widget-clipping: task duration ▂▃▃▆▅▅▂▅█▂▆█▁▂▇ ➡️ 398ms
subgraph-dom-widget-clipping: script duration ▃▃▃▄▅▅▂▄█▂▅▇▁▂▅ ➡️ 131ms
subgraph-dom-widget-clipping: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-dom-widget-clipping: heap used ➡️ NaN MB
subgraph-dom-widget-clipping: DOM nodes ▅▇▅▂▅▂▁▅▅▅▁▇▅█▄ ➡️ 22
subgraph-dom-widget-clipping: event listeners ▅▅▅▂▅▁▅██▁▁█▅█▅ 📈 16
subgraph-idle: avg frame time ▆▆█▁▆▃▆▆▆▃▆▁▃▆█ ➡️ 17ms
subgraph-idle: p95 frame time ➡️ NaNms
subgraph-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-idle: style recalc duration ▁▇▃▆▂▄▂▃▃▆▆▄▃▇█ ➡️ 12ms
subgraph-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
subgraph-idle: style recalc count ▃▆▃▃▂▅▁▂▁▆▃▃██▇ ➡️ 12
subgraph-idle: task duration ▁▃▁▇▁▁▃▆▅▂█▅▁▁▄ ➡️ 378ms
subgraph-idle: script duration ▁▃▂▇▁▂▃▇▆▂█▅▂▁▅ ➡️ 22ms
subgraph-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-idle: heap used ➡️ NaN MB
subgraph-idle: DOM nodes ▃▅▃▂▁▄▁▂▁▅▃▂▇█▇ ➡️ 24
subgraph-idle: event listeners ▁▅▁▁▁▁▁▁▁▅▄▁███ 📈 21
subgraph-mouse-sweep: avg frame time ▅▄▁▃▃▄▆▄▆▃▃█▁▃▃ ➡️ 17ms
subgraph-mouse-sweep: p95 frame time ➡️ NaNms
subgraph-mouse-sweep: layout duration ▁▄▄▄▃▃▅▅▅▂█▇▂▃▆ ➡️ 5ms
subgraph-mouse-sweep: style recalc duration ▃▂▄▅▂▃▄▅█▃█▆▁▂▅ ➡️ 43ms
subgraph-mouse-sweep: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 16
subgraph-mouse-sweep: style recalc count ▅▂▅▅▁▄▃▅█▅▆▄▂▄▅ ➡️ 81
subgraph-mouse-sweep: task duration ▃▂▄▅▂▄▄▅▇▄█▆▁▃▅ ➡️ 785ms
subgraph-mouse-sweep: script duration ▄▅▄▇▅▅▆▇▆▅██▁▄▆ ➡️ 105ms
subgraph-mouse-sweep: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-mouse-sweep: heap used ➡️ NaN MB
subgraph-mouse-sweep: DOM nodes ▅▁▄▅▁▄▃▃█▅▅▄▂▅▃ ➡️ 66
subgraph-mouse-sweep: event listeners ▇▁▂▇▁▂▂▂█▇▂▂▇▇▂ 📈 5
workflow-execution: avg frame time ▆▆▆▄▆▆▃▄▁▄█▆▅▄▆ ➡️ 17ms
workflow-execution: p95 frame time ➡️ NaNms
workflow-execution: layout duration ▁▆▁▃▂▄▃▂▃▃▅█▄▂▅ ➡️ 2ms
workflow-execution: style recalc duration ▃▇▅▇▁▅▆▇█▁██▂▄▆ ➡️ 25ms
workflow-execution: layout count ▁█▂▃▂▃▃▁▃▃▄▃▂▃▂ ➡️ 5
workflow-execution: style recalc count ▃█▅▇▁▄▅▆▅▅▅▅▄▄▂ ➡️ 15
workflow-execution: task duration ▂▅▄▅▁▄▆▆▆▁▇█▁▃▃ ➡️ 120ms
workflow-execution: script duration ▄▃▄▄▃▅▄▅▆▂▇█▁▃▄ ➡️ 29ms
workflow-execution: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
workflow-execution: heap used ➡️ NaN MB
workflow-execution: DOM nodes ▂█▃▆▁▄▃▅▃█▃▃▄▃▁ ➡️ 152
workflow-execution: event listeners ▅███▁▅███▁██▅█▅ ➡️ 49
Raw data
{
  "timestamp": "2026-04-02T04:51:34.041Z",
  "gitSha": "cbc2069d561ce54a0dba3835e49c7c9441a8a5cc",
  "branch": "drjkl/test/the-active-ingredient-is-selenium",
  "measurements": [
    {
      "name": "canvas-idle",
      "durationMs": 2022.4070000000154,
      "styleRecalcs": 8,
      "styleRecalcDurationMs": 8.567000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 364.588,
      "heapDeltaBytes": 20673628,
      "heapUsedBytes": 63774192,
      "domNodes": 16,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 18.180999999999997,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-idle",
      "durationMs": 2028.8909999999873,
      "styleRecalcs": 9,
      "styleRecalcDurationMs": 8.811000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 350.9,
      "heapDeltaBytes": 20642448,
      "heapUsedBytes": 63786364,
      "domNodes": 18,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 17.158000000000005,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-idle",
      "durationMs": 2054.072000000019,
      "styleRecalcs": 12,
      "styleRecalcDurationMs": 9.905,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 426.28399999999993,
      "heapDeltaBytes": 20967884,
      "heapUsedBytes": 63884532,
      "domNodes": 23,
      "jsHeapTotalBytes": 22544384,
      "scriptDurationMs": 29.516999999999996,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 2022.812000000016,
      "styleRecalcs": 83,
      "styleRecalcDurationMs": 46.514,
      "layouts": 12,
      "layoutDurationMs": 4.132000000000001,
      "taskDurationMs": 1056.663,
      "heapDeltaBytes": 16528412,
      "heapUsedBytes": 60799856,
      "domNodes": 65,
      "jsHeapTotalBytes": 23330816,
      "scriptDurationMs": 143.16,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 2021.0030000000074,
      "styleRecalcs": 85,
      "styleRecalcDurationMs": 45.968999999999994,
      "layouts": 12,
      "layoutDurationMs": 3.7960000000000003,
      "taskDurationMs": 971.268,
      "heapDeltaBytes": 16290432,
      "heapUsedBytes": 59130664,
      "domNodes": 68,
      "jsHeapTotalBytes": 23592960,
      "scriptDurationMs": 135.751,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 1791.4810000000898,
      "styleRecalcs": 75,
      "styleRecalcDurationMs": 39.923,
      "layouts": 12,
      "layoutDurationMs": 3.5530000000000004,
      "taskDurationMs": 798.3720000000001,
      "heapDeltaBytes": 15752200,
      "heapUsedBytes": 58908032,
      "domNodes": 59,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 137.974,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1729.5430000000351,
      "styleRecalcs": 31,
      "styleRecalcDurationMs": 18.531000000000002,
      "layouts": 6,
      "layoutDurationMs": 0.6479999999999999,
      "taskDurationMs": 326.79099999999994,
      "heapDeltaBytes": 15509676,
      "heapUsedBytes": 66839404,
      "domNodes": 77,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 26.881999999999998,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1739.6939999999859,
      "styleRecalcs": 33,
      "styleRecalcDurationMs": 19.823,
      "layouts": 6,
      "layoutDurationMs": 0.7160000000000001,
      "taskDurationMs": 317.152,
      "heapDeltaBytes": 24717820,
      "heapUsedBytes": 67105612,
      "domNodes": 80,
      "jsHeapTotalBytes": 20709376,
      "scriptDurationMs": 28.308,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1733.021000000008,
      "styleRecalcs": 32,
      "styleRecalcDurationMs": 18.82,
      "layouts": 6,
      "layoutDurationMs": 0.6169999999999999,
      "taskDurationMs": 335.23400000000004,
      "heapDeltaBytes": 15421496,
      "heapUsedBytes": 68207076,
      "domNodes": 78,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 28.237,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 584.163999999987,
      "styleRecalcs": 13,
      "styleRecalcDurationMs": 10.087,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 361.914,
      "heapDeltaBytes": -2157664,
      "heapUsedBytes": 49628616,
      "domNodes": 22,
      "jsHeapTotalBytes": 16252928,
      "scriptDurationMs": 67.273,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 551.6829999999686,
      "styleRecalcs": 13,
      "styleRecalcDurationMs": 9.195,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 356.903,
      "heapDeltaBytes": -2656856,
      "heapUsedBytes": 49161376,
      "domNodes": 22,
      "jsHeapTotalBytes": 16515072,
      "scriptDurationMs": 70.213,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 577.0129999999654,
      "styleRecalcs": 14,
      "styleRecalcDurationMs": 11.348000000000003,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 371.609,
      "heapDeltaBytes": 6580592,
      "heapUsedBytes": 49056732,
      "domNodes": 23,
      "jsHeapTotalBytes": 14155776,
      "scriptDurationMs": 71.44300000000001,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2051.521000000008,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 9.491,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 547.096,
      "heapDeltaBytes": 4800992,
      "heapUsedBytes": 55876780,
      "domNodes": -257,
      "jsHeapTotalBytes": 16707584,
      "scriptDurationMs": 105.33,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2052.958999999987,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 11.536000000000001,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 561.2470000000001,
      "heapDeltaBytes": 5790544,
      "heapUsedBytes": 56279120,
      "domNodes": -255,
      "jsHeapTotalBytes": 15921152,
      "scriptDurationMs": 105.003,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2057.1239999999307,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 11.75,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 618.259,
      "heapDeltaBytes": 4692828,
      "heapUsedBytes": 55573776,
      "domNodes": -255,
      "jsHeapTotalBytes": 16183296,
      "scriptDurationMs": 114.097,
      "eventListeners": -121,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2100.644999999986,
      "styleRecalcs": 69,
      "styleRecalcDurationMs": 17.217999999999996,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1085.0040000000001,
      "heapDeltaBytes": 16366688,
      "heapUsedBytes": 69381996,
      "domNodes": -259,
      "jsHeapTotalBytes": 18747392,
      "scriptDurationMs": 398.36899999999997,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2137.6879999999687,
      "styleRecalcs": 69,
      "styleRecalcDurationMs": 17.276,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1201.731,
      "heapDeltaBytes": 18691616,
      "heapUsedBytes": 73045840,
      "domNodes": -261,
      "jsHeapTotalBytes": 18485248,
      "scriptDurationMs": 464.97600000000006,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2142.1440000000302,
      "styleRecalcs": 68,
      "styleRecalcDurationMs": 15.905,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1130.0349999999999,
      "heapDeltaBytes": 15350108,
      "heapUsedBytes": 68922592,
      "domNodes": -262,
      "jsHeapTotalBytes": 18747392,
      "scriptDurationMs": 402.563,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3209.3619999999987,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 18.166,
      "layouts": 60,
      "layoutDurationMs": 7.391,
      "taskDurationMs": 1345.479,
      "heapDeltaBytes": 10123292,
      "heapUsedBytes": 64463648,
      "domNodes": -260,
      "jsHeapTotalBytes": 15396864,
      "scriptDurationMs": 511.964,
      "eventListeners": -123,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.670000000000012,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3196.860000000015,
      "styleRecalcs": 66,
      "styleRecalcDurationMs": 17.130000000000003,
      "layouts": 60,
      "layoutDurationMs": 7.686,
      "taskDurationMs": 1351.247,
      "heapDeltaBytes": 7607860,
      "heapUsedBytes": 62480076,
      "domNodes": -262,
      "jsHeapTotalBytes": 17756160,
      "scriptDurationMs": 501.081,
      "eventListeners": -123,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3184.028000000012,
      "styleRecalcs": 65,
      "styleRecalcDurationMs": 16.490000000000002,
      "layouts": 60,
      "layoutDurationMs": 7.465,
      "taskDurationMs": 1366.5669999999998,
      "heapDeltaBytes": 9626620,
      "heapUsedBytes": 64638628,
      "domNodes": -266,
      "jsHeapTotalBytes": 16183296,
      "scriptDurationMs": 504.32200000000006,
      "eventListeners": -123,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66999999999998,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "minimap-idle",
      "durationMs": 2011.6090000000213,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 10.195000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 554.3169999999999,
      "heapDeltaBytes": 4063804,
      "heapUsedBytes": 56248468,
      "domNodes": -262,
      "jsHeapTotalBytes": 16445440,
      "scriptDurationMs": 103.10699999999999,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "minimap-idle",
      "durationMs": 2070.112999999992,
      "styleRecalcs": 9,
      "styleRecalcDurationMs": 10.893,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 578.34,
      "heapDeltaBytes": 3941732,
      "heapUsedBytes": 57775944,
      "domNodes": -262,
      "jsHeapTotalBytes": 16027648,
      "scriptDurationMs": 103.20499999999998,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.670000000000012,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "minimap-idle",
      "durationMs": 2027.029999999968,
      "styleRecalcs": 9,
      "styleRecalcDurationMs": 9.284,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 623.7660000000001,
      "heapDeltaBytes": 4561220,
      "heapUsedBytes": 56821360,
      "domNodes": -261,
      "jsHeapTotalBytes": 15134720,
      "scriptDurationMs": 113.15000000000002,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 556.7830000000527,
      "styleRecalcs": 48,
      "styleRecalcDurationMs": 12.9,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 376.174,
      "heapDeltaBytes": 6855844,
      "heapUsedBytes": 49673988,
      "domNodes": 22,
      "jsHeapTotalBytes": 13107200,
      "scriptDurationMs": 130.628,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.799999999999727
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 561.2290000000257,
      "styleRecalcs": 48,
      "styleRecalcDurationMs": 12.87,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 377.0739999999999,
      "heapDeltaBytes": 6250720,
      "heapUsedBytes": 49296668,
      "domNodes": 22,
      "jsHeapTotalBytes": 13893632,
      "scriptDurationMs": 132.41699999999997,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.669999999999998,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 553.8799999999355,
      "styleRecalcs": 47,
      "styleRecalcDurationMs": 11.044,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 366.674,
      "heapDeltaBytes": 6189788,
      "heapUsedBytes": 49404784,
      "domNodes": 20,
      "jsHeapTotalBytes": 13631488,
      "scriptDurationMs": 126.53099999999998,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2004.9980000000005,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 11.125000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 371.642,
      "heapDeltaBytes": 19947092,
      "heapUsedBytes": 63019252,
      "domNodes": 23,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 21.182,
      "eventListeners": 4,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2014.6310000000085,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 9.864999999999998,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 343.106,
      "heapDeltaBytes": 19823492,
      "heapUsedBytes": 63020092,
      "domNodes": 22,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 14.092,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2024.450999999999,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 11.801999999999998,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 398.98900000000003,
      "heapDeltaBytes": 19970884,
      "heapUsedBytes": 62739380,
      "domNodes": 22,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 23.726999999999997,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1985.7609999999966,
      "styleRecalcs": 87,
      "styleRecalcDurationMs": 50.837999999999994,
      "layouts": 16,
      "layoutDurationMs": 4.6,
      "taskDurationMs": 912.3809999999999,
      "heapDeltaBytes": 11836608,
      "heapUsedBytes": 54890964,
      "domNodes": 73,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 97.67,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1977.1139999999718,
      "styleRecalcs": 84,
      "styleRecalcDurationMs": 44.769999999999996,
      "layouts": 16,
      "layoutDurationMs": 4.308,
      "taskDurationMs": 901.1369999999998,
      "heapDeltaBytes": 11930500,
      "heapUsedBytes": 54940564,
      "domNodes": 73,
      "jsHeapTotalBytes": 22282240,
      "scriptDurationMs": 99.83899999999998,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 2003.2469999999876,
      "styleRecalcs": 89,
      "styleRecalcDurationMs": 54.733000000000004,
      "layouts": 16,
      "layoutDurationMs": 5.1610000000000005,
      "taskDurationMs": 991.9960000000001,
      "heapDeltaBytes": 11890520,
      "heapUsedBytes": 54599808,
      "domNodes": 75,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 112.077,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8167.92300000003,
      "styleRecalcs": 250,
      "styleRecalcDurationMs": 43.511,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 3754.3479999999995,
      "heapDeltaBytes": 25576072,
      "heapUsedBytes": 76295600,
      "domNodes": -257,
      "jsHeapTotalBytes": 19271680,
      "scriptDurationMs": 1273.007,
      "eventListeners": -109,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8245.363999999994,
      "styleRecalcs": 251,
      "styleRecalcDurationMs": 44.204,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 4070.0270000000005,
      "heapDeltaBytes": 30849992,
      "heapUsedBytes": 81614664,
      "domNodes": -257,
      "jsHeapTotalBytes": 25563136,
      "scriptDurationMs": 1434.882,
      "eventListeners": -111,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8170.799999999986,
      "styleRecalcs": 252,
      "styleRecalcDurationMs": 45.199000000000005,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 3971.647,
      "heapDeltaBytes": 29699804,
      "heapUsedBytes": 80666928,
      "domNodes": -257,
      "jsHeapTotalBytes": 21106688,
      "scriptDurationMs": 1386.415,
      "eventListeners": -111,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 12337.429000000044,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 12327.23,
      "heapDeltaBytes": -31639848,
      "heapUsedBytes": 165904156,
      "domNodes": -8331,
      "jsHeapTotalBytes": 27353088,
      "scriptDurationMs": 605.196,
      "eventListeners": -16470,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.223333333333237,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 11873.733000000015,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 11861.613,
      "heapDeltaBytes": -28000312,
      "heapUsedBytes": 166712756,
      "domNodes": -8331,
      "jsHeapTotalBytes": 28925952,
      "scriptDurationMs": 573.716,
      "eventListeners": -16464,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.220000000000073,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 12500.139999999989,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 12489.386999999999,
      "heapDeltaBytes": -27732684,
      "heapUsedBytes": 167212144,
      "domNodes": -8331,
      "jsHeapTotalBytes": 28663808,
      "scriptDurationMs": 633.027,
      "eventListeners": -16466,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.223333333333358,
      "p95FrameDurationMs": 16.80000000000291
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 14668.229999999994,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 14.450999999999992,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 14644.27,
      "heapDeltaBytes": -22910748,
      "heapUsedBytes": 170801376,
      "domNodes": -8331,
      "jsHeapTotalBytes": 24907776,
      "scriptDurationMs": 925.0830000000001,
      "eventListeners": -16457,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.77333333333336,
      "p95FrameDurationMs": 33.20000000000073
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 14578.983999999991,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 14.676999999999996,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 14557.000000000002,
      "heapDeltaBytes": -8137748,
      "heapUsedBytes": 185412400,
      "domNodes": -8333,
      "jsHeapTotalBytes": 24645632,
      "scriptDurationMs": 889.524,
      "eventListeners": -16458,
      "totalBlockingTimeMs": 89,
      "frameDurationMs": 17.219999999999953,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 14744.291999999972,
      "styleRecalcs": 68,
      "styleRecalcDurationMs": 15.012999999999998,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 14722.193999999998,
      "heapDeltaBytes": -57500496,
      "heapUsedBytes": 148624188,
      "domNodes": -8331,
      "jsHeapTotalBytes": -2007040,
      "scriptDurationMs": 920.104,
      "eventListeners": -16486,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.220000000000073,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "workflow-execution",
      "durationMs": 448.3809999999835,
      "styleRecalcs": 18,
      "styleRecalcDurationMs": 27.341,
      "layouts": 5,
      "layoutDurationMs": 1.6630000000000003,
      "taskDurationMs": 133.948,
      "heapDeltaBytes": 4744524,
      "heapUsedBytes": 49615332,
      "domNodes": 167,
      "jsHeapTotalBytes": 262144,
      "scriptDurationMs": 29.928000000000004,
      "eventListeners": 71,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.799999999999727
    },
    {
      "name": "workflow-execution",
      "durationMs": 450.3190000000359,
      "styleRecalcs": 17,
      "styleRecalcDurationMs": 26.238,
      "layouts": 5,
      "layoutDurationMs": 1.4649999999999999,
      "taskDurationMs": 130.495,
      "heapDeltaBytes": 4510508,
      "heapUsedBytes": 49197132,
      "domNodes": 156,
      "jsHeapTotalBytes": 0,
      "scriptDurationMs": 33.208,
      "eventListeners": 71,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999727
    },
    {
      "name": "workflow-execution",
      "durationMs": 129.35600000002978,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 21.828999999999997,
      "layouts": 5,
      "layoutDurationMs": 1.838,
      "taskDurationMs": 106.28900000000002,
      "heapDeltaBytes": 2843164,
      "heapUsedBytes": 47551844,
      "domNodes": 145,
      "jsHeapTotalBytes": 0,
      "scriptDurationMs": 29.122000000000003,
      "eventListeners": 39,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.800000000000182
    }
  ]
}

@coderabbitai
Copy link
Copy Markdown
Contributor

coderabbitai bot commented Apr 2, 2026

📝 Walkthrough

Walkthrough

Tests were updated to use retrying/polling assertions and additional synchronization; one test replaces a hardcoded canvas click coordinate with a dynamic lookup; a drag-and-drop helper now waits for upload; imports in playwright.config.ts were reordered (type import before value imports). No public API changes.

Changes

Cohort / File(s) Summary
Config import reorder
playwright.config.ts
Reordered imports so PlaywrightTestConfig (type-only) appears before defineConfig/devices value imports. No behavior change.
Retry/polling & sync updates (tests)
browser_tests/helpers/builderTestUtils.ts, browser_tests/tests/changeTracker.spec.ts, browser_tests/tests/subgraph/subgraphPromotion.spec.ts, browser_tests/tests/subgraph/subgraphPromotionDom.spec.ts
Replaced immediate assertions with Playwright expect(...).toPass(...) or expect.poll(...) to wait up to 5s for eventual consistency (promoted widget presence, undo/redo queue sizes, modified-state), improving test synchronization.
Canvas coordinate dynamic lookup
browser_tests/tests/rerouteNode.spec.ts
Replaced static clickable midpoint with an in-page waitForFunction that finds window.app.canvas.renderedPaths entry (id === 5) and extracts its _pos for the click.
Visibility wait added
browser_tests/tests/vueNodes/interactions/node/contextMenu.spec.ts
Added an explicit wait for the first img inside [data-node-id] to be visible before proceeding with image context-menu actions.
Drag-and-drop upload sync
browser_tests/tests/widget.spec.ts
Passed waitForUpload: true to dragAndDropFile(...) and removed an immediate nextFrame() call; upload now awaited.
Direct input fill for zoom test
browser_tests/tests/zoomControls.spec.ts
Replaced sequential keypress/select approach with input.fill('100') for zoom percentage entry.

Estimated code review effort

🎯 3 (Moderate) | ⏱️ ~25 minutes

Poem

🐰
I hopped through tests with eager paws,
Waiting, polling, fixing small flaws.
Clicks that find their drifting spot,
Uploads that finish — tidy plot.
Hooray, the garden's steadier now! 🥕✨

🚥 Pre-merge checks | ✅ 4 | ❌ 1

❌ Failed checks (1 warning)

Check name Status Explanation Resolution
Description check ⚠️ Warning The description is incomplete compared to the template. It is missing the detailed 'Changes' section with 'What', 'Breaking', and 'Dependencies' subsections, and the 'Review Focus' section is absent. Only a basic summary is provided. Expand the description to follow the template structure: add a detailed 'Changes' section explaining what was modified and why, include 'Review Focus' section highlighting critical areas requiring review, and add specific issue number reference if applicable.
✅ Passed checks (4 passed)
Check name Status Explanation
Title check ✅ Passed The title 'test: stabilize flaky Playwright tests' directly and clearly summarizes the main change—fixing flaky e2e tests through improved test reliability across multiple test files.
Docstring Coverage ✅ Passed Docstring coverage is 100.00% which is sufficient. The required threshold is 80.00%.
End-To-End Regression Coverage For Fixes ✅ Passed PR title and commit subjects avoid bug-fix language, and PR modifies multiple test files under browser_tests/ directory with polling mechanisms to address flakiness.
Adr Compliance For Entity/Litegraph Changes ✅ Passed All changes are in browser_tests/ and playwright.config.ts; no modifications to src/lib/litegraph/, src/ecs/, or graph entity files.

✏️ Tip: You can configure your own custom pre-merge checks in the settings.

✨ Finishing Touches
📝 Generate docstrings
  • Create stacked PR
  • Commit on current branch
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Commit unit tests in branch drjkl/test/the-active-ingredient-is-selenium

Comment @coderabbitai help to get the list of available commands and usage tips.

@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 2, 2026

🎭 Playwright: ❌ 911 passed, 1 failed · 2 flaky

❌ Failed Tests

📊 Browser Reports
  • chromium: View Report (✅ 897 / ❌ 1 / ⚠️ 2 / ⏭️ 1)
  • chromium-2x: View Report (✅ 2 / ❌ 0 / ⚠️ 0 / ⏭️ 0)
  • chromium-0.5x: View Report (✅ 1 / ❌ 0 / ⚠️ 0 / ⏭️ 0)
  • mobile-chrome: View Report (✅ 11 / ❌ 0 / ⚠️ 0 / ⏭️ 0)

coderabbitai[bot]
coderabbitai bot previously approved these changes Apr 2, 2026
- proxyWidgets stale-read (3 tests): wrap assertions in toPass()/expect.poll()
- changeTracker undo race: use expect.poll() for async undo assertions
- rerouteNode timeout: replace hardcoded 8px click target with dynamic renderedPaths lookup
- contextMenu image timeout: wait for img visible before interacting
- widget animated webp: add waitForUpload: true to drag-and-drop
- zoomControls input race: use fill() instead of pressSequentially

Amp-Thread-ID: https://ampcode.com/threads/T-019d4c4c-4dbc-7120-9f90-f03f19d78a63
Co-authored-by: Amp <amp@ampcode.com>
Copy link
Copy Markdown
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🧹 Nitpick comments (1)
browser_tests/tests/vueNodes/interactions/node/contextMenu.spec.ts (1)

225-228: Use a preview-specific readiness wait instead of a generic node image selector.

Line 226 waits on the first [data-node-id] img, which can resolve to a non-preview image and still leave image actions flaky. Please target the actual preview image and poll until it has a usable src.

Proposed change
-      await comfyPage.page
-        .locator('[data-node-id] img')
-        .first()
-        .waitFor({ state: 'visible' })
+      const imagePreview = comfyPage.page.locator('.image-preview img').first()
+      await expect(imagePreview).toBeVisible()
+      await expect.poll(async () => imagePreview.getAttribute('src')).toBeTruthy()

As per coding guidelines: “Follow Playwright best practices as documented in @docs/guidance/playwright.md.”

🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In `@browser_tests/tests/vueNodes/interactions/node/contextMenu.spec.ts` around
lines 225 - 228, The current wait uses comfyPage.page.locator('[data-node-id]
img').first().waitFor(...) which can match non-preview images; change it to
target the actual preview image locator (e.g., the preview image element inside
the node preview) and poll its src until it's a usable value rather than just
visible. Replace the generic selector with the preview-specific selector used
elsewhere in the test suite (use the preview image locator) and loop/await until
locator.getAttribute('src') returns a non-empty/valid URL (not a placeholder
like data:), using Playwright polling (e.g., waitForFunction or repeated
getAttribute checks) instead of first().waitFor to ensure the preview image is
ready before proceeding.
🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.

Nitpick comments:
In `@browser_tests/tests/vueNodes/interactions/node/contextMenu.spec.ts`:
- Around line 225-228: The current wait uses
comfyPage.page.locator('[data-node-id] img').first().waitFor(...) which can
match non-preview images; change it to target the actual preview image locator
(e.g., the preview image element inside the node preview) and poll its src until
it's a usable value rather than just visible. Replace the generic selector with
the preview-specific selector used elsewhere in the test suite (use the preview
image locator) and loop/await until locator.getAttribute('src') returns a
non-empty/valid URL (not a placeholder like data:), using Playwright polling
(e.g., waitForFunction or repeated getAttribute checks) instead of
first().waitFor to ensure the preview image is ready before proceeding.

ℹ️ Review info
⚙️ Run configuration

Configuration used: Path: .coderabbit.yaml

Review profile: CHILL

Plan: Pro

Run ID: 0376b44f-0ac8-4c77-9e84-0d159ead9e34

📥 Commits

Reviewing files that changed from the base of the PR and between 8afcf6c and 751df14.

📒 Files selected for processing (8)
  • browser_tests/helpers/builderTestUtils.ts
  • browser_tests/tests/changeTracker.spec.ts
  • browser_tests/tests/rerouteNode.spec.ts
  • browser_tests/tests/subgraph/subgraphPromotion.spec.ts
  • browser_tests/tests/subgraph/subgraphPromotionDom.spec.ts
  • browser_tests/tests/vueNodes/interactions/node/contextMenu.spec.ts
  • browser_tests/tests/widget.spec.ts
  • browser_tests/tests/zoomControls.spec.ts

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant