n8n/packages/testing/playwright/pages/SidebarPage.ts
Declan Carroll bf25fad7df
test: Resolve 43 janitor violations and update baseline (no-changelog) (#28173)
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-09 14:34:18 +00:00

153 lines
4.0 KiB
TypeScript

import { expect, type Locator, type Page } from '@playwright/test';
export class SidebarPage {
readonly page: Page;
constructor(page: Page) {
this.page = page;
}
get container() {
return this.page.locator('#side-menu');
}
async clickHomeButton() {
await this.container.getByTestId('project-home-menu-item').click();
}
async universalAdd() {
await this.container.getByTestId('universal-add').click();
}
async clickHomeMenuItem() {
await this.container.getByTestId('project-home-menu-item').click();
}
async clickPersonalMenuItem() {
await this.container.getByTestId('project-personal-menu-item').click();
}
async clickWorkflowsLink(): Promise<void> {
await this.page.getByRole('link', { name: 'Workflows' }).click();
}
async clickCredentialsLink(): Promise<void> {
await this.page.getByRole('link', { name: 'Credentials' }).click();
}
getProjectButtonInUniversalAdd(): Locator {
return this.page.getByTestId('navigation-menu-item').filter({ hasText: 'Project' });
}
async addWorkflowFromUniversalAdd(projectName: string) {
await this.universalAdd();
await this.page.getByTestId('universal-add').getByText('Workflow').click();
await this.page.getByTestId('universal-add').getByRole('link', { name: projectName }).click();
}
async openNewCredentialDialogForProject(projectName: string) {
await this.universalAdd();
await this.page.getByTestId('universal-add').getByText('Credential', { exact: true }).click();
await this.page.getByTestId('universal-add').getByRole('link', { name: projectName }).click();
}
getProjectMenuItems(): Locator {
return this.container.getByTestId('project-menu-item');
}
async clickProjectMenuItem(projectName: string) {
await this.expand();
await this.getProjectMenuItems().filter({ hasText: projectName }).click();
}
getSettings(): Locator {
return this.container.getByTestId('main-sidebar-settings');
}
getLogoutMenuItem(): Locator {
return this.page.getByTestId('main-sidebar-log-out');
}
getAboutModal(): Locator {
return this.page.getByTestId('about-modal');
}
getHelp(): Locator {
return this.container.getByTestId('main-sidebar-help');
}
async clickHelpMenuItem(): Promise<void> {
await this.getHelp().click();
}
async clickAboutMenuItem(): Promise<void> {
await this.getHelp().click();
await this.page.getByTestId('about').click();
}
async openAboutModalViaShortcut(): Promise<void> {
await this.page.keyboard.press('Alt+Meta+o');
}
async closeAboutModal(): Promise<void> {
await this.page.getByTestId('close-about-modal-button').click();
}
getAdminPanel(): Locator {
return this.container.getByTestId('main-sidebar-cloud-admin');
}
getTrialBanner(): Locator {
return this.page.getByTestId('banners-TRIAL');
}
getTemplatesLink(): Locator {
return this.container.getByTestId('main-sidebar-templates').locator('a');
}
getVersionUpdateItem(): Locator {
return this.page.getByTestId('version-update-cta-button');
}
getSourceControlPushButton(): Locator {
return this.container.getByTestId('main-sidebar-source-control-push');
}
getSourceControlPullButton(): Locator {
return this.container.getByTestId('main-sidebar-source-control-pull');
}
getSourceControlConnectedIndicator(): Locator {
return this.container.getByTestId('main-sidebar-source-control-connected');
}
async openSettings(): Promise<void> {
await this.getSettings().click();
}
async clickSignout(): Promise<void> {
await this.expand();
await this.openSettings();
await this.getLogoutMenuItem().click();
}
async signOutFromWorkflows(): Promise<void> {
await this.page.goto('/workflows');
await this.clickSignout();
}
async expand() {
// First ensure the sidebar is visible before checking if it is expanded
await expect(this.getSettings()).toBeVisible();
const logo = this.container.getByTestId('n8n-logo');
const isExpanded = await logo.isVisible();
if (!isExpanded) {
const collapseButton = this.container.locator('#toggle-sidebar-button');
await expect(collapseButton).toBeVisible();
await collapseButton.click();
}
}
}