mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-04-19 22:09:37 +00:00
## Summary Add 30 E2E tests across 5 spec files covering medium-impact UI interactions: node search V2, bottom panel logs, focus mode, job history actions, and right side panel tabs. ## Tests | Spec file | Tests | Coverage | |---|---|---| | `nodeSearchBoxV2Extended.spec.ts` | 6 | V2 search filtering, keyboard navigation, category display | | `bottomPanelLogs.spec.ts` | 6 | Bottom panel toggle, logs tab, xterm terminal rendering | | `focusMode.spec.ts` | 6 | Focus mode hide/show UI chrome, sidebar/menu visibility | | `jobHistoryActions.spec.ts` | 6 | More options popover, docked history panel, queue interactions | | `rightSidePanelTabs.spec.ts` | 6 | Properties panel, node details, search from side panel | ## Review Focus - Bottom panel logs tests interact with xterm.js — the approach uses terminal container visibility rather than text content assertions. Is this the right level of testing? - Focus mode tests verify UI element hiding — they check element count/visibility rather than visual regression. Appropriate? ## Stack Depends on #9554 for FeatureFlagHelper/QueueHelper infrastructure. - #9554: Test infrastructure helpers - #9555: Toasts, error overlay, selection toolbox, linear mode, selection rectangle - **→ This PR**: Node search, bottom panel, focus mode, job history, side panel - #9557: Errors tab, node headers, queue notifications, settings sidebar - #9558: Minimap, widget copy, floating menus, node library essentials
66 lines
2.0 KiB
TypeScript
66 lines
2.0 KiB
TypeScript
import {
|
|
comfyExpect as expect,
|
|
comfyPageFixture as test
|
|
} from '../fixtures/ComfyPage'
|
|
|
|
test.describe('Focus Mode', { tag: '@ui' }, () => {
|
|
test.beforeEach(async ({ comfyPage }) => {
|
|
await comfyPage.settings.setSetting('Comfy.UseNewMenu', 'Top')
|
|
await comfyPage.setup()
|
|
})
|
|
|
|
test('Focus mode hides UI chrome', async ({ comfyPage }) => {
|
|
await expect(comfyPage.menu.sideToolbar).toBeVisible()
|
|
|
|
await comfyPage.setFocusMode(true)
|
|
|
|
await expect(comfyPage.menu.sideToolbar).not.toBeVisible()
|
|
})
|
|
|
|
test('Focus mode restores UI chrome', async ({ comfyPage }) => {
|
|
await comfyPage.setFocusMode(true)
|
|
await expect(comfyPage.menu.sideToolbar).not.toBeVisible()
|
|
|
|
await comfyPage.setFocusMode(false)
|
|
await expect(comfyPage.menu.sideToolbar).toBeVisible()
|
|
})
|
|
|
|
test('Toggle focus mode command works', async ({ comfyPage }) => {
|
|
await expect(comfyPage.menu.sideToolbar).toBeVisible()
|
|
|
|
await comfyPage.command.executeCommand('Workspace.ToggleFocusMode')
|
|
await comfyPage.nextFrame()
|
|
await expect(comfyPage.menu.sideToolbar).not.toBeVisible()
|
|
|
|
await comfyPage.command.executeCommand('Workspace.ToggleFocusMode')
|
|
await comfyPage.nextFrame()
|
|
await expect(comfyPage.menu.sideToolbar).toBeVisible()
|
|
})
|
|
|
|
test('Focus mode hides topbar', async ({ comfyPage }) => {
|
|
const topMenu = comfyPage.page.locator('.comfy-menu-button-wrapper')
|
|
await expect(topMenu).toBeVisible()
|
|
|
|
await comfyPage.setFocusMode(true)
|
|
|
|
await expect(topMenu).not.toBeVisible()
|
|
})
|
|
|
|
test('Canvas remains visible in focus mode', async ({ comfyPage }) => {
|
|
await comfyPage.setFocusMode(true)
|
|
|
|
await expect(comfyPage.canvas).toBeVisible()
|
|
})
|
|
|
|
test('Focus mode can be toggled multiple times', async ({ comfyPage }) => {
|
|
await comfyPage.setFocusMode(true)
|
|
await expect(comfyPage.menu.sideToolbar).not.toBeVisible()
|
|
|
|
await comfyPage.setFocusMode(false)
|
|
await expect(comfyPage.menu.sideToolbar).toBeVisible()
|
|
|
|
await comfyPage.setFocusMode(true)
|
|
await expect(comfyPage.menu.sideToolbar).not.toBeVisible()
|
|
})
|
|
})
|