rename(phase 1): CapaKraken → Nexus across code, UI, docs, CI (#61)
CI / Architecture Guardrails (push) Successful in 2m38s
CI / Assistant Split Regression (push) Successful in 3m33s
CI / Typecheck (push) Successful in 3m51s
CI / Lint (push) Successful in 5m2s
CI / E2E Tests (push) Has been cancelled
CI / Fresh-Linux Docker Deploy (push) Has been cancelled
CI / Release Images (push) Has been cancelled
CI / Build (push) Has been cancelled
CI / Unit Tests (push) Has been cancelled
CI / Architecture Guardrails (push) Successful in 2m38s
CI / Assistant Split Regression (push) Successful in 3m33s
CI / Typecheck (push) Successful in 3m51s
CI / Lint (push) Successful in 5m2s
CI / E2E Tests (push) Has been cancelled
CI / Fresh-Linux Docker Deploy (push) Has been cancelled
CI / Release Images (push) Has been cancelled
CI / Build (push) Has been cancelled
CI / Unit Tests (push) Has been cancelled
rename(phase 1): CapaKraken → Nexus across code, UI, docs, CI (#61) Co-authored-by: Hartmut Nörenberg <hn@hartmut-noerenberg.com> Co-committed-by: Hartmut Nörenberg <hn@hartmut-noerenberg.com>
This commit was merged in pull request #61.
This commit is contained in:
@@ -2,7 +2,7 @@ import { expect, test, type Page } from "@playwright/test";
|
||||
|
||||
async function signInAsAdmin(page: Page) {
|
||||
await page.goto("/auth/signin");
|
||||
await page.fill('input[type="email"]', "admin@capakraken.dev");
|
||||
await page.fill('input[type="email"]', "admin@nexus.dev");
|
||||
await page.fill('input[type="password"]', "admin123");
|
||||
await page.click('button[type="submit"]');
|
||||
await expect(page).toHaveURL(/\/(dashboard|resources)/);
|
||||
@@ -27,9 +27,9 @@ test.describe("Vacations", () => {
|
||||
|
||||
test("request vacation button is visible", async ({ page }) => {
|
||||
await page.waitForLoadState("networkidle");
|
||||
await expect(
|
||||
page.locator("button", { hasText: /Request Vacation/i }),
|
||||
).toBeVisible({ timeout: 10000 });
|
||||
await expect(page.locator("button", { hasText: /Request Vacation/i })).toBeVisible({
|
||||
timeout: 10000,
|
||||
});
|
||||
});
|
||||
|
||||
test("request vacation is blocked without linked resource", async ({ page }) => {
|
||||
@@ -37,7 +37,9 @@ test.describe("Vacations", () => {
|
||||
const reqBtn = page.locator("button", { hasText: /Request Vacation/i });
|
||||
await expect(reqBtn).toBeDisabled();
|
||||
await expect(
|
||||
page.getByText("Your account is not linked to a resource. Please contact an administrator."),
|
||||
page.getByText(
|
||||
"Your account is not linked to a resource. Please contact an administrator.",
|
||||
),
|
||||
).toBeVisible({ timeout: 5000 });
|
||||
});
|
||||
});
|
||||
@@ -57,11 +59,18 @@ test.describe("Vacations", () => {
|
||||
|
||||
test("team calendar tab renders", async ({ page }) => {
|
||||
await page.waitForLoadState("networkidle");
|
||||
await page.locator("button", { hasText: "Team Calendar" }).or(page.locator("text=Team Calendar")).first().click();
|
||||
await page
|
||||
.locator("button", { hasText: "Team Calendar" })
|
||||
.or(page.locator("text=Team Calendar"))
|
||||
.first()
|
||||
.click();
|
||||
await page.waitForTimeout(500);
|
||||
// Calendar view should appear
|
||||
await expect(
|
||||
page.locator("table").or(page.locator("[data-calendar]")).or(page.locator("text=Mon").or(page.locator("text=Week"))),
|
||||
page
|
||||
.locator("table")
|
||||
.or(page.locator("[data-calendar]"))
|
||||
.or(page.locator("text=Mon").or(page.locator("text=Week"))),
|
||||
).toBeVisible({ timeout: 10000 });
|
||||
});
|
||||
|
||||
@@ -75,11 +84,15 @@ test.describe("Vacations", () => {
|
||||
await expect(filters.nth(2)).toHaveValue("");
|
||||
});
|
||||
|
||||
test("vacation request preview excludes regional public holidays from deducted days", async ({ page }) => {
|
||||
test("vacation request preview excludes regional public holidays from deducted days", async ({
|
||||
page,
|
||||
}) => {
|
||||
await page.waitForLoadState("networkidle");
|
||||
await page.getByRole("button", { name: /request vacation/i }).click();
|
||||
|
||||
await expect(page.getByLabel(/^type/i).locator("option", { hasText: /Public Holiday/i })).toHaveCount(0);
|
||||
await expect(
|
||||
page.getByLabel(/^type/i).locator("option", { hasText: /Public Holiday/i }),
|
||||
).toHaveCount(0);
|
||||
await page.getByLabel(/resource/i).selectOption({ label: "Bruce Banner (bruce.banner)" });
|
||||
await page.getByLabel(/^type/i).selectOption("ANNUAL");
|
||||
await fillDisplayDate(page, /start date/i, "2026-01-06");
|
||||
@@ -89,9 +102,13 @@ test.describe("Vacations", () => {
|
||||
await expect(page.getByTestId("vacation-preview-requested-days")).toHaveText("1");
|
||||
await expect(page.getByTestId("vacation-preview-effective-days")).toHaveText("0");
|
||||
await expect(page.getByTestId("vacation-preview-deducted-days")).toHaveText("0");
|
||||
await expect(page.getByTestId("vacation-preview-public-holidays")).toContainText("2026-01-06");
|
||||
await expect(page.getByTestId("vacation-preview-public-holidays")).toContainText(
|
||||
"2026-01-06",
|
||||
);
|
||||
await expect(page.getByTestId("vacation-preview-holiday-basis")).toContainText("Germany");
|
||||
await expect(page.getByTestId("vacation-preview-holiday-sources")).toContainText("Holiday Calendar");
|
||||
await expect(page.getByTestId("vacation-preview-holiday-sources")).toContainText(
|
||||
"Holiday Calendar",
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user