forked from baron/baron-sso
109 lines
3.2 KiB
TypeScript
109 lines
3.2 KiB
TypeScript
import { expect, test } from "@playwright/test";
|
|
|
|
test.describe("Bulk Actions and Tree Search", () => {
|
|
test.beforeEach(async ({ page }) => {
|
|
// Authenticate as Super Admin
|
|
await page.addInitScript(() => {
|
|
const authority = "http://localhost:5000/oidc";
|
|
const client_id = "adminfront";
|
|
const key = `oidc.user:${authority}:${client_id}`;
|
|
window.localStorage.setItem(
|
|
key,
|
|
JSON.stringify({
|
|
access_token: "fake",
|
|
profile: { sub: "admin", role: "super_admin" },
|
|
expires_at: 9999999999,
|
|
}),
|
|
);
|
|
});
|
|
|
|
// Mock APIs
|
|
await page.route("**/api/v1/user/me", async (route) => {
|
|
await route.fulfill({ json: { id: "admin", role: "super_admin" } });
|
|
});
|
|
|
|
await page.route("**/api/v1/admin/users?*", async (route) => {
|
|
await route.fulfill({
|
|
json: {
|
|
items: [
|
|
{
|
|
id: "u-1",
|
|
name: "User One",
|
|
email: "u1@test.com",
|
|
status: "active",
|
|
role: "user",
|
|
createdAt: new Date().toISOString(),
|
|
},
|
|
{
|
|
id: "u-2",
|
|
name: "User Two",
|
|
email: "u2@test.com",
|
|
status: "active",
|
|
role: "user",
|
|
createdAt: new Date().toISOString(),
|
|
},
|
|
],
|
|
total: 2,
|
|
},
|
|
});
|
|
});
|
|
|
|
await page.route("**/api/v1/admin/tenants/t-1", async (route) => {
|
|
await route.fulfill({
|
|
json: { id: "t-1", name: "Main Tenant", slug: "main" },
|
|
});
|
|
});
|
|
|
|
await page.route(
|
|
"**/api/v1/admin/tenants/t-1/organization",
|
|
async (route) => {
|
|
await route.fulfill({
|
|
json: [
|
|
{ id: "g-1", name: "Engineering", slug: "eng", tenantId: "t-1" },
|
|
{ id: "g-2", name: "Sales", slug: "sales", tenantId: "t-1" },
|
|
],
|
|
});
|
|
},
|
|
);
|
|
});
|
|
|
|
test("should show bulk action bar when users are selected", async ({
|
|
page,
|
|
}) => {
|
|
await page.goto("/users");
|
|
|
|
// Check individual row
|
|
await page.locator('input[type="checkbox"]').nth(1).check();
|
|
await expect(page.getByText("1명 선택됨")).toBeVisible();
|
|
await expect(
|
|
page.getByRole("button", { name: /활성화|Active/i }),
|
|
).toBeVisible();
|
|
|
|
// Check select all
|
|
await page.locator('input[type="checkbox"]').first().check();
|
|
await expect(page.getByText("2명 선택됨")).toBeVisible();
|
|
|
|
// Clear selection
|
|
await page.getByRole("button", { name: "Plus" }).click(); // The close icon
|
|
await expect(page.getByText("명 선택됨")).not.toBeVisible();
|
|
});
|
|
|
|
test("should filter and highlight nodes in organization tree", async ({
|
|
page,
|
|
}) => {
|
|
await page.goto("/tenants/t-1");
|
|
await page
|
|
.getByRole("link", { name: /하위 테넌트 관리|Sub-tenant/i })
|
|
.click();
|
|
|
|
const searchInput = page.getByPlaceholder(/조직도 내 검색|Search in tree/i);
|
|
await expect(searchInput).toBeVisible();
|
|
|
|
await searchInput.fill("Eng");
|
|
|
|
// Check if Engineering row is highlighted
|
|
const engRow = page.locator('tr:has-text("Engineering")');
|
|
await expect(engRow).toHaveClass(/bg-primary\/10/);
|
|
});
|
|
});
|