feat: unified E2E testing engine — 205 tests, dual-stack support
Infrastructure: - adapters/: base, tauri (port 9750), electrobun (port 9761 + PTY daemon) - helpers/: 120+ centralized selectors, reusable actions, custom assertions - wdio.shared.conf.js + stack-specific configs 18 unified specs (205 tests): splash(6) smoke(15) settings(19) terminal(14) agent(15) search(12) files(15) comms(10) tasks(10) theme(12) groups(12) keyboard(8) notifications(10) diagnostics(8) status-bar(12) context(9) worktree(8) llm-judged(10) Daemon: --stack tauri|electrobun|both flag Scripts: test:e2e:tauri, test:e2e:electrobun, test:e2e:both
This commit is contained in:
parent
1995f03682
commit
77b9ce9f62
31 changed files with 3547 additions and 344 deletions
186
tests/e2e/helpers/selectors.ts
Normal file
186
tests/e2e/helpers/selectors.ts
Normal file
|
|
@ -0,0 +1,186 @@
|
|||
/**
|
||||
* Centralized CSS selectors for all E2E specs.
|
||||
*
|
||||
* Both Tauri (WebKit2GTK via tauri-driver) and Electrobun (WebKitGTK) render
|
||||
* the same Svelte frontend. These selectors work across both stacks.
|
||||
*
|
||||
* Convention: data-testid where available, CSS class fallback.
|
||||
*/
|
||||
|
||||
// ── App Shell ──
|
||||
export const APP_SHELL = '.app-shell';
|
||||
export const WORKSPACE = '.workspace';
|
||||
export const PROJECT_GRID = '.project-grid';
|
||||
|
||||
// ── Sidebar ──
|
||||
export const SIDEBAR = '.sidebar';
|
||||
export const SIDEBAR_RAIL = '[data-testid="sidebar-rail"]';
|
||||
export const SIDEBAR_PANEL = '.sidebar-panel';
|
||||
export const SIDEBAR_ICON = '.sidebar-icon';
|
||||
export const SETTINGS_BTN = '[data-testid="settings-btn"]';
|
||||
export const PANEL_CLOSE = '.panel-close';
|
||||
|
||||
// ── Groups ──
|
||||
export const GROUP_BTN = '.group-btn';
|
||||
export const GROUP_CIRCLE = '.group-circle';
|
||||
export const GROUP_BTN_ACTIVE = '.group-btn.active';
|
||||
export const ADD_GROUP_BTN = '.add-group-btn';
|
||||
export const GROUP_BADGE = '.group-badge';
|
||||
|
||||
// ── Project Cards ──
|
||||
export const PROJECT_CARD = '.project-card';
|
||||
export const PROJECT_HEADER = '.project-header';
|
||||
export const AGOR_TITLE = '.agor-title';
|
||||
|
||||
// ── Status Bar ──
|
||||
export const STATUS_BAR = '[data-testid="status-bar"]';
|
||||
export const STATUS_BAR_CLASS = '.status-bar';
|
||||
export const STATUS_BAR_VERSION = '.status-bar .version';
|
||||
export const BURN_RATE = '.burn-rate';
|
||||
export const AGENT_COUNTS = '.agent-counts';
|
||||
export const ATTENTION_QUEUE = '.attention-queue';
|
||||
export const FLEET_TOKENS = '.fleet-tokens';
|
||||
export const FLEET_COST = '.fleet-cost';
|
||||
export const PROJECT_COUNT = '.project-count';
|
||||
|
||||
// ── Settings ──
|
||||
export const SETTINGS_DRAWER = '.settings-drawer';
|
||||
export const SETTINGS_TAB = '.settings-tab';
|
||||
export const SETTINGS_TAB_ACTIVE = '.settings-tab.active';
|
||||
export const SETTINGS_CLOSE = '.settings-close';
|
||||
export const SETTINGS_CAT_BTN = '.cat-btn';
|
||||
export const THEME_SECTION = '.theme-section';
|
||||
export const FONT_STEPPER = '.font-stepper';
|
||||
export const FONT_DROPDOWN = '.font-dropdown';
|
||||
export const STEP_UP = '.font-stepper .step-up';
|
||||
export const SIZE_VALUE = '.font-stepper .size-value';
|
||||
export const UPDATE_ROW = '.update-row';
|
||||
export const VERSION_LABEL = '.version-label';
|
||||
|
||||
// ── Terminal ──
|
||||
export const TERMINAL_SECTION = '.terminal-section';
|
||||
export const TERMINAL_TABS = '.terminal-tabs';
|
||||
export const TERMINAL_TAB = '.terminal-tab';
|
||||
export const TERMINAL_TAB_ACTIVE = '.terminal-tab.active';
|
||||
export const TAB_ADD_BTN = '.tab-add-btn';
|
||||
export const TAB_CLOSE = '.tab-close';
|
||||
export const TERMINAL_COLLAPSE_BTN = '.terminal-collapse-btn';
|
||||
export const XTERM = '.xterm';
|
||||
export const XTERM_TEXTAREA = '.xterm-helper-textarea';
|
||||
|
||||
// ── Agent ──
|
||||
export const CHAT_INPUT = '.chat-input';
|
||||
export const CHAT_INPUT_TEXTAREA = '.chat-input textarea';
|
||||
export const CHAT_INPUT_ALT = '.chat-input input';
|
||||
export const SEND_BTN = '.send-btn';
|
||||
export const AGENT_MESSAGES = '.agent-messages';
|
||||
export const AGENT_STATUS = '.agent-status';
|
||||
export const AGENT_STATUS_TEXT = '.agent-status .status-text';
|
||||
export const PROVIDER_BADGE = '.provider-badge';
|
||||
export const AGENT_COST = '.agent-cost';
|
||||
export const MODEL_LABEL = '.model-label';
|
||||
export const STOP_BTN = '.stop-btn';
|
||||
|
||||
// ── Search Overlay ──
|
||||
export const OVERLAY_BACKDROP = '.overlay-backdrop';
|
||||
export const OVERLAY_PANEL = '.overlay-panel';
|
||||
export const SEARCH_INPUT = '.search-input';
|
||||
export const NO_RESULTS = '.no-results';
|
||||
export const ESC_HINT = '.esc-hint';
|
||||
export const LOADING_DOT = '.loading-dot';
|
||||
export const RESULTS_LIST = '.results-list';
|
||||
export const GROUP_LABEL = '.group-label';
|
||||
|
||||
// ── Command Palette ──
|
||||
export const PALETTE_BACKDROP = '.palette-backdrop';
|
||||
export const PALETTE_PANEL = '.palette-panel';
|
||||
export const PALETTE_INPUT = '.palette-input';
|
||||
export const PALETTE_ITEM = '.palette-item';
|
||||
export const CMD_LABEL = '.cmd-label';
|
||||
export const CMD_SHORTCUT = '.cmd-shortcut';
|
||||
|
||||
// ── File Browser ──
|
||||
export const FILE_BROWSER = '.file-browser';
|
||||
export const FB_TREE = '.fb-tree';
|
||||
export const FB_VIEWER = '.fb-viewer';
|
||||
export const FB_DIR = '.fb-dir';
|
||||
export const FB_FILE = '.fb-file';
|
||||
export const FB_EMPTY = '.fb-empty';
|
||||
export const FB_CHEVRON = '.fb-chevron';
|
||||
export const FB_EDITOR_HEADER = '.fb-editor-header';
|
||||
export const FB_IMAGE_WRAP = '.fb-image-wrap';
|
||||
export const FB_ERROR = '.fb-error';
|
||||
export const FILE_TYPE = '.file-type';
|
||||
|
||||
// ── Communications ──
|
||||
export const COMMS_TAB = '.comms-tab';
|
||||
export const COMMS_MODE_BAR = '.comms-mode-bar';
|
||||
export const MODE_BTN = '.mode-btn';
|
||||
export const MODE_BTN_ACTIVE = '.mode-btn.active';
|
||||
export const COMMS_SIDEBAR = '.comms-sidebar';
|
||||
export const CH_HASH = '.ch-hash';
|
||||
export const COMMS_MESSAGES = '.comms-messages';
|
||||
export const MSG_INPUT_BAR = '.msg-input-bar';
|
||||
export const MSG_SEND_BTN = '.msg-send-btn';
|
||||
|
||||
// ── Task Board ──
|
||||
export const TASK_BOARD = '.task-board';
|
||||
export const TB_TITLE = '.tb-title';
|
||||
export const TB_COLUMN = '.tb-column';
|
||||
export const TB_COL_LABEL = '.tb-col-label';
|
||||
export const TB_COL_COUNT = '.tb-col-count';
|
||||
export const TB_ADD_BTN = '.tb-add-btn';
|
||||
export const TB_CREATE_FORM = '.tb-create-form';
|
||||
export const TB_COUNT = '.tb-count';
|
||||
|
||||
// ── Theme ──
|
||||
export const DD_BTN = '.dd-btn';
|
||||
export const DD_LIST = '.dd-list';
|
||||
export const DD_GROUP_LABEL = '.dd-group-label';
|
||||
export const DD_ITEM = '.dd-item';
|
||||
export const DD_ITEM_SELECTED = '.dd-item.selected';
|
||||
export const SIZE_STEPPER = '.size-stepper';
|
||||
export const THEME_ACTION_BTN = '.theme-action-btn';
|
||||
|
||||
// ── Notifications ──
|
||||
export const NOTIF_BTN = '.notif-btn';
|
||||
export const NOTIF_DRAWER = '.notif-drawer';
|
||||
export const DRAWER_TITLE = '.drawer-title';
|
||||
export const CLEAR_BTN = '.clear-btn';
|
||||
export const NOTIF_EMPTY = '.notif-empty';
|
||||
export const NOTIF_ITEM = '.notif-item';
|
||||
export const NOTIF_BACKDROP = '.notif-backdrop';
|
||||
|
||||
// ── Splash ──
|
||||
export const SPLASH = '.splash';
|
||||
export const LOGO_TEXT = '.logo-text';
|
||||
export const SPLASH_VERSION = '.splash .version';
|
||||
export const SPLASH_DOT = '.splash .dot';
|
||||
|
||||
// ── Diagnostics ──
|
||||
export const DIAGNOSTICS = '.diagnostics';
|
||||
export const DIAG_HEADING = '.diagnostics .sh';
|
||||
export const DIAG_KEY = '.diag-key';
|
||||
export const DIAG_LABEL = '.diag-label';
|
||||
export const DIAG_FOOTER = '.diag-footer';
|
||||
export const REFRESH_BTN = '.refresh-btn';
|
||||
|
||||
// ── Right Bar (Electrobun) ──
|
||||
export const RIGHT_BAR = '.right-bar';
|
||||
export const CLOSE_BTN = '.close-btn';
|
||||
|
||||
// ── Context Tab ──
|
||||
export const CONTEXT_TAB = '.context-tab';
|
||||
export const TOKEN_METER = '.token-meter';
|
||||
export const FILE_REFS = '.file-refs';
|
||||
export const TURN_COUNT = '.turn-count';
|
||||
|
||||
// ── Worktree ──
|
||||
export const CLONE_BTN = '.clone-btn';
|
||||
export const BRANCH_DIALOG = '.branch-dialog';
|
||||
export const WT_BADGE = '.wt-badge';
|
||||
export const CLONE_GROUP = '.clone-group';
|
||||
|
||||
// ── Toast / Errors ──
|
||||
export const TOAST_ERROR = '.toast-error';
|
||||
export const LOAD_ERROR = '.load-error';
|
||||
Loading…
Add table
Add a link
Reference in a new issue