mirror of
https://github.com/n8n-io/n8n.git
synced 2026-06-02 17:57:06 +02:00
Some checks are pending
CI: Master (Build, Test, Lint) / Build for Github Cache (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (22.x) (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (24.14.1) (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (25.x) (push) Waiting to run
CI: Master (Build, Test, Lint) / Lint (push) Waiting to run
CI: Master (Build, Test, Lint) / Performance (push) Waiting to run
CI: Master (Build, Test, Lint) / Notify Slack on failure (push) Blocked by required conditions
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
75 lines
2.2 KiB
TypeScript
75 lines
2.2 KiB
TypeScript
import type { Locator } from '@playwright/test';
|
|
|
|
import { BasePage } from './BasePage';
|
|
import { CredentialModal } from './components/CredentialModal';
|
|
|
|
export class TemplateCredentialSetupPage extends BasePage {
|
|
async goto(templateId: number) {
|
|
await this.page.goto(`/templates/${templateId}/setup`);
|
|
}
|
|
|
|
readonly credentialModal = new CredentialModal(this.page.getByTestId('editCredential-modal'));
|
|
|
|
getTitle(titleText: string): Locator {
|
|
return this.page.getByRole('heading', { name: titleText, level: 1 });
|
|
}
|
|
|
|
getInfoCallout(): Locator {
|
|
return this.page.getByTestId('info-callout');
|
|
}
|
|
|
|
getFormSteps(): Locator {
|
|
return this.page.getByTestId('setup-credentials-form-step');
|
|
}
|
|
|
|
getStepHeading(step: Locator): Locator {
|
|
return step.getByTestId('credential-step-heading');
|
|
}
|
|
|
|
getStepDescription(step: Locator): Locator {
|
|
return step.getByTestId('credential-step-description');
|
|
}
|
|
|
|
getSkipLink(): Locator {
|
|
return this.page.getByRole('link', { name: 'Skip' });
|
|
}
|
|
|
|
getContinueButton(): Locator {
|
|
return this.page.getByTestId('continue-button');
|
|
}
|
|
|
|
getCanvasSetupButton(): Locator {
|
|
return this.page.getByTestId('setup-credentials-button');
|
|
}
|
|
|
|
getCanvasCredentialModal(): Locator {
|
|
return this.page.getByTestId('setup-workflow-credentials-modal');
|
|
}
|
|
|
|
getSetupCredentialModalSteps(): Locator {
|
|
return this.getCanvasCredentialModal().getByTestId('setup-credentials-form-step');
|
|
}
|
|
|
|
getCreateCredentialButton(appName: string): Locator {
|
|
return this.page.getByRole('button', { name: `Create new ${appName} credential` });
|
|
}
|
|
|
|
getMessageBox(): Locator {
|
|
// Using class selector as Element UI message box doesn't have semantic attributes
|
|
return this.page.locator('.el-message-box');
|
|
}
|
|
|
|
/** Opens credential creation modal and waits for it to be visible */
|
|
async openCredentialCreation(appName: string): Promise<void> {
|
|
await this.getCreateCredentialButton(appName).click();
|
|
await this.credentialModal.waitForModal();
|
|
}
|
|
|
|
/** Waits for the message box to appear and clicks the cancel button to dismiss it */
|
|
async dismissMessageBox(): Promise<void> {
|
|
const messageBox = this.getMessageBox();
|
|
await messageBox.waitFor({ state: 'visible' });
|
|
await messageBox.locator('.btn--cancel').click();
|
|
}
|
|
}
|