Files
fast-next-template/frontend/e2e/settings-password.spec.ts
Felipe Cardoso f8b77200f0 Refactor E2E tests and mock APIs for improved reliability and maintainability
- Updated E2E tests to use specific role-based heading selectors for better robustness.
- Enhanced mock routes in `auth.ts` to handle detailed organization endpoints more effectively.
- Improved test flow by adding `waitUntil: 'networkidle'` to navigation steps.
- Refined `admin-access.spec.ts` interactions to use optimized wait and click implementations for better performance.
- Updated dialog texts and field labels to match latest UI changes.
2025-11-07 00:02:01 +01:00

57 lines
2.1 KiB
TypeScript

/**
* E2E Tests for Password Change Page
* Tests password change functionality
*/
import { test, expect } from '@playwright/test';
import { setupAuthenticatedMocks, loginViaUI } from './helpers/auth';
test.describe('Password Change', () => {
test.beforeEach(async ({ page }) => {
// Set up API mocks
await setupAuthenticatedMocks(page);
// Login via UI to establish authenticated session
await loginViaUI(page);
// Navigate to password page
await page.goto('/settings/password', { waitUntil: 'networkidle' });
// Wait for form to be visible
await page.getByLabel(/current password/i).waitFor({ state: 'visible', timeout: 10000 });
});
test('should display password change form', async ({ page }) => {
// Check page title
await expect(page.getByRole('heading', { name: 'Password' })).toBeVisible();
// Verify all password fields are present
await expect(page.getByLabel(/current password/i)).toBeVisible();
await expect(page.getByLabel(/^new password/i)).toBeVisible();
await expect(page.getByLabel(/confirm.*password/i)).toBeVisible();
// Verify submit button is present
await expect(page.getByRole('button', { name: /change password/i })).toBeVisible();
});
test('should have all password fields as password type', async ({ page }) => {
// Wait for form to load
const currentPasswordInput = page.getByLabel(/current password/i);
await currentPasswordInput.waitFor({ state: 'visible', timeout: 10000 });
// Verify all password fields have type="password"
await expect(currentPasswordInput).toHaveAttribute('type', 'password');
await expect(page.getByLabel(/^new password/i)).toHaveAttribute('type', 'password');
await expect(page.getByLabel(/confirm.*password/i)).toHaveAttribute('type', 'password');
});
test('should have submit button disabled initially', async ({ page }) => {
// Wait for form to load
const submitButton = page.getByRole('button', { name: /change password/i });
await submitButton.waitFor({ state: 'visible', timeout: 10000 });
// Verify button is disabled when form is empty/untouched
await expect(submitButton).toBeDisabled();
});
});