mirror of
https://github.com/ramvignesh-b/pi-ku.git
synced 2026-05-04 18:03:58 +00:00
3c9c72d25f
* feat: update E2E testing configuration to use ssl * fix: add IPv6 loopback support to mkcert generation command in CI workflow * feat: centralize SSL certificate generation into a reusable workflow job * fix: use static ip in mkcert command * fix: correct mkcert command args * feat: implement certificate caching in CI workflow to persist SSL files across jobs * refactor: optimize CI workflow caching * ci: implement certificate caching in workflow * fix: correct certificate caching keys and fix environment file paths in CI workflows * fix: correct environment file paths and parallelize frontend dependency installation in CI workflow * test: set TZ environment variable to Asia/Kolkata in vitest configuration * fix: force en-US locale in Intl formatters to ensure consistent date and time output * fix: update MAILPIT_API_URL protocol from https to http in e2e environment example * chore: set test timezone to Asia/Kolkata * ci: add sll support and enhance e2e workflow * ci: improve compatibility for docker-compose execution * refactor: improve container orchestration detection and fallback logic in e2e test script * feat: add container runtime validation and force docker usage in CI environment * feat: add caching for Playwright dependencies in CI workflow * chore: update restart policy to unless-stopped for postgres and mailpit services in e2e docker-compose --------- Co-authored-by: ramvignesh-b <ramvignesh-b@github.com>
62 lines
1.9 KiB
TypeScript
62 lines
1.9 KiB
TypeScript
import { expect, type Page } from "@playwright/test";
|
|
import pino from "pino";
|
|
import { MailpitHelper } from "./mailpit";
|
|
|
|
const logger = pino({
|
|
transport: {
|
|
target: "pino-pretty",
|
|
options: {
|
|
colorize: true,
|
|
},
|
|
},
|
|
});
|
|
|
|
/**
|
|
* Completes the full registration -> activation -> login cycle.
|
|
*/
|
|
export async function registerAndLogin(
|
|
page: Page,
|
|
email: string,
|
|
fullName: string,
|
|
password: string,
|
|
) {
|
|
// 1. Registration
|
|
logger.info(`[Auth] Registering user: ${email}`);
|
|
await page.goto("/onboard");
|
|
await page.getByLabel(/full name/i).fill(fullName);
|
|
await page.getByLabel("Email", { exact: true }).fill(email);
|
|
await page.getByLabel("Password", { exact: true }).fill(password);
|
|
await page.getByLabel(/confirm password/i).fill(password);
|
|
await page.getByRole("button", { name: /^register$/i }).click();
|
|
|
|
await expect(page).toHaveURL(/\/verify-email/);
|
|
|
|
// 2. Activation via Mailpit
|
|
logger.info(`[Auth] Polling Mailpit for activation email...`);
|
|
const activationLink = await MailpitHelper.getActivationLink(email);
|
|
|
|
await page.goto(activationLink);
|
|
|
|
await expect(page.getByText(/account activated/i)).toBeVisible();
|
|
await page.getByRole("button", { name: /start writing/i }).click();
|
|
|
|
// 3. Login
|
|
logger.info(`[Auth] Logging in...`);
|
|
await expect(page).toHaveURL(/\/login/);
|
|
|
|
const welcomeButton = page.getByRole("button", { name: /i understand/i });
|
|
await welcomeButton.waitFor({ state: "visible", timeout: 10000 });
|
|
await welcomeButton.click();
|
|
await expect(welcomeButton).toBeHidden();
|
|
|
|
await page.getByLabel("Email", { exact: true }).fill(email);
|
|
await page.getByLabel("Password", { exact: true }).fill(password);
|
|
await page.getByRole("button", { name: /sign in/i }).click();
|
|
|
|
await expect(page).toHaveURL(/\/drawer/);
|
|
logger.info(`[Auth] Successfully authenticated ${email}`);
|
|
}
|
|
|
|
// Maintain backward compatibility if needed, or update callers
|
|
export const AuthHelper = { registerAndLogin };
|