Skip to content

refactor(test): extract dialog page objects from inline getByRole usage#10822

Open
dante01yoon wants to merge 2 commits intomainfrom
refactor/dialog-page-objects-v2
Open

refactor(test): extract dialog page objects from inline getByRole usage#10822
dante01yoon wants to merge 2 commits intomainfrom
refactor/dialog-page-objects-v2

Conversation

@dante01yoon
Copy link
Copy Markdown
Collaborator

@dante01yoon dante01yoon commented Apr 2, 2026

Summary

Extract inline getByRole('dialog') calls across E2E tests into reusable page objects.

Changes

  • What: Extract ConfirmDialog class from ComfyPage.ts into browser_tests/fixtures/components/ConfirmDialog.ts with new save button locator. Add MediaLightbox and TemplatesDialog page objects. Refactor 4 test files to use these page objects instead of raw dialog locators.
  • Skipped: appModeDropdownClipping.spec.ts uses getByRole('dialog') for a PrimeVue Popover (not a true dialog), left as-is.

Review Focus

The ConfirmDialog.click() method now supports a save action used by workflowPersistence.spec.ts, which also waits for the dialog mask to disappear and workflow service to settle.

Fixes #10723

┆Issue is synchronized with this Notion page by Unito

Extract ConfirmDialog from ComfyPage.ts into its own component file and
add MediaLightbox and TemplatesDialog page objects. Refactor tests to use
these page objects instead of inline getByRole('dialog') calls.
@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 2, 2026

🎨 Storybook: ✅ Built — View Storybook

Details

⏰ Completed at: 04/02/2026, 11:28:11 AM UTC

Links

@coderabbitai
Copy link
Copy Markdown
Contributor

coderabbitai bot commented Apr 2, 2026

📝 Walkthrough

Walkthrough

Extracts inline dialog lookups into three Playwright page-object classes (ConfirmDialog, MediaLightbox, TemplatesDialog), imports and instantiates them on ComfyPage, and updates tests to use these page-object properties instead of direct getByRole('dialog') queries.

Changes

Cohort / File(s) Summary
New Dialog & Lightbox Page Objects
browser_tests/fixtures/components/ConfirmDialog.ts, browser_tests/fixtures/components/MediaLightbox.ts, browser_tests/fixtures/components/TemplatesDialog.ts
Three new page-object classes added. ConfirmDialog exposes typed locators (root, delete, overwrite, reject, confirm, save) and an async click() that waits for dialog hide and workflow idle. MediaLightbox exposes root and closeButton. TemplatesDialog exposes root, filterByHeading() and getCombobox().
ComfyPage Refactor
browser_tests/fixtures/ComfyPage.ts
Removed local ConfirmDialog/KeysOfType implementation; imported and instantiated ConfirmDialog, MediaLightbox, and TemplatesDialog; added public templatesDialog and mediaLightbox properties and switched confirmDialog to the imported class.
Test Updates to Use Page Objects
browser_tests/tests/confirmDialogTextWrap.spec.ts, browser_tests/tests/resultGallery.spec.ts, browser_tests/tests/templates.spec.ts, browser_tests/tests/workflowPersistence.spec.ts
Replaced direct page.getByRole('dialog') locators with comfyPage.confirmDialog.root, comfyPage.mediaLightbox, or comfyPage.templatesDialog usages; adjusted assertions and interactions to use the new locators and confirmDialog.click() where applicable.

Estimated code review effort

🎯 3 (Moderate) | ⏱️ ~20 minutes

Poem

🐰 I hopped through code with nimble paws,
dialogs tamed by tidy laws,
Buttons found where rabbits peep,
No more wild getByRole to keep—
Tests now rest, my hop's complete. 🥕

🚥 Pre-merge checks | ✅ 6 | ❌ 1

❌ Failed checks (1 warning)

Check name Status Explanation Resolution
Docstring Coverage ⚠️ Warning Docstring coverage is 0.00% which is insufficient. The required threshold is 80.00%. Write docstrings for the functions missing them to satisfy the coverage threshold.
✅ Passed checks (6 passed)
Check name Status Explanation
Title check ✅ Passed The title accurately and concisely describes the main change: extracting dialog-related page objects from inline getByRole usage in E2E tests.
Description check ✅ Passed The description covers the summary, changes, and review focus sections. However, it lacks explicit detail on what breaking changes exist (none mentioned) and dependencies.
Linked Issues check ✅ Passed The PR successfully addresses all coding requirements from issue #10723: ConfirmDialog extracted with save button [10723], MediaLightbox and TemplatesDialog created [10723], four test files refactored [10723], and appModeDropdownClipping.spec.ts appropriately skipped [10723].
Out of Scope Changes check ✅ Passed All changes are directly aligned with issue #10723 objectives: page object extraction, test refactoring, and appropriate exception handling for PrimeVue Popover.
End-To-End Regression Coverage For Fixes ✅ Passed PR changes multiple files under browser_tests/ directory, satisfying the E2E regression coverage requirement despite fix language in commit message.
Adr Compliance For Entity/Litegraph Changes ✅ Passed PR contains no modifications to src/lib/litegraph/, src/ecs/, or graph entity-related files. All changes isolated to browser_tests/ directory.

✏️ 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 refactor/dialog-page-objects-v2

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

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: ✅ 899 passed, 0 failed · 9 flaky

📊 Browser Reports
  • chromium: View Report (✅ 885 / ❌ 0 / ⚠️ 9 / ⏭️ 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)

@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 2, 2026

📦 Bundle: 5.11 MB gzip 🟢 -44 B

Details

Summary

  • Raw size: 23.5 MB baseline 23.5 MB — ⚪ 0 B
  • Gzip: 5.11 MB baseline 5.11 MB — 🟢 -44 B
  • Brotli: 3.95 MB baseline 3.95 MB — 🟢 -190 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-B_JPjqn0.js (new) 22.3 kB 🔴 +22.3 kB 🔴 +7.95 kB 🔴 +6.84 kB
assets/index-BZS2_1T_.js (removed) 22.3 kB 🟢 -22.3 kB 🟢 -7.95 kB 🟢 -6.79 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-C_a5WZax.js (removed) 1.2 MB 🟢 -1.2 MB 🟢 -256 kB 🟢 -193 kB
assets/GraphView-WjxXbtY7.js (new) 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-B6Wv65v-.js (new) 15.7 kB 🔴 +15.7 kB 🔴 +3.4 kB 🔴 +2.9 kB
assets/CloudSurveyView-C7Xr5uQb.js (removed) 15.7 kB 🟢 -15.7 kB 🟢 -3.4 kB 🟢 -2.9 kB
assets/CloudLoginView-BazK2WD7.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-C8DgoGav.js (new) 9.78 kB 🔴 +9.78 kB 🔴 +2.85 kB 🔴 +2.49 kB
assets/CloudSignupView-Cg1NGub1.js (removed) 9.78 kB 🟢 -9.78 kB 🟢 -2.85 kB 🟢 -2.5 kB
assets/UserCheckView-C0nHPOJH.js (removed) 9.04 kB 🟢 -9.04 kB 🟢 -2.33 kB 🟢 -2.03 kB
assets/UserCheckView-DYe_u400.js (new) 9.04 kB 🔴 +9.04 kB 🔴 +2.33 kB 🔴 +2.06 kB
assets/CloudLayoutView-Bs_pvIgh.js (new) 7.54 kB 🔴 +7.54 kB 🔴 +2.36 kB 🔴 +2.04 kB
assets/CloudLayoutView-YtKOkN9X.js (removed) 7.54 kB 🟢 -7.54 kB 🟢 -2.36 kB 🟢 -2.05 kB
assets/CloudForgotPasswordView-DbGlaD65.js (removed) 5.94 kB 🟢 -5.94 kB 🟢 -2.09 kB 🟢 -1.87 kB
assets/CloudForgotPasswordView-uN0F9iJF.js (new) 5.94 kB 🔴 +5.94 kB 🔴 +2.09 kB 🔴 +1.84 kB
assets/CloudAuthTimeoutView-ChhQ4KDP.js (removed) 5.31 kB 🟢 -5.31 kB 🟢 -1.93 kB 🟢 -1.69 kB
assets/CloudAuthTimeoutView-DL2upWQ_.js (new) 5.31 kB 🔴 +5.31 kB 🔴 +1.93 kB 🔴 +1.69 kB
assets/CloudSubscriptionRedirectView-BrFruYVl.js (new) 5.08 kB 🔴 +5.08 kB 🔴 +1.9 kB 🔴 +1.68 kB
assets/CloudSubscriptionRedirectView-DQ2oJagK.js (removed) 5.08 kB 🟢 -5.08 kB 🟢 -1.91 kB 🟢 -1.69 kB
assets/UserSelectView-A4BPvD-b.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-eyDufHNb.js (removed) 46.6 kB 🟢 -46.6 kB 🟢 -9.52 kB 🟢 -8.47 kB
assets/KeybindingPanel-T1305IJ9.js (new) 46.6 kB 🔴 +46.6 kB 🔴 +9.52 kB 🔴 +8.47 kB
assets/SecretsPanel-BTdXN5QH.js (removed) 22.4 kB 🟢 -22.4 kB 🟢 -5.43 kB 🟢 -4.77 kB
assets/SecretsPanel-DVmxZ29h.js (new) 22.4 kB 🔴 +22.4 kB 🔴 +5.43 kB 🔴 +4.76 kB
assets/LegacyCreditsPanel-B6lIhib4.js (new) 21.5 kB 🔴 +21.5 kB 🔴 +5.81 kB 🔴 +5.13 kB
assets/LegacyCreditsPanel-Cx7X8Ugl.js (removed) 21.5 kB 🟢 -21.5 kB 🟢 -5.81 kB 🟢 -5.13 kB
assets/SubscriptionPanel-CN9duWJ6.js (new) 19.7 kB 🔴 +19.7 kB 🔴 +5.01 kB 🔴 +4.4 kB
assets/SubscriptionPanel-k8153Ye7.js (removed) 19.7 kB 🟢 -19.7 kB 🟢 -5.01 kB 🟢 -4.41 kB
assets/AboutPanel-D2sQvHna.js (removed) 12 kB 🟢 -12 kB 🟢 -3.33 kB 🟢 -2.98 kB
assets/AboutPanel-fNuj-6qm.js (new) 12 kB 🔴 +12 kB 🔴 +3.33 kB 🔴 +3 kB
assets/ExtensionPanel-3He-wyM1.js (removed) 9.78 kB 🟢 -9.78 kB 🟢 -2.82 kB 🟢 -2.51 kB
assets/ExtensionPanel-egf5r7hL.js (new) 9.78 kB 🔴 +9.78 kB 🔴 +2.82 kB 🔴 +2.5 kB
assets/ServerConfigPanel-CXPxxrBH.js (removed) 6.85 kB 🟢 -6.85 kB 🟢 -2.27 kB 🟢 -2.03 kB
assets/ServerConfigPanel-DylPfgQu.js (new) 6.85 kB 🔴 +6.85 kB 🔴 +2.27 kB 🔴 +2.05 kB
assets/UserPanel-BsNs94Hs.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-D6JuW4PX.js (new) 1.85 kB 🔴 +1.85 kB 🔴 +901 B 🔴 +786 B
assets/refreshRemoteConfig-D-WXidlx.js (new) 1.45 kB 🔴 +1.45 kB 🔴 +648 B 🔴 +551 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-GWqgT04T.js (removed) 3.57 kB 🟢 -3.57 kB 🟢 -1.26 kB 🟢 -1.07 kB
assets/auth-I3Wyq5Dg.js (new) 3.57 kB 🔴 +3.57 kB 🔴 +1.26 kB 🔴 +1.08 kB
assets/SignUpForm-CLtpQ9vB.js (removed) 3.16 kB 🟢 -3.16 kB 🟢 -1.29 kB 🟢 -1.14 kB
assets/SignUpForm-DMYq5A4S.js (new) 3.16 kB 🔴 +3.16 kB 🔴 +1.29 kB 🔴 +1.14 kB
assets/UpdatePasswordContent-BF_WeHlL.js (removed) 2.66 kB 🟢 -2.66 kB 🟢 -1.19 kB 🟢 -1.05 kB
assets/UpdatePasswordContent-oibt7RO2.js (new) 2.66 kB 🔴 +2.66 kB 🔴 +1.19 kB 🔴 +1.06 kB
assets/authStore-CgmJUvO5.js (new) 989 B 🔴 +989 B 🔴 +485 B 🔴 +432 B
assets/authStore-Dt3w8-RF.js (removed) 989 B 🟢 -989 B 🟢 -484 B 🟢 -433 B
assets/auth-BmWkLNAX.js (removed) 348 B 🟢 -348 B 🟢 -218 B 🟢 -192 B
assets/auth-FQpckzcl.js (new) 348 B 🔴 +348 B 🔴 +219 B 🔴 +189 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-BhqUfLBm.js (new) 108 kB 🔴 +108 kB 🔴 +22.4 kB 🔴 +18.9 kB
assets/useSubscriptionDialog-Csz5AHKW.js (new) 969 B 🔴 +969 B 🔴 +475 B 🔴 +415 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-DMkIMyu6.js (new) 13.5 kB 🔴 +13.5 kB 🔴 +3.79 kB 🔴 +3.38 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-ChnfOFjc.js (new) 10.7 kB 🔴 +10.7 kB 🔴 +3.6 kB 🔴 +3.16 kB
assets/SubscribeButton-_lUPJoSy.js (removed) 2.42 kB 🟢 -2.42 kB 🟢 -1.04 kB 🟢 -914 B
assets/SubscribeButton-CtyIxUKd.js (new) 2.42 kB 🔴 +2.42 kB 🔴 +1.04 kB 🔴 +915 B
assets/cloudFeedbackTopbarButton-BlOC1cOI.js (new) 1.66 kB 🔴 +1.66 kB 🔴 +844 B 🔴 +760 B
assets/cloudFeedbackTopbarButton-C-XPHAZs.js (removed) 1.66 kB 🟢 -1.66 kB 🟢 -842 B 🟢 -748 B
assets/ComfyQueueButton-CQhrKSzu.js (removed) 1.03 kB 🟢 -1.03 kB 🟢 -490 B 🟢 -436 B
assets/ComfyQueueButton-j31fe232.js (new) 1.03 kB 🔴 +1.03 kB 🔴 +488 B 🔴 +437 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-DN-Pj-xS.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-D-kSEPdV.js (new) 885 kB 🔴 +885 kB 🔴 +211 kB 🔴 +166 kB
assets/load3dService-CJwtgilB.js (new) 92.5 kB 🔴 +92.5 kB 🔴 +19.7 kB 🔴 +17 kB
assets/load3dService-CrlQdqyx.js (removed) 92.5 kB 🟢 -92.5 kB 🟢 -19.7 kB 🟢 -16.9 kB
assets/workflowShareService-BgsP6Oww.js (new) 16.6 kB 🔴 +16.6 kB 🔴 +4.88 kB 🔴 +4.34 kB
assets/workflowShareService-C4yDSmQb.js (removed) 16.6 kB 🟢 -16.6 kB 🟢 -4.88 kB 🟢 -4.32 kB
assets/keybindingService-BcXL4edm.js (new) 13.8 kB 🔴 +13.8 kB 🔴 +3.66 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-sPShlM-Y.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-DOOePsDe.js (new) 2.24 kB 🔴 +2.24 kB 🔴 +868 B 🔴 +769 B
assets/audioService-Bp7soHYz.js (new) 1.8 kB 🔴 +1.8 kB 🔴 +878 B 🔴 +758 B
assets/audioService-C3uEdD3D.js (removed) 1.8 kB 🟢 -1.8 kB 🟢 -877 B 🟢 -762 B
assets/releaseStore-BNl0_9yf.js (new) 993 B 🔴 +993 B 🔴 +479 B 🔴 +428 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-CLOn48EN.js (new) 969 B 🔴 +969 B 🔴 +474 B 🔴 +422 B
assets/dialogService-CmrIIKQX.js (new) 958 B 🔴 +958 B 🔴 +467 B 🔴 +416 B
assets/dialogService-hDtzEvpe.js (removed) 958 B 🟢 -958 B 🟢 -467 B 🟢 -419 B
assets/settingStore-C88H2Id2.js (new) 956 B 🔴 +956 B 🔴 +470 B 🔴 +416 B
assets/settingStore-Dwb_XVL9.js (removed) 956 B 🟢 -956 B 🟢 -471 B 🟢 -417 B
assets/assetsStore-CzJYVyR-.js (removed) 955 B 🟢 -955 B 🟢 -471 B 🟢 -420 B
assets/assetsStore-DLmKolfi.js (new) 955 B 🔴 +955 B 🔴 +470 B 🔴 +418 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-X5IZCFev.js (new) 232 kB 🔴 +232 kB 🔴 +51.3 kB 🔴 +41.8 kB
assets/useLoad3dViewer-59JLE_lz.js (new) 18.7 kB 🔴 +18.7 kB 🔴 +4.44 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-DdnCrgEe.js (new) 15 kB 🔴 +15 kB 🔴 +3.79 kB 🔴 +3.35 kB
assets/useFeatureFlags-DVvMoTXo.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-D5qZ4LP6.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-BBN8N8ep.js (new) 3.34 kB 🔴 +3.34 kB 🔴 +981 B 🔴 +806 B
assets/useWorkspaceUI-Cvx-xzC6.js (removed) 3.34 kB 🟢 -3.34 kB 🟢 -982 B 🟢 -815 B
assets/subscriptionCheckoutUtil-CeHIIhsy.js (removed) 2.97 kB 🟢 -2.97 kB 🟢 -1.31 kB 🟢 -1.14 kB
assets/subscriptionCheckoutUtil-CsDF9edj.js (new) 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-DjVEa5qO.js (new) 2.27 kB 🔴 +2.27 kB 🔴 +957 B 🔴 +834 B
assets/useUpstreamValue-BZI4FwvP.js (removed) 2.08 kB 🟢 -2.08 kB 🟢 -804 B 🟢 -715 B
assets/useUpstreamValue-CbRt8qa7.js (new) 2.08 kB 🔴 +2.08 kB 🔴 +804 B 🔴 +712 B
assets/useLoad3d-Cb-_1cmQ.js (removed) 1.13 kB 🟢 -1.13 kB 🟢 -541 B 🟢 -481 B
assets/useLoad3d-D8uKU6b-.js (new) 1.13 kB 🔴 +1.13 kB 🔴 +537 B 🔴 +483 B
assets/useLoad3dViewer-1-M-ZLu0.js (removed) 1.07 kB 🟢 -1.07 kB 🟢 -506 B 🟢 -454 B
assets/useLoad3dViewer-DjH6ggjW.js (new) 1.07 kB 🔴 +1.07 kB 🔴 +505 B 🔴 +453 B
assets/useCurrentUser-B9m2zi43.js (new) 955 B 🔴 +955 B 🔴 +470 B 🔴 +415 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-DklGu_yo.js (new) 747 B 🔴 +747 B 🔴 +383 B 🔴 +333 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-DE7maGKP.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-gPSCclIk.js (new) 74 kB 🔴 +74 kB 🔴 +18.5 kB 🔴 +16.3 kB
assets/WidgetSelect-Bb0k3hSF.js (removed) 64.6 kB 🟢 -64.6 kB 🟢 -14.1 kB 🟢 -12.2 kB
assets/WidgetSelect-BM5hH3xO.js (new) 64.6 kB 🔴 +64.6 kB 🔴 +14.1 kB 🔴 +12.2 kB
assets/SubscriptionRequiredDialogContentWorkspace-DgQ7Y0oP.js (removed) 48.9 kB 🟢 -48.9 kB 🟢 -9.29 kB 🟢 -7.95 kB
assets/SubscriptionRequiredDialogContentWorkspace-uRAgBsYZ.js (new) 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-BSGyw5DK.js (new) 33.3 kB 🔴 +33.3 kB 🔴 +8.11 kB 🔴 +7.2 kB
assets/Load3DControls-CBSbu7hl.js (removed) 32.1 kB 🟢 -32.1 kB 🟢 -5.47 kB 🟢 -4.75 kB
assets/Load3DControls-CJ2MQ3zI.js (new) 32.1 kB 🔴 +32.1 kB 🔴 +5.47 kB 🔴 +4.76 kB
assets/WorkspacePanelContent-B1yz6jcc.js (new) 29.9 kB 🔴 +29.9 kB 🔴 +6.33 kB 🔴 +5.56 kB
assets/WorkspacePanelContent-DQjc2bzh.js (removed) 29.9 kB 🟢 -29.9 kB 🟢 -6.32 kB 🟢 -5.55 kB
assets/SubscriptionRequiredDialogContent-BGsru0oN.js (new) 28.2 kB 🔴 +28.2 kB 🔴 +7.17 kB 🔴 +6.29 kB
assets/SubscriptionRequiredDialogContent-Ck4xIwBd.js (removed) 28.2 kB 🟢 -28.2 kB 🟢 -7.16 kB 🟢 -6.3 kB
assets/Load3dViewerContent-Cu2Kxe_S.js (new) 24.5 kB 🔴 +24.5 kB 🔴 +5.33 kB 🔴 +4.63 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-KuZmLhei.js (new) 23.3 kB 🔴 +23.3 kB 🔴 +5.83 kB 🔴 +5.14 kB
assets/SubscriptionPanelContentWorkspace-CXpEjPbW.js (removed) 22.2 kB 🟢 -22.2 kB 🟢 -5.18 kB 🟢 -4.57 kB
assets/SubscriptionPanelContentWorkspace-DRXcYp3H.js (new) 22.2 kB 🔴 +22.2 kB 🔴 +5.18 kB 🔴 +4.55 kB
assets/SignInContent-D8nET2XW.js (new) 20.4 kB 🔴 +20.4 kB 🔴 +5.29 kB 🔴 +4.64 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-CpswcE6j.js (new) 20.4 kB 🔴 +20.4 kB 🔴 +4.83 kB 🔴 +4.33 kB
assets/WidgetInputNumber-BmX6ZrX9.js (new) 19.1 kB 🔴 +19.1 kB 🔴 +4.84 kB 🔴 +4.3 kB
assets/WidgetInputNumber-CySFVyW8.js (removed) 19.1 kB 🟢 -19.1 kB 🟢 -4.84 kB 🟢 -4.3 kB
assets/WidgetRecordAudio-CzVWx_OT.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-BXL3iX6p.js (new) 16.9 kB 🔴 +16.9 kB 🔴 +4.11 kB 🔴 +3.58 kB
assets/Load3D-uq9yuomV.js (removed) 16.9 kB 🟢 -16.9 kB 🟢 -4.12 kB 🟢 -3.6 kB
assets/load3d-B5Y5wnBu.js (new) 15 kB 🔴 +15 kB 🔴 +4.32 kB 🔴 +3.73 kB
assets/load3d-C9d_Teis.js (removed) 15 kB 🟢 -15 kB 🟢 -4.32 kB 🟢 -3.73 kB
assets/WaveAudioPlayer-ntKWg0Hr.js (new) 13.4 kB 🔴 +13.4 kB 🔴 +3.69 kB 🔴 +3.21 kB
assets/WaveAudioPlayer-R3OFvCck.js (removed) 13.4 kB 🟢 -13.4 kB 🟢 -3.69 kB 🟢 -3.22 kB
assets/WidgetCurve-1vd-yY7v.js (new) 12 kB 🔴 +12 kB 🔴 +3.85 kB 🔴 +3.48 kB
assets/WidgetCurve-CmSDxj2S.js (removed) 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-isg9Khai.js (new) 11.1 kB 🔴 +11.1 kB 🔴 +3.33 kB 🔴 +2.97 kB
assets/nodeTemplates-D8F3K3Cj.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-jo9tw0_t.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-C6SRkUj-.js (new) 6.6 kB 🔴 +6.6 kB 🔴 +2.04 kB 🔴 +1.78 kB
assets/onboardingCloudRoutes-BGL7dF4w.js (removed) 6.53 kB 🟢 -6.53 kB 🟢 -2.04 kB 🟢 -1.77 kB
assets/onboardingCloudRoutes-CqLA1-q0.js (new) 6.53 kB 🔴 +6.53 kB 🔴 +2.04 kB 🔴 +1.77 kB
assets/WidgetWithControl-6bv0PMlu.js (new) 5.99 kB 🔴 +5.99 kB 🔴 +2.38 kB 🔴 +2.13 kB
assets/WidgetWithControl-6pGdAyhk.js (removed) 5.99 kB 🟢 -5.99 kB 🟢 -2.39 kB 🟢 -2.13 kB
assets/CreateWorkspaceDialogContent-C5lQfIee.js (new) 5.95 kB 🔴 +5.95 kB 🔴 +2.15 kB 🔴 +1.87 kB
assets/CreateWorkspaceDialogContent-GOS6NgU7.js (removed) 5.95 kB 🟢 -5.95 kB 🟢 -2.15 kB 🟢 -1.87 kB
assets/FreeTierDialogContent-DU9ZvL5d.js (new) 5.82 kB 🔴 +5.82 kB 🔴 +2.05 kB 🔴 +1.81 kB
assets/FreeTierDialogContent-edsnllXJ.js (removed) 5.82 kB 🟢 -5.82 kB 🟢 -2.04 kB 🟢 -1.81 kB
assets/EditWorkspaceDialogContent-ChwFF2hL.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-BvDT8bsx.js (new) 5.53 kB 🔴 +5.53 kB 🔴 +2.17 kB 🔴 +1.93 kB
assets/Preview3d-CX2sK-nL.js (new) 5.36 kB 🔴 +5.36 kB 🔴 +1.79 kB 🔴 +1.55 kB
assets/Preview3d-Dlfz31wy.js (removed) 5.36 kB 🟢 -5.36 kB 🟢 -1.79 kB 🟢 -1.56 kB
assets/ValueControlPopover-DdMinfPf.js (new) 5.33 kB 🔴 +5.33 kB 🔴 +1.93 kB 🔴 +1.73 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-gJO8EinQ.js (new) 5.22 kB 🔴 +5.22 kB 🔴 +1.95 kB 🔴 +1.7 kB
assets/DeleteWorkspaceDialogContent-DVidMgQl.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-BwImhbaN.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-DQJMhCGl.js (new) 4.46 kB 🔴 +4.46 kB 🔴 +1.69 kB 🔴 +1.47 kB
assets/tierBenefits-CwmAHNyB.js (new) 4.45 kB 🔴 +4.45 kB 🔴 +1.58 kB 🔴 +1.36 kB
assets/tierBenefits-DxCK7Xcl.js (removed) 4.45 kB 🟢 -4.45 kB 🟢 -1.58 kB 🟢 -1.36 kB
assets/RevokeInviteDialogContent-Dc7YfMiW.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-BdqoZO40.js (removed) 4.27 kB 🟢 -4.27 kB 🟢 -1.56 kB 🟢 -1.37 kB
assets/InviteMemberUpsellDialogContent-DX3qWaT5.js (new) 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-DncsUcZ-.js (new) 4.12 kB 🔴 +4.12 kB 🔴 +1.49 kB 🔴 +1.3 kB
assets/saveMesh-DMsoEE2V.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-CifyFEWU.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-D7f455Ml.js (new) 3.05 kB 🔴 +3.05 kB 🔴 +1.26 kB 🔴 +1.08 kB
assets/SubscribeToRun-B9I3YAhq.js (new) 2.13 kB 🔴 +2.13 kB 🔴 +985 B 🔴 +874 B
assets/SubscribeToRun-DnZdU5Jz.js (removed) 2.13 kB 🟢 -2.13 kB 🟢 -984 B 🟢 -881 B
assets/MediaAudioTop-Cs4lAh42.js (new) 2.02 kB 🔴 +2.02 kB 🔴 +983 B 🔴 +833 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-Cyww5U4q.js (new) 1.99 kB 🔴 +1.99 kB 🔴 +910 B 🔴 +803 B
assets/graphHasMissingNodes-CfaeeSYw.js (new) 1.83 kB 🔴 +1.83 kB 🔴 +861 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-s88PwCiv.js (new) 1.77 kB 🔴 +1.77 kB 🔴 +889 B 🔴 +789 B
assets/cloudSubscription-f6FYoWlw.js (removed) 1.68 kB 🟢 -1.68 kB 🟢 -812 B 🟢 -705 B
assets/cloudSubscription-N8_IvAex.js (new) 1.68 kB 🔴 +1.68 kB 🔴 +813 B 🔴 +707 B
assets/previousFullPath-C5uurzR6.js (removed) 1.53 kB 🟢 -1.53 kB 🟢 -694 B 🟢 -607 B
assets/previousFullPath-CqXas_7B.js (new) 1.53 kB 🔴 +1.53 kB 🔴 +694 B 🔴 +605 B
assets/Load3D-DmwA-wwt.js (removed) 1.34 kB 🟢 -1.34 kB 🟢 -612 B 🟢 -546 B
assets/Load3D-jW9iKgse.js (new) 1.34 kB 🔴 +1.34 kB 🔴 +610 B 🔴 +541 B
assets/nightlyBadges-ChiT474A.js (removed) 1.29 kB 🟢 -1.29 kB 🟢 -657 B 🟢 -579 B
assets/nightlyBadges-CqcpvWgD.js (new) 1.29 kB 🔴 +1.29 kB 🔴 +656 B 🔴 +581 B
assets/Load3dViewerContent-CL7fN7Bd.js (new) 1.23 kB 🔴 +1.23 kB 🔴 +563 B 🔴 +496 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-DCx2bPwd.js (new) 1.15 kB 🔴 +1.15 kB 🔴 +534 B 🔴 +470 B
assets/WidgetLegacy-DF9UgzlM.js (removed) 978 B 🟢 -978 B 🟢 -481 B 🟢 -423 B
assets/WidgetLegacy-Dtluov02.js (new) 978 B 🔴 +978 B 🔴 +481 B 🔴 +422 B
assets/changeTracker-BBpTrdtT.js (removed) 952 B 🟢 -952 B 🟢 -471 B 🟢 -417 B
assets/changeTracker-Bxco5S_8.js (new) 952 B 🔴 +952 B 🔴 +470 B 🔴 +417 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.2 MB heap
canvas-mouse-sweep: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 56.3 MB heap
canvas-zoom-sweep: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 64.4 MB heap
dom-widget-clipping: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 47.2 MB heap
large-graph-idle: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 63.8 MB heap
large-graph-pan: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 69.4 MB heap
large-graph-zoom: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 61.5 MB heap
minimap-idle: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 53.9 MB heap
subgraph-dom-widget-clipping: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 47.3 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.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 52.4 MB heap
viewport-pan-sweep: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 72.4 MB heap
vue-large-graph-idle: · 58.1 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 158.9 MB heap
vue-large-graph-pan: · 56.2 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 163.5 MB heap
workflow-execution: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 47.6 MB heap

⚠️ 9 regressions detected

Metric Baseline PR (median) Δ Sig
canvas-zoom-sweep: layout duration 1ms 1ms +13% ⚠️ z=2.2
canvas-zoom-sweep: task duration 369ms 385ms +4% ⚠️ z=2.5
canvas-zoom-sweep: script duration 34ms 37ms +10% ⚠️ z=3.2
large-graph-pan: task duration 1232ms 1243ms +1% ⚠️ z=3.7
minimap-idle: task duration 636ms 629ms -1% ⚠️ z=2.1
subgraph-idle: task duration 421ms 445ms +6% ⚠️ z=2.4
subgraph-idle: script duration 23ms 27ms +19% ⚠️ z=2.7
subgraph-mouse-sweep: style recalc duration 52ms 50ms -5% ⚠️ z=2.1
subgraph-mouse-sweep: task duration 1009ms 955ms -5% ⚠️ z=2.7
All metrics
Metric Baseline PR (median) Δ Sig
canvas-idle: avg frame time 17ms 17ms +0% z=-0.1
canvas-idle: p95 frame time 17ms 17ms +0%
canvas-idle: layout duration 0ms 0ms +0%
canvas-idle: style recalc duration 10ms 12ms +15% z=0.8
canvas-idle: layout count 0 0 +0%
canvas-idle: style recalc count 10 11 +10% z=-0.3
canvas-idle: task duration 383ms 441ms +15% z=1.5
canvas-idle: script duration 28ms 25ms -12% z=-0.3
canvas-idle: TBT 0ms 0ms +0%
canvas-idle: heap used 61.1 MB 60.2 MB -1%
canvas-idle: DOM nodes 20 22 +10% z=-0.5
canvas-idle: event listeners 6 6 +0% z=-1.2
canvas-mouse-sweep: avg frame time 17ms 17ms +0% z=-0.4
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 44ms -8% z=0.3
canvas-mouse-sweep: layout count 12 12 +0%
canvas-mouse-sweep: style recalc count 82 77 -6% z=-0.7
canvas-mouse-sweep: task duration 997ms 856ms -14% z=-0.2
canvas-mouse-sweep: script duration 138ms 147ms +6% z=1.8
canvas-mouse-sweep: TBT 0ms 0ms +0%
canvas-mouse-sweep: heap used 63.8 MB 56.3 MB -12%
canvas-mouse-sweep: DOM nodes 65 60 -8% z=-0.9
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 +1%
canvas-zoom-sweep: layout duration 1ms 1ms +13% ⚠️ z=2.2
canvas-zoom-sweep: style recalc duration 19ms 20ms +1% z=0.3
canvas-zoom-sweep: layout count 6 6 +0%
canvas-zoom-sweep: style recalc count 31 31 +0% z=-0.6
canvas-zoom-sweep: task duration 369ms 385ms +4% ⚠️ z=2.5
canvas-zoom-sweep: script duration 34ms 37ms +10% ⚠️ z=3.2
canvas-zoom-sweep: TBT 0ms 0ms +0%
canvas-zoom-sweep: heap used 64.0 MB 64.4 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 +1%
dom-widget-clipping: layout duration 0ms 0ms +0%
dom-widget-clipping: style recalc duration 10ms 10ms -6% z=-0.0
dom-widget-clipping: layout count 0 0 +0%
dom-widget-clipping: style recalc count 13 12 -8% z=-2.2
dom-widget-clipping: task duration 370ms 378ms +2% z=0.8
dom-widget-clipping: script duration 65ms 72ms +11% z=1.3
dom-widget-clipping: TBT 0ms 0ms +0%
dom-widget-clipping: heap used 46.8 MB 47.2 MB +1%
dom-widget-clipping: DOM nodes 22 20 -9% z=-1.5
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 11ms +8% z=-1.5
large-graph-idle: layout count 0 0 +0%
large-graph-idle: style recalc count 10 10 +0% z=-5.1
large-graph-idle: task duration 680ms 629ms -8% z=1.6
large-graph-idle: script duration 118ms 117ms -1% z=1.4
large-graph-idle: TBT 0ms 0ms +0%
large-graph-idle: heap used 53.1 MB 63.8 MB +20%
large-graph-idle: DOM nodes -258 -257 -0% z=-311.7
large-graph-idle: event listeners -127 -129 +2% z=-25.4
large-graph-pan: avg frame time 17ms 17ms -0% z=-0.8
large-graph-pan: p95 frame time 17ms 17ms +0%
large-graph-pan: layout duration 0ms 0ms +0%
large-graph-pan: style recalc duration 19ms 16ms -17% z=-1.7
large-graph-pan: layout count 0 0 +0%
large-graph-pan: style recalc count 69 68 -1% z=-2.4
large-graph-pan: task duration 1232ms 1243ms +1% ⚠️ z=3.7
large-graph-pan: script duration 422ms 444ms +5% z=1.8
large-graph-pan: TBT 0ms 0ms +0%
large-graph-pan: heap used 68.1 MB 69.4 MB +2%
large-graph-pan: DOM nodes -262 -265 +1% z=-172.1
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 -1%
large-graph-zoom: layout duration 9ms 8ms -18%
large-graph-zoom: style recalc duration 20ms 17ms -13%
large-graph-zoom: layout count 60 60 +0%
large-graph-zoom: style recalc count 66 65 -2%
large-graph-zoom: task duration 1498ms 1433ms -4%
large-graph-zoom: script duration 550ms 525ms -4%
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 -266 +0%
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 +0%
minimap-idle: layout duration 0ms 0ms +0%
minimap-idle: style recalc duration 8ms 11ms +33% z=1.8
minimap-idle: layout count 0 0 +0%
minimap-idle: style recalc count 9 9 +0% z=-0.8
minimap-idle: task duration 636ms 629ms -1% ⚠️ z=2.1
minimap-idle: script duration 103ms 117ms +14% z=1.9
minimap-idle: TBT 0ms 0ms +0%
minimap-idle: heap used 54.5 MB 53.9 MB -1%
minimap-idle: DOM nodes -262 -261 -0% z=-204.8
minimap-idle: event listeners -127 -127 +0% z=-199.3
subgraph-dom-widget-clipping: avg frame time 17ms 17ms -0% z=-0.9
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 14ms +1% z=1.1
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 396ms +2% z=0.9
subgraph-dom-widget-clipping: script duration 135ms 130ms -4% z=0.3
subgraph-dom-widget-clipping: TBT 0ms 0ms +0%
subgraph-dom-widget-clipping: heap used 47.2 MB 47.3 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.7
subgraph-idle: p95 frame time 17ms 17ms +1%
subgraph-idle: layout duration 0ms 0ms +0%
subgraph-idle: style recalc duration 10ms 12ms +15% z=1.8
subgraph-idle: layout count 0 0 +0%
subgraph-idle: style recalc count 10 10 +0% z=-1.4
subgraph-idle: task duration 421ms 445ms +6% ⚠️ z=2.4
subgraph-idle: script duration 23ms 27ms +19% ⚠️ z=2.7
subgraph-idle: TBT 0ms 0ms +0%
subgraph-idle: heap used 60.1 MB 60.1 MB -0%
subgraph-idle: DOM nodes 20 20 +0% z=-1.2
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 +0%
subgraph-mouse-sweep: layout duration 5ms 5ms -4% z=0.8
subgraph-mouse-sweep: style recalc duration 52ms 50ms -5% ⚠️ z=2.1
subgraph-mouse-sweep: layout count 16 16 +0%
subgraph-mouse-sweep: style recalc count 88 84 -5% z=2.0
subgraph-mouse-sweep: task duration 1009ms 955ms -5% ⚠️ z=2.7
subgraph-mouse-sweep: script duration 114ms 110ms -3% z=1.4
subgraph-mouse-sweep: TBT 0ms 0ms +0%
subgraph-mouse-sweep: heap used 52.1 MB 52.4 MB +1%
subgraph-mouse-sweep: DOM nodes 74 72 -3% z=2.3
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 47ms -11%
viewport-pan-sweep: layout count 0 0 +0%
viewport-pan-sweep: style recalc count 251 251 +0%
viewport-pan-sweep: task duration 4166ms 4168ms +0%
viewport-pan-sweep: script duration 1327ms 1365ms +3%
viewport-pan-sweep: TBT 0ms 0ms +0%
viewport-pan-sweep: heap used 75.5 MB 72.4 MB -4%
viewport-pan-sweep: DOM nodes -255 -258 +1%
viewport-pan-sweep: event listeners -111 -109 -2%
vue-large-graph-idle: avg frame time 17ms 17ms -0%
vue-large-graph-idle: p95 frame time 17ms 17ms +0%
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 12901ms -6%
vue-large-graph-idle: script duration 602ms 655ms +9%
vue-large-graph-idle: TBT 0ms 0ms +0%
vue-large-graph-idle: heap used 157.7 MB 158.9 MB +1%
vue-large-graph-idle: DOM nodes -8331 -8331 +0%
vue-large-graph-idle: event listeners -16460 -16462 +0%
vue-large-graph-pan: avg frame time 18ms 18ms +0%
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 16ms -17%
vue-large-graph-pan: layout count 0 0 +0%
vue-large-graph-pan: style recalc count 83 72 -13%
vue-large-graph-pan: task duration 15933ms 14963ms -6%
vue-large-graph-pan: script duration 915ms 932ms +2%
vue-large-graph-pan: TBT 0ms 0ms +0%
vue-large-graph-pan: heap used 164.0 MB 163.5 MB -0%
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.6
workflow-execution: p95 frame time 17ms 17ms +0%
workflow-execution: layout duration 2ms 2ms -5% z=0.1
workflow-execution: style recalc duration 23ms 27ms +19% z=1.2
workflow-execution: layout count 4 5 +25% z=0.1
workflow-execution: style recalc count 16 20 +25% z=1.1
workflow-execution: task duration 113ms 140ms +24% z=1.6
workflow-execution: script duration 25ms 34ms +34% z=1.7
workflow-execution: TBT 0ms 0ms +0%
workflow-execution: heap used 46.2 MB 47.6 MB +3%
workflow-execution: DOM nodes 154 158 +3% z=-0.4
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-02T11:39:21.339Z",
  "gitSha": "e052622ded5cd22cd7f6aa619b45db8552e9f6eb",
  "branch": "refactor/dialog-page-objects-v2",
  "measurements": [
    {
      "name": "canvas-idle",
      "durationMs": 2015.1619999999753,
      "styleRecalcs": 8,
      "styleRecalcDurationMs": 9.312000000000001,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 441.423,
      "heapDeltaBytes": 20004700,
      "heapUsedBytes": 62635272,
      "domNodes": 16,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 24.674000000000003,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "canvas-idle",
      "durationMs": 2029.404999999997,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 11.522,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 407.381,
      "heapDeltaBytes": 20154104,
      "heapUsedBytes": 63160248,
      "domNodes": 22,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 24.232,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-idle",
      "durationMs": 2046.1039999999002,
      "styleRecalcs": 13,
      "styleRecalcDurationMs": 13.621,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 505.01399999999995,
      "heapDeltaBytes": 21087180,
      "heapUsedBytes": 64872324,
      "domNodes": 25,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 35.921,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 1954.2980000000512,
      "styleRecalcs": 78,
      "styleRecalcDurationMs": 48.259,
      "layouts": 12,
      "layoutDurationMs": 4.41,
      "taskDurationMs": 876.169,
      "heapDeltaBytes": 16277772,
      "heapUsedBytes": 60377412,
      "domNodes": 64,
      "jsHeapTotalBytes": 23855104,
      "scriptDurationMs": 148.68,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 1865.8179999999902,
      "styleRecalcs": 74,
      "styleRecalcDurationMs": 37.584999999999994,
      "layouts": 12,
      "layoutDurationMs": 3.439,
      "taskDurationMs": 806.43,
      "heapDeltaBytes": 16224392,
      "heapUsedBytes": 59063740,
      "domNodes": 57,
      "jsHeapTotalBytes": 23330816,
      "scriptDurationMs": 143.296,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 1896.4489999999614,
      "styleRecalcs": 77,
      "styleRecalcDurationMs": 43.666,
      "layouts": 12,
      "layoutDurationMs": 3.7960000000000003,
      "taskDurationMs": 855.8370000000001,
      "heapDeltaBytes": 16255124,
      "heapUsedBytes": 58824172,
      "domNodes": 60,
      "jsHeapTotalBytes": 23592960,
      "scriptDurationMs": 147.377,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.670000000000012,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1726.1219999999753,
      "styleRecalcs": 31,
      "styleRecalcDurationMs": 17.96,
      "layouts": 6,
      "layoutDurationMs": 0.6050000000000001,
      "taskDurationMs": 307.161,
      "heapDeltaBytes": 24711352,
      "heapUsedBytes": 68443636,
      "domNodes": 78,
      "jsHeapTotalBytes": 20185088,
      "scriptDurationMs": 25.231,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1751.677000000086,
      "styleRecalcs": 31,
      "styleRecalcDurationMs": 23.916,
      "layouts": 6,
      "layoutDurationMs": 0.8180000000000002,
      "taskDurationMs": 430.92299999999994,
      "heapDeltaBytes": 19464588,
      "heapUsedBytes": 66031152,
      "domNodes": 80,
      "jsHeapTotalBytes": 22282240,
      "scriptDurationMs": 60.12200000000001,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.670000000000012,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1726.8699999999626,
      "styleRecalcs": 30,
      "styleRecalcDurationMs": 19.538,
      "layouts": 6,
      "layoutDurationMs": 0.7439999999999999,
      "taskDurationMs": 385.108,
      "heapDeltaBytes": 24707452,
      "heapUsedBytes": 67476656,
      "domNodes": 77,
      "jsHeapTotalBytes": 20185088,
      "scriptDurationMs": 36.82299999999999,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 613.002999999992,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 14.859000000000004,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 356.02099999999996,
      "heapDeltaBytes": 6186388,
      "heapUsedBytes": 49401852,
      "domNodes": 16,
      "jsHeapTotalBytes": 13369344,
      "scriptDurationMs": 61.744,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 613.7560000000235,
      "styleRecalcs": 12,
      "styleRecalcDurationMs": 9.56,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 377.884,
      "heapDeltaBytes": 6556404,
      "heapUsedBytes": 49450872,
      "domNodes": 20,
      "jsHeapTotalBytes": 13631488,
      "scriptDurationMs": 72.132,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999727
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 607.9509999999573,
      "styleRecalcs": 13,
      "styleRecalcDurationMs": 9.843000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 396.9239999999999,
      "heapDeltaBytes": 6832196,
      "heapUsedBytes": 49621060,
      "domNodes": 22,
      "jsHeapTotalBytes": 12845056,
      "scriptDurationMs": 72.50300000000001,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2025.1900000000091,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 10.629,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 617.6460000000001,
      "heapDeltaBytes": 14971484,
      "heapUsedBytes": 66896940,
      "domNodes": -257,
      "jsHeapTotalBytes": 15716352,
      "scriptDurationMs": 112.58800000000001,
      "eventListeners": -129,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2031.7059999999856,
      "styleRecalcs": 12,
      "styleRecalcDurationMs": 13.058999999999997,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 629.1469999999999,
      "heapDeltaBytes": 4517872,
      "heapUsedBytes": 55588716,
      "domNodes": -255,
      "jsHeapTotalBytes": 16707584,
      "scriptDurationMs": 116.70099999999998,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2038.7829999999667,
      "styleRecalcs": 9,
      "styleRecalcDurationMs": 10.167000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 734.634,
      "heapDeltaBytes": 17259888,
      "heapUsedBytes": 70062100,
      "domNodes": -261,
      "jsHeapTotalBytes": 15454208,
      "scriptDurationMs": 126.20499999999998,
      "eventListeners": -129,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2119.798000000003,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 15.061000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1124.952,
      "heapDeltaBytes": -15471488,
      "heapUsedBytes": 47837372,
      "domNodes": -265,
      "jsHeapTotalBytes": 16822272,
      "scriptDurationMs": 397.403,
      "eventListeners": -129,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2191.1739999999895,
      "styleRecalcs": 68,
      "styleRecalcDurationMs": 15.955,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1242.953,
      "heapDeltaBytes": 19248752,
      "heapUsedBytes": 72791532,
      "domNodes": -265,
      "jsHeapTotalBytes": 18747392,
      "scriptDurationMs": 444.096,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2218.32100000006,
      "styleRecalcs": 68,
      "styleRecalcDurationMs": 16.340000000000003,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1328.451,
      "heapDeltaBytes": 19480360,
      "heapUsedBytes": 73097212,
      "domNodes": -264,
      "jsHeapTotalBytes": 17960960,
      "scriptDurationMs": 443.801,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3232.1260000000507,
      "styleRecalcs": 66,
      "styleRecalcDurationMs": 17.624000000000002,
      "layouts": 60,
      "layoutDurationMs": 7.631,
      "taskDurationMs": 1408.204,
      "heapDeltaBytes": 6540996,
      "heapUsedBytes": 61589000,
      "domNodes": -266,
      "jsHeapTotalBytes": 15921152,
      "scriptDurationMs": 513.496,
      "eventListeners": -123,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3147.4019999999996,
      "styleRecalcs": 64,
      "styleRecalcDurationMs": 16.333000000000006,
      "layouts": 60,
      "layoutDurationMs": 7.509999999999999,
      "taskDurationMs": 1433.3519999999999,
      "heapDeltaBytes": 9281768,
      "heapUsedBytes": 64553656,
      "domNodes": -268,
      "jsHeapTotalBytes": 16183296,
      "scriptDurationMs": 525.413,
      "eventListeners": -123,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3177.9750000000604,
      "styleRecalcs": 65,
      "styleRecalcDurationMs": 17.322,
      "layouts": 60,
      "layoutDurationMs": 8.088,
      "taskDurationMs": 1468.257,
      "heapDeltaBytes": 9513908,
      "heapUsedBytes": 64458436,
      "domNodes": -266,
      "jsHeapTotalBytes": 16183296,
      "scriptDurationMs": 530.528,
      "eventListeners": -123,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "minimap-idle",
      "durationMs": 2049.289999999985,
      "styleRecalcs": 7,
      "styleRecalcDurationMs": 7.682999999999999,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 558.703,
      "heapDeltaBytes": 787156,
      "heapUsedBytes": 54691360,
      "domNodes": -264,
      "jsHeapTotalBytes": 15134720,
      "scriptDurationMs": 97.84,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "minimap-idle",
      "durationMs": 2044.8169999999664,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 11.901000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 628.6290000000001,
      "heapDeltaBytes": 4061136,
      "heapUsedBytes": 56627112,
      "domNodes": -259,
      "jsHeapTotalBytes": 16183296,
      "scriptDurationMs": 117.15800000000002,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "minimap-idle",
      "durationMs": 2021.7549999999846,
      "styleRecalcs": 9,
      "styleRecalcDurationMs": 11.007000000000003,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 728.7669999999999,
      "heapDeltaBytes": 2738372,
      "heapUsedBytes": 56524216,
      "domNodes": -261,
      "jsHeapTotalBytes": 16969728,
      "scriptDurationMs": 121.907,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 554.6180000000049,
      "styleRecalcs": 48,
      "styleRecalcDurationMs": 12.676000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 363.121,
      "heapDeltaBytes": 6860356,
      "heapUsedBytes": 50951480,
      "domNodes": 22,
      "jsHeapTotalBytes": 12582912,
      "scriptDurationMs": 125.967,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 623.4139999999115,
      "styleRecalcs": 48,
      "styleRecalcDurationMs": 13.777000000000001,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 398.787,
      "heapDeltaBytes": 6265164,
      "heapUsedBytes": 49369528,
      "domNodes": 22,
      "jsHeapTotalBytes": 13631488,
      "scriptDurationMs": 130.123,
      "eventListeners": 12,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 614.2869999999903,
      "styleRecalcs": 48,
      "styleRecalcDurationMs": 19.056000000000004,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 395.54,
      "heapDeltaBytes": 6767784,
      "heapUsedBytes": 49602912,
      "domNodes": 22,
      "jsHeapTotalBytes": 12582912,
      "scriptDurationMs": 135.252,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2021.74100000002,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 12.205999999999998,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 380.15,
      "heapDeltaBytes": 19980744,
      "heapUsedBytes": 63011684,
      "domNodes": 20,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 22.01600000000001,
      "eventListeners": 4,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2037.0360000000005,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 11.850000000000001,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 444.511,
      "heapDeltaBytes": 19978552,
      "heapUsedBytes": 62755412,
      "domNodes": 22,
      "jsHeapTotalBytes": 22544384,
      "scriptDurationMs": 27.592,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2028.2720000000154,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 10.716999999999999,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 467.2390000000001,
      "heapDeltaBytes": 20173088,
      "heapUsedBytes": 63272444,
      "domNodes": 20,
      "jsHeapTotalBytes": 22544384,
      "scriptDurationMs": 27.482,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1991.6650000000118,
      "styleRecalcs": 84,
      "styleRecalcDurationMs": 49.626000000000005,
      "layouts": 16,
      "layoutDurationMs": 5.585,
      "taskDurationMs": 955.0999999999999,
      "heapDeltaBytes": 11844948,
      "heapUsedBytes": 54930584,
      "domNodes": 72,
      "jsHeapTotalBytes": 23330816,
      "scriptDurationMs": 109.815,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1701.64299999999,
      "styleRecalcs": 76,
      "styleRecalcDurationMs": 41.553000000000004,
      "layouts": 16,
      "layoutDurationMs": 4.965,
      "taskDurationMs": 774.966,
      "heapDeltaBytes": 11480204,
      "heapUsedBytes": 54670680,
      "domNodes": 63,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 108.41699999999999,
      "eventListeners": 4,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1992.843999999991,
      "styleRecalcs": 85,
      "styleRecalcDurationMs": 50.937,
      "layouts": 16,
      "layoutDurationMs": 4.71,
      "taskDurationMs": 993.2359999999999,
      "heapDeltaBytes": 11814596,
      "heapUsedBytes": 55791072,
      "domNodes": 73,
      "jsHeapTotalBytes": 23330816,
      "scriptDurationMs": 114.11200000000001,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8176.815999999973,
      "styleRecalcs": 251,
      "styleRecalcDurationMs": 46.38399999999999,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 3884.043,
      "heapDeltaBytes": 25057304,
      "heapUsedBytes": 75925928,
      "domNodes": -255,
      "jsHeapTotalBytes": 20582400,
      "scriptDurationMs": 1280.3300000000002,
      "eventListeners": -105,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8224.625000000004,
      "styleRecalcs": 251,
      "styleRecalcDurationMs": 46.663999999999994,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 4168.101,
      "heapDeltaBytes": 25804096,
      "heapUsedBytes": 78546856,
      "domNodes": -258,
      "jsHeapTotalBytes": 19009536,
      "scriptDurationMs": 1365.312,
      "eventListeners": -111,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8348.848999999973,
      "styleRecalcs": 251,
      "styleRecalcDurationMs": 49.491,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 4773.224,
      "heapDeltaBytes": 6479324,
      "heapUsedBytes": 57735348,
      "domNodes": -259,
      "jsHeapTotalBytes": 23785472,
      "scriptDurationMs": 1666.557,
      "eventListeners": -109,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 12801.202000000047,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 12787.054000000002,
      "heapDeltaBytes": -30070184,
      "heapUsedBytes": 166594944,
      "domNodes": -8331,
      "jsHeapTotalBytes": 28139520,
      "scriptDurationMs": 633.714,
      "eventListeners": -16466,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.223333333333358,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 12932.884000000058,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 12901.401,
      "heapDeltaBytes": -13281700,
      "heapUsedBytes": 180032544,
      "domNodes": -8331,
      "jsHeapTotalBytes": 26566656,
      "scriptDurationMs": 655.1,
      "eventListeners": -16462,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.219999999999953,
      "p95FrameDurationMs": 16.80000000000291
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 13482.649999999921,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 13459.941999999997,
      "heapDeltaBytes": -32596416,
      "heapUsedBytes": 164966068,
      "domNodes": -8331,
      "jsHeapTotalBytes": 26304512,
      "scriptDurationMs": 699.141,
      "eventListeners": -16462,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.223333333333237,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 14696.647999999983,
      "styleRecalcs": 70,
      "styleRecalcDurationMs": 15.305000000000014,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 14664.085,
      "heapDeltaBytes": -22474740,
      "heapUsedBytes": 171429872,
      "domNodes": -8331,
      "jsHeapTotalBytes": 25432064,
      "scriptDurationMs": 891.719,
      "eventListeners": -16458,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.223333333333358,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 14987.88300000001,
      "styleRecalcs": 72,
      "styleRecalcDurationMs": 16.937000000000037,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 14963.335000000001,
      "heapDeltaBytes": -20613652,
      "heapUsedBytes": 173880116,
      "domNodes": -8331,
      "jsHeapTotalBytes": 25694208,
      "scriptDurationMs": 946.45,
      "eventListeners": -16460,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.780000000000047,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 15076.621000000046,
      "styleRecalcs": 72,
      "styleRecalcDurationMs": 15.67400000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 15053.448999999999,
      "heapDeltaBytes": -35024960,
      "heapUsedBytes": 160430744,
      "domNodes": -8331,
      "jsHeapTotalBytes": -4714496,
      "scriptDurationMs": 932.1800000000001,
      "eventListeners": -16456,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.779999999999927,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "workflow-execution",
      "durationMs": 470.99900000000616,
      "styleRecalcs": 21,
      "styleRecalcDurationMs": 27.002,
      "layouts": 4,
      "layoutDurationMs": 1.568,
      "taskDurationMs": 132.36,
      "heapDeltaBytes": 4748316,
      "heapUsedBytes": 49950220,
      "domNodes": 190,
      "jsHeapTotalBytes": 262144,
      "scriptDurationMs": 28.499000000000002,
      "eventListeners": 71,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "workflow-execution",
      "durationMs": 460.5189999999766,
      "styleRecalcs": 20,
      "styleRecalcDurationMs": 29.663,
      "layouts": 6,
      "layoutDurationMs": 2.2239999999999993,
      "taskDurationMs": 143.499,
      "heapDeltaBytes": 4572812,
      "heapUsedBytes": 49885792,
      "domNodes": 158,
      "jsHeapTotalBytes": 0,
      "scriptDurationMs": 34.137,
      "eventListeners": 71,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.799999999999727
    },
    {
      "name": "workflow-execution",
      "durationMs": 458.0119999999397,
      "styleRecalcs": 17,
      "styleRecalcDurationMs": 25.269,
      "layouts": 5,
      "layoutDurationMs": 1.4489999999999998,
      "taskDurationMs": 140.031,
      "heapDeltaBytes": 4516876,
      "heapUsedBytes": 48432100,
      "domNodes": 156,
      "jsHeapTotalBytes": 0,
      "scriptDurationMs": 36.945,
      "eventListeners": 71,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    }
  ]
}

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/workflowPersistence.spec.ts (1)

384-386: Consider updating the first test for consistency.

The test "Closing an inactive tab with save" (lines 384-386) still uses raw button locators:

const saveButton = comfyPage.page.getByRole('button', { name: 'Save' })
await saveButton.waitFor({ state: 'visible' })
await saveButton.click()

For consistency with the updated test below, consider refactoring to use comfyPage.confirmDialog.click('save').

♻️ Suggested refactor for consistency
-    // Click "Save" in the dirty close dialog
-    const saveButton = comfyPage.page.getByRole('button', { name: 'Save' })
-    await saveButton.waitFor({ state: 'visible' })
-    await saveButton.click()
-    await comfyPage.workflow.waitForWorkflowIdle()
-    await comfyPage.nextFrame()
+    // Click "Save" in the dirty close dialog
+    await comfyPage.confirmDialog.click('save')
🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In `@browser_tests/tests/workflowPersistence.spec.ts` around lines 384 - 386, The
test "Closing an inactive tab with save" uses a raw Playwright locator
(comfyPage.page.getByRole(...)) instead of the shared confirm dialog helper;
replace the three lines that create/wait/click saveButton with a call to the
confirm dialog helper (comfyPage.confirmDialog.click('save')) so the test uses
the same abstraction as the other test; locate the code referencing
comfyPage.page.getByRole('button', { name: 'Save' }) and swap it to call
comfyPage.confirmDialog.click('save'), removing the explicit wait/click since
the helper handles visibility and interaction.
🤖 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/workflowPersistence.spec.ts`:
- Around line 384-386: The test "Closing an inactive tab with save" uses a raw
Playwright locator (comfyPage.page.getByRole(...)) instead of the shared confirm
dialog helper; replace the three lines that create/wait/click saveButton with a
call to the confirm dialog helper (comfyPage.confirmDialog.click('save')) so the
test uses the same abstraction as the other test; locate the code referencing
comfyPage.page.getByRole('button', { name: 'Save' }) and swap it to call
comfyPage.confirmDialog.click('save'), removing the explicit wait/click since
the helper handles visibility and interaction.

ℹ️ Review info
⚙️ Run configuration

Configuration used: Path: .coderabbit.yaml

Review profile: CHILL

Plan: Pro

Run ID: 92d38f4f-f43b-480f-8a08-228d44607a6e

📥 Commits

Reviewing files that changed from the base of the PR and between d946694 and 5299556.

📒 Files selected for processing (8)
  • browser_tests/fixtures/ComfyPage.ts
  • browser_tests/fixtures/components/ConfirmDialog.ts
  • browser_tests/fixtures/components/MediaLightbox.ts
  • browser_tests/fixtures/components/TemplatesDialog.ts
  • browser_tests/tests/confirmDialogTextWrap.spec.ts
  • browser_tests/tests/resultGallery.spec.ts
  • browser_tests/tests/templates.spec.ts
  • browser_tests/tests/workflowPersistence.spec.ts

coderabbitai[bot]
coderabbitai bot previously approved these changes Apr 2, 2026
The .p-dialog-mask wait timed out when clicking Save triggers a
second dialog (save-as filename). Use root.waitFor(hidden) with
catch instead — non-fatal if another dialog replaces it.
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/fixtures/components/ConfirmDialog.ts (1)

26-27: Restrict click to actionable buttons only.

KeysOfType<ConfirmDialog, Locator> also includes root, so click('root') is currently valid and can cause unintended behavior. Narrow this to explicit action keys.

Proposed refactor
-type KeysOfType<T, Match> = {
-  [K in keyof T]: T[K] extends Match ? K : never
-}[keyof T]
+type ConfirmDialogAction = 'delete' | 'overwrite' | 'reject' | 'confirm' | 'save'
@@
-  async click(locator: KeysOfType<ConfirmDialog, Locator>) {
-    const loc = this[locator]
+  async click(action: ConfirmDialogAction) {
+    const loc = this[action]
As per coding guidelines: "Whenever new code is written, ask if there's a simpler way to introduce the same functionality; choose the simpler course" and "Minimize the surface area (exported values) of each module and composable".
🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In `@browser_tests/fixtures/components/ConfirmDialog.ts` around lines 26 - 27, The
click method on ConfirmDialog currently types its locator as
KeysOfType<ConfirmDialog, Locator>, which includes non-actionable keys like
root; narrow the type to only the actionable button keys (e.g., explicitly union
the action keys such as 'confirm' | 'cancel' | 'secondary' that correspond to
Locator properties) and update the click signature (method click(locator:
'confirm' | 'cancel' | ...)) so callers cannot pass 'root'; additionally, add a
runtime guard that throws if an invalid key is passed and update any
tests/usages to use the explicit action key names.
🤖 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/fixtures/components/ConfirmDialog.ts`:
- Around line 26-27: The click method on ConfirmDialog currently types its
locator as KeysOfType<ConfirmDialog, Locator>, which includes non-actionable
keys like root; narrow the type to only the actionable button keys (e.g.,
explicitly union the action keys such as 'confirm' | 'cancel' | 'secondary' that
correspond to Locator properties) and update the click signature (method
click(locator: 'confirm' | 'cancel' | ...)) so callers cannot pass 'root';
additionally, add a runtime guard that throws if an invalid key is passed and
update any tests/usages to use the explicit action key names.

ℹ️ Review info
⚙️ Run configuration

Configuration used: Path: .coderabbit.yaml

Review profile: CHILL

Plan: Pro

Run ID: 55780840-36cb-46b7-91de-89c919c673e5

📥 Commits

Reviewing files that changed from the base of the PR and between 5299556 and 932f5af.

📒 Files selected for processing (1)
  • browser_tests/fixtures/components/ConfirmDialog.ts

@dante01yoon dante01yoon marked this pull request as ready for review April 2, 2026 12:50
@dante01yoon dante01yoon requested a review from a team April 2, 2026 12:50
@dosubot dosubot bot added the size:L This PR changes 100-499 lines, ignoring generated files. label Apr 2, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:L This PR changes 100-499 lines, ignoring generated files.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

refactor: replace inline getByRole('dialog') with page objects in E2E tests

2 participants