Files
caddy-proxy-manager/tests/e2e/auth.spec.ts
2026-03-07 02:02:14 +01:00

43 lines
1.8 KiB
TypeScript

import { test, expect } from '@playwright/test';
// Auth tests run WITHOUT pre-authenticated state
test.use({ storageState: { cookies: [], origins: [] } });
test.describe('Authentication', () => {
test('unauthenticated access to / redirects to /login', async ({ page }) => {
await page.goto('/');
await expect(page).toHaveURL(/\/login/);
});
test('unauthenticated access to /proxy-hosts redirects to /login', async ({ page }) => {
await page.goto('/proxy-hosts');
await expect(page).toHaveURL(/\/login/);
});
test('/login page renders the login form', async ({ page }) => {
await page.goto('/login');
await expect(page.getByRole('textbox', { name: /username/i })).toBeVisible();
await expect(page.getByRole('textbox', { name: /password/i })).toBeVisible();
await expect(page.getByRole('button', { name: /sign in/i })).toBeVisible();
});
test('/login with wrong password shows an error message', async ({ page }) => {
await page.goto('/login');
await page.getByRole('textbox', { name: /username/i }).fill('testadmin');
await page.getByRole('textbox', { name: /password/i }).fill('WrongPassword!');
await page.getByRole('button', { name: /sign in/i }).click();
// Should show an error and stay on login
await expect(page).toHaveURL(/\/login/);
await expect(page.locator('text=/invalid|error|incorrect/i')).toBeVisible({ timeout: 5000 });
});
test('/login with correct credentials lands on dashboard', async ({ page }) => {
await page.goto('/login');
await page.getByRole('textbox', { name: /username/i }).fill('testadmin');
await page.getByRole('textbox', { name: /password/i }).fill('TestPassword2026!');
await page.getByRole('button', { name: /sign in/i }).click();
// Should redirect away from login
await expect(page).not.toHaveURL(/\/login/, { timeout: 10000 });
});
});