httpOnly 쿠키로 인해 브라우저 JS에서 로그아웃 불가. 대시보드 UI, 세션 유지, 프로필 메뉴 검증으로 변경. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
103 lines
3.7 KiB
JSON
103 lines
3.7 KiB
JSON
{
|
|
"id": "login-test",
|
|
"name": "인증 세션 테스트",
|
|
"screenshotPolicy": {
|
|
"onErrorOnly": true,
|
|
"captureOn": ["error", "fail", "timeout", "404", "500", "blocked"]
|
|
},
|
|
"description": "로그인 상태 확인, 대시보드 UI 검증, 세션 유지, 프로필 메뉴 테스트 (httpOnly 쿠키로 인해 로그아웃/재로그인 불가)",
|
|
"baseUrl": "https://dev.codebridge-x.com",
|
|
"timeout": 30000,
|
|
"tags": ["auth", "login", "critical"],
|
|
"auth": {
|
|
"username": "TestUser5",
|
|
"password": "password123!"
|
|
},
|
|
"steps": [
|
|
{
|
|
"id": 1,
|
|
"name": "대시보드 URL 확인",
|
|
"action": "verify_url",
|
|
"expected": { "url_contains": "/dashboard" }
|
|
},
|
|
{
|
|
"id": 2,
|
|
"name": "필수 검증 #5: 목업 페이지 감지",
|
|
"action": "verify_not_mockup",
|
|
"checks": ["대시보드 위젯 표시", "사용자 정보 표시", "사이드바 메뉴 존재"],
|
|
"expected": "정상 페이지 (목업 아님)"
|
|
},
|
|
{
|
|
"id": 3,
|
|
"name": "사용자명 홍킬동 표시 확인",
|
|
"action": "verify_text",
|
|
"target": "body",
|
|
"expected": "홍킬동"
|
|
},
|
|
{
|
|
"id": 4,
|
|
"name": "대시보드 UI 요소 확인",
|
|
"action": "verify_elements",
|
|
"checks": ["사용자명 '홍킬동' 표시", "메뉴 영역 표시", "SAM 로고 표시"],
|
|
"expected": "대시보드 UI 정상"
|
|
},
|
|
{
|
|
"id": 5,
|
|
"name": "사이드바 메뉴 존재 확인",
|
|
"action": "evaluate",
|
|
"script": "(() => { const sidebar = document.querySelector('[class*=\"sidebar\"], [class*=\"Sidebar\"], nav, aside'); const menuItems = document.querySelectorAll('[class*=\"menu\"] a, [class*=\"Menu\"] a, nav a'); return 'Sidebar: ' + !!sidebar + ', Menu items: ' + menuItems.length; })()"
|
|
},
|
|
{
|
|
"id": 6,
|
|
"name": "세션 유지 확인 - 페이지 새로고침",
|
|
"action": "reload"
|
|
},
|
|
{
|
|
"id": 7,
|
|
"name": "새로고침 후 대시보드 유지 확인",
|
|
"action": "verify_url",
|
|
"expected": { "url_contains": "/dashboard" }
|
|
},
|
|
{
|
|
"id": 8,
|
|
"name": "새로고침 후 사용자명 유지 확인",
|
|
"action": "verify_text",
|
|
"target": "body",
|
|
"expected": "홍킬동"
|
|
},
|
|
{
|
|
"id": 9,
|
|
"name": "프로필 메뉴 열기",
|
|
"action": "evaluate",
|
|
"script": "(() => { const btns = Array.from(document.querySelectorAll('button')); const profileBtn = btns.find(b => b.innerText?.includes('홍킬동') || b.querySelector('[class*=\"avatar\"], [class*=\"Avatar\"], img[alt]')); if (profileBtn) { profileBtn.click(); return 'Profile menu clicked'; } return 'Profile button not found'; })()"
|
|
},
|
|
{
|
|
"id": 10,
|
|
"name": "프로필 드롭다운 확인",
|
|
"action": "evaluate",
|
|
"script": "(() => { const body = document.body.innerText; const hasLogout = body.includes('로그아웃'); const hasProfile = body.includes('프로필') || body.includes('마이페이지') || body.includes('내 정보') || body.includes('설정'); return 'Logout visible: ' + hasLogout + ', Profile visible: ' + hasProfile; })()"
|
|
},
|
|
{
|
|
"id": 11,
|
|
"name": "프로필 메뉴 닫기",
|
|
"action": "press_key",
|
|
"target": "Escape"
|
|
},
|
|
{
|
|
"id": 12,
|
|
"name": "대시보드 위젯 확인",
|
|
"action": "evaluate",
|
|
"script": "(() => { const cards = document.querySelectorAll('[class*=\"card\"], [class*=\"Card\"], [class*=\"widget\"], [class*=\"Widget\"]'); return 'Dashboard widgets: ' + cards.length; })()"
|
|
},
|
|
{
|
|
"id": 13,
|
|
"name": "콘솔 에러 확인",
|
|
"action": "verify_element",
|
|
"target": "body"
|
|
}
|
|
],
|
|
"expectedAPIs": [
|
|
{ "method": "GET", "endpoint": "/api/v1/auth/me", "description": "현재 사용자 정보 조회" }
|
|
]
|
|
}
|