n8n/packages/testing/playwright/pages/CredentialsPage.ts
Declan Carroll f96cdb17db
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
test: Resolve 20 janitor scope-lockdown and dead-code violations (#27948)
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-02 17:32:27 +00:00

72 lines
2.4 KiB
TypeScript

import { BasePage } from './BasePage';
import { AddResource } from './components/AddResource';
import { CredentialModal } from './components/CredentialModal';
import { ResourceCards } from './components/ResourceCards';
export class CredentialsPage extends BasePage {
async goto() {
await this.page.goto('/home/credentials');
}
readonly credentialModal = new CredentialModal(this.page.getByTestId('editCredential-modal'));
readonly addResource = new AddResource(this.page);
readonly cards = new ResourceCards(this.page);
get emptyListCreateCredentialButton() {
return this.page.getByRole('button', { name: 'Add first credential' });
}
get createCredentialButton() {
return this.page.getByTestId('create-credential-button');
}
/**
* Create a credential from the credentials list, fill fields, save, and close the modal.
* @param credentialType - The type of credential to create (e.g. 'Notion API')
* @param fields - Key-value pairs for credential fields to fill
*/
async createCredentialFromCredentialPicker(
credentialType: string,
fields: Record<string, string>,
options?: { closeDialog?: boolean; skipSave?: boolean; name?: string },
): Promise<void> {
await this.page.getByRole('combobox', { name: 'Search for app...' }).fill(credentialType);
await this.page
.getByTestId('new-credential-type-select-option')
.filter({ hasText: credentialType })
.click();
await this.page.getByTestId('new-credential-type-button').click();
await this.credentialModal.addCredential(fields, {
name: options?.name,
closeDialog: options?.closeDialog,
skipSave: options?.skipSave,
});
}
async clearSearch() {
await this.page.getByTestId('resources-list-search').clear();
}
async sortByNameDescending() {
await this.page.getByTestId('resources-list-sort').click();
await this.page.getByText('Name (Z-A)').click();
}
async sortByNameAscending() {
await this.page.getByTestId('resources-list-sort').click();
await this.page.getByText('Name (A-Z)').click();
}
/**
* Select credential type without auto-saving (for tests that need to handle save manually)
*/
async selectCredentialType(credentialType: string): Promise<void> {
await this.page.getByRole('combobox', { name: 'Search for app...' }).fill(credentialType);
await this.page
.getByTestId('new-credential-type-select-option')
.filter({ hasText: credentialType })
.click();
await this.page.getByTestId('new-credential-type-button').click();
}
}