- Playwright + Chromium 브라우저 테스트 환경 세팅 - 테스터 계정 4개 생성 (admin/local/shop/user, pw: test1234!) - seed SQL + Node.js 시더 스크립트 포함 - E2E 테스트 23개 작성 (전체 통과): - auth: 로그인/로그아웃/실패/회원가입 (9개) - admin: 지자체관리자/Super Admin 패널 접근 (10개) - public: 홈/로그인/회원가입/404 (4개) - CLAUDE.md: 테스트 섹션을 Playwright 기반으로 업데이트 - jobs.md: 테스트 작업 완료 기록 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
71 lines
2.7 KiB
JavaScript
71 lines
2.7 KiB
JavaScript
// @ts-check
|
|
const { test, expect } = require('@playwright/test');
|
|
const { login, logout, TEST_ACCOUNTS } = require('./helpers/auth');
|
|
|
|
test.describe('인증 시스템', () => {
|
|
|
|
test('로그인 페이지 접속', async ({ page }) => {
|
|
await page.goto('/login');
|
|
await expect(page).toHaveURL(/\/login/);
|
|
await expect(page.locator('input[name="login_id"]')).toBeVisible();
|
|
await expect(page.locator('input[name="password"]')).toBeVisible();
|
|
});
|
|
|
|
test('잘못된 ID로 로그인 실패', async ({ page }) => {
|
|
await page.goto('/login');
|
|
await page.fill('input[name="login_id"]', 'wrong_user');
|
|
await page.fill('input[name="password"]', 'wrong_pass');
|
|
await page.click('button[type="submit"]');
|
|
// 로그인 페이지에 머물러야 함
|
|
await expect(page).toHaveURL(/\/login/);
|
|
});
|
|
|
|
test('잘못된 비밀번호로 로그인 실패', async ({ page }) => {
|
|
await page.goto('/login');
|
|
await page.fill('input[name="login_id"]', 'tester_admin');
|
|
await page.fill('input[name="password"]', 'wrong_password');
|
|
await page.click('button[type="submit"]');
|
|
await expect(page).toHaveURL(/\/login/);
|
|
});
|
|
|
|
test('Super Admin 로그인 성공 → 지자체 선택 페이지', async ({ page }) => {
|
|
await login(page, 'admin');
|
|
// Super Admin은 지자체 선택 페이지로 리다이렉트
|
|
await expect(page).toHaveURL(/\/admin\/select-local-government/);
|
|
});
|
|
|
|
test('지자체관리자 로그인 성공 → 관리자 대시보드', async ({ page }) => {
|
|
await login(page, 'local');
|
|
await expect(page).toHaveURL(/\/admin/);
|
|
});
|
|
|
|
test('일반 사용자 로그인 성공 → 홈/대시보드', async ({ page }) => {
|
|
await login(page, 'user');
|
|
// 일반 사용자는 홈 또는 대시보드로 이동
|
|
const url = page.url();
|
|
expect(url.includes('/dashboard') || url.endsWith('/') || url.includes('/login') === false).toBeTruthy();
|
|
});
|
|
|
|
test('로그아웃', async ({ page }) => {
|
|
await login(page, 'local');
|
|
await page.goto('/logout');
|
|
await page.waitForURL(/\/login/, { timeout: 10000 });
|
|
await expect(page).toHaveURL(/\/login/);
|
|
// 로그아웃 후 관리자 접근 불가 확인
|
|
await page.goto('/admin');
|
|
await expect(page).toHaveURL(/\/login/);
|
|
});
|
|
|
|
test('비로그인 상태에서 관리자 페이지 접근 → 로그인으로 리다이렉트', async ({ page }) => {
|
|
await page.goto('/admin');
|
|
await expect(page).toHaveURL(/\/login/);
|
|
});
|
|
|
|
test('회원가입 페이지 접속', async ({ page }) => {
|
|
await page.goto('/register');
|
|
await expect(page.locator('input[name="mb_id"]')).toBeVisible();
|
|
await expect(page.locator('input[name="mb_passwd"]')).toBeVisible();
|
|
await expect(page.locator('input[name="mb_name"]')).toBeVisible();
|
|
});
|
|
});
|