Files
sam-scenarios/login.json
김보곤 23827c257d refactor: 비표준 포맷 13개 시나리오 Format A 통일
- actions 배열(Format B) → 단일 action(Format A) 변환
- fill_form fields: target 키 → name 키 수정
- verify_detail checks: 객체 배열 → 문자열 배열 수정
- 전체 13개 시나리오 E2E 테스트 PASS 확인
2026-02-28 17:21:01 +09:00

314 lines
8.6 KiB
JSON

{
"id": "login-test",
"name": "로그인 테스트 (끝판왕)",
"screenshotPolicy": {
"onErrorOnly": true,
"captureOn": [
"error",
"fail",
"timeout",
"404",
"500",
"blocked"
]
},
"description": "로그인 페이지 UI 검증, 로그인 실패/성공, 대시보드 진입, 로그아웃까지 전체 인증 플로우 테스트",
"baseUrl": "https://dev.codebridge-x.com",
"timeout": 30000,
"tags": [
"auth",
"login",
"critical"
],
"auth": {
"username": "TestUser5",
"password": "password123!",
"wrongPassword": "wrongpassword"
},
"selectors": {
"usernameInput": "#userId",
"passwordInput": "#password",
"rememberMeCheckbox": "input[type='checkbox']",
"forgotPasswordButton": "button:has-text('비밀번호를 잊으셨나요?')",
"loginButton": "button[type='submit']",
"passwordToggle": "button:has(.lucide-eye)",
"userProfileButton": "button:has-text('홍킬동')",
"logoutButton": "button:has-text('로그아웃')"
},
"steps": [
{
"id": 1,
"name": "로그인 페이지 접속",
"action": "navigate",
"target": "/ko/login",
"expected": {
"url": "/ko/login",
"visible": [
"로그인",
"환영합니다",
"SAM MES",
"아이디",
"비밀번호"
]
}
},
{
"id": 2,
"name": "필수 검증 #5: 목업 페이지 감지",
"action": "verify_not_mockup",
"checks": [
"아이디 입력 필드 존재 및 입력 가능",
"비밀번호 입력 필드 존재 및 입력 가능",
"로그인 버튼 존재 및 클릭 가능"
],
"expected": "정상 페이지 (목업 아님)"
},
{
"id": 3,
"name": "UI 요소 검증 - 입력 필드",
"action": "verify_elements",
"checks": [
"아이디 입력 필드 placeholder: '아이디를 입력하세요'",
"비밀번호 입력 필드 placeholder: '비밀번호를 입력하세요'",
"비밀번호 표시/숨김 토글 버튼 존재"
],
"expected": "모든 입력 필드 정상"
},
{
"id": 4,
"name": "UI 요소 검증 - 옵션",
"action": "verify_elements",
"checks": [
"로그인 상태 유지 체크박스 존재",
"비밀번호 찾기 링크 존재",
"로그인 버튼 존재"
],
"expected": "모든 옵션 요소 정상"
},
{
"id": 5,
"name": "비밀번호 표시/숨김 토글 테스트",
"action": "click_if_exists",
"target": "passwordToggle",
"expected": "비밀번호 필드 type이 'text'로 변경 (표시 모드)"
},
{
"id": 6,
"name": "비밀번호 숨김 복원",
"action": "click_if_exists",
"target": "passwordToggle",
"expected": "비밀번호 필드 type이 'password'로 복원 (숨김 모드)"
},
{
"id": 7,
"name": "로그인 실패 테스트 - 빈 필드",
"action": "click_if_exists",
"target": "loginButton",
"expected": "유효성 검사 에러 또는 로그인 실패 메시지"
},
{
"id": 8,
"name": "아이디 입력",
"action": "click_if_exists",
"target": "usernameInput",
"value": "TestUser5",
"expected": "아이디 필드에 값 입력됨"
},
{
"id": 9,
"name": "로그인 실패 테스트 - 잘못된 비밀번호",
"action": "click_if_exists",
"target": "passwordInput",
"value": "wrongpassword",
"expected": "비밀번호 필드에 값 입력됨"
},
{
"id": 10,
"name": "잘못된 비밀번호로 로그인 시도",
"action": "click_if_exists",
"target": "loginButton",
"expected": "로그인 실패 에러 메시지 표시",
"verify": {
"type": "error_message",
"contains": [
"실패",
"오류",
"일치하지 않",
"incorrect",
"failed"
]
}
},
{
"id": 11,
"name": "비밀번호 필드 초기화",
"action": "click_if_exists",
"target": "passwordInput",
"expected": "비밀번호 필드 비워짐"
},
{
"id": 12,
"name": "올바른 비밀번호 입력",
"action": "click_if_exists",
"target": "passwordInput",
"value": "password123!",
"expected": "올바른 비밀번호 입력됨"
},
{
"id": 13,
"name": "필수 검증 #2: 로그인 버튼 클릭",
"action": "click_if_exists",
"target": "loginButton",
"verify": {
"url_should_change": true,
"no_error_page": true,
"api_call": "POST /api/v1/auth/login"
},
"expected": "로그인 성공 및 대시보드로 이동"
},
{
"id": 14,
"name": "대시보드 페이지 확인",
"action": "wait_for_navigation",
"expected": {
"url_contains": "/dashboard",
"visible": [
"대시보드",
"홍킬동"
]
}
},
{
"id": 15,
"name": "사용자 정보 표시 확인",
"action": "verify_elements",
"checks": [
"사용자명 '홍킬동' 표시",
"메뉴 영역 표시",
"SAM 로고 표시"
],
"expected": "사용자 정보 및 메인 레이아웃 정상"
},
{
"id": 16,
"name": "세션 유지 확인 - 페이지 새로고침",
"action": "reload",
"expected": "새로고침 후에도 로그인 상태 유지"
},
{
"id": 17,
"name": "새로고침 후 대시보드 유지 확인",
"action": "verify_url",
"expected": {
"url_contains": "/dashboard",
"visible": [
"대시보드",
"홍킬동"
]
}
},
{
"id": 18,
"name": "사용자 프로필 메뉴 열기",
"action": "click_if_exists",
"target": "userProfileButton",
"expected": "사용자 메뉴 드롭다운 열림"
},
{
"id": 19,
"name": "로그아웃 버튼 클릭",
"action": "click_if_exists",
"target": "logoutButton",
"expected": "로그아웃 처리 및 로그인 페이지로 이동"
},
{
"id": 20,
"name": "로그아웃 후 로그인 페이지 확인",
"action": "verify_element",
"expected": {
"url_contains": "/login",
"visible": [
"로그인",
"아이디",
"비밀번호"
]
}
},
{
"id": 21,
"name": "로그아웃 후 보호된 페이지 접근 시도",
"action": "navigate",
"target": "/ko/dashboard",
"expected": "로그인 페이지로 리다이렉트"
},
{
"id": 22,
"name": "재로그인 테스트",
"action": "evaluate",
"script": "(async () => { const uid = document.querySelector('#userId'); if (uid) { uid.focus(); uid.value = 'TestUser5'; uid.dispatchEvent(new Event('input', {bubbles:true})); } await new Promise(r => setTimeout(r, 300)); const pwd = document.querySelector('#password'); if (pwd) { pwd.focus(); pwd.value = 'password123!'; pwd.dispatchEvent(new Event('input', {bubbles:true})); } await new Promise(r => setTimeout(r, 300)); const btn = document.querySelector(\"button[type='submit']\"); if (btn) btn.click(); return 'Re-login submitted'; })()",
"expected": "재로그인 성공"
},
{
"id": 23,
"name": "최종 확인 - 대시보드 진입",
"action": "verify_url",
"expected": {
"url_contains": "/dashboard",
"visible": [
"대시보드",
"홍킬동"
]
}
},
{
"id": 24,
"name": "콘솔 에러 확인",
"action": "verify_element",
"target": "body"
}
],
"requiredVerifications": [
{
"id": 2,
"name": "등록/저장 버튼 (로그인)",
"steps": [
13
],
"criteria": "로그인 버튼 클릭 → API 호출 → 대시보드 이동"
},
{
"id": 5,
"name": "목업 페이지 감지",
"steps": [
2
],
"criteria": "입력 필드 동작, 버튼 클릭 가능"
}
],
"expectedAPIs": [
{
"method": "POST",
"endpoint": "/api/v1/auth/login",
"description": "로그인 인증"
},
{
"method": "GET",
"endpoint": "/api/v1/auth/me",
"description": "현재 사용자 정보 조회"
},
{
"method": "POST",
"endpoint": "/api/v1/auth/logout",
"description": "로그아웃"
}
],
"testData": {
"validUser": {
"username": "TestUser5",
"password": "password123!",
"displayName": "홍킬동"
},
"invalidPassword": "wrongpassword"
}
}