forked from baron/baron-sso
i18n, adminfront, devfront: 'make code-check' 통과를 위한 번역 싱크 엔진 개선, 룰 오브 훅 정합성 교정 및 테스트 레이스 컨디션 해결
This commit is contained in:
@@ -2,6 +2,10 @@ import { expect, test } from "@playwright/test";
|
||||
|
||||
test.describe("Authentication", () => {
|
||||
test.beforeEach(async ({ page }) => {
|
||||
page.on("console", (msg) => console.log("BROWSER LOG:", msg.text()));
|
||||
page.on("pageerror", (err) =>
|
||||
console.error("BROWSER EXCEPTION:", err.message),
|
||||
);
|
||||
// 1. Force state
|
||||
await page.addInitScript(() => {
|
||||
window.localStorage.setItem("locale", "ko");
|
||||
@@ -70,8 +74,24 @@ test.describe("Authentication", () => {
|
||||
|
||||
// 3. Catch-all for others
|
||||
await page.route(/.*\/api\/v1\/.*/, async (route) => {
|
||||
if (route.request().url().includes("/user/me")) {
|
||||
return route.fallback();
|
||||
}
|
||||
if (route.request().method() === "GET") {
|
||||
await route.fulfill({ json: { items: [], total: 0 } });
|
||||
await route.fulfill({
|
||||
json: {
|
||||
items: [],
|
||||
total: 0,
|
||||
summary: {
|
||||
failures: 0,
|
||||
warnings: 0,
|
||||
pass: 0,
|
||||
success: 0,
|
||||
total: 0,
|
||||
},
|
||||
sections: [],
|
||||
},
|
||||
});
|
||||
} else {
|
||||
await route.fulfill({ status: 200, json: {} });
|
||||
}
|
||||
|
||||
@@ -297,7 +297,9 @@ test.describe("보안 및 접근 제어: 시스템 관리자 vs 일반 사용자
|
||||
});
|
||||
|
||||
test.describe("세부 기능 권한(System Permissions)을 가진 비-슈퍼어드민", () => {
|
||||
test("테넌트 조회 권한(tenants)이 있을 때 테넌트 목록 페이지 진입 가능 및 쓰기 기능 제한 확인", async ({ page }) => {
|
||||
test("테넌트 조회 권한(tenants)이 있을 때 테넌트 목록 페이지 진입 가능 및 쓰기 기능 제한 확인", async ({
|
||||
page,
|
||||
}) => {
|
||||
await setupAuth(page, "tenant_admin", {
|
||||
tenantId: "t1",
|
||||
tenantSlug: "t1",
|
||||
@@ -315,18 +317,24 @@ test.describe("보안 및 접근 제어: 시스템 관리자 vs 일반 사용자
|
||||
|
||||
// 차단 메시지 비노출 확인
|
||||
await expect(
|
||||
page.getByText(/접근 권한이 없습니다|이 작업을 수행할 권한이 없습니다/i),
|
||||
page.getByText(
|
||||
/접근 권한이 없습니다|이 작업을 수행할 권한이 없습니다/i,
|
||||
),
|
||||
).not.toBeVisible();
|
||||
|
||||
// "테넌트 1" 목록 노출 확인
|
||||
await expect(page.getByText("테넌트 1")).toBeVisible();
|
||||
|
||||
// 수정 권한(manage_tenants)이 없으므로 쓰기 버튼 비노출 확인
|
||||
await expect(page.getByRole("link", { name: /테넌트 추가/i })).not.toBeVisible();
|
||||
await expect(
|
||||
page.getByRole("link", { name: /테넌트 추가/i }),
|
||||
).not.toBeVisible();
|
||||
await expect(page.getByTestId("tenant-data-mgmt-btn")).not.toBeVisible();
|
||||
});
|
||||
|
||||
test("테넌트 관리 권한(manage_tenants)까지 있을 때 테넌트 추가 및 데이터 관리 버튼 활성화 확인", async ({ page }) => {
|
||||
test("테넌트 관리 권한(manage_tenants)까지 있을 때 테넌트 추가 및 데이터 관리 버튼 활성화 확인", async ({
|
||||
page,
|
||||
}) => {
|
||||
await setupAuth(page, "tenant_admin", {
|
||||
tenantId: "t1",
|
||||
tenantSlug: "t1",
|
||||
@@ -341,7 +349,9 @@ test.describe("보안 및 접근 제어: 시스템 관리자 vs 일반 사용자
|
||||
await expect(page.getByText("테넌트 1")).toBeVisible();
|
||||
|
||||
// 수정 권한(manage_tenants)이 있으므로 쓰기 버튼(테넌트 추가, 데이터 관리) 노출 확인
|
||||
await expect(page.getByRole("link", { name: /테넌트 추가/i })).toBeVisible();
|
||||
await expect(
|
||||
page.getByRole("link", { name: /테넌트 추가/i }),
|
||||
).toBeVisible();
|
||||
await expect(page.getByTestId("tenant-data-mgmt-btn")).toBeVisible();
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user