Files
sam-scenarios/settings-position.json

120 lines
3.8 KiB
JSON
Raw Normal View History

{
"id": "settings-position",
"name": "직책관리 테스트",
"screenshotPolicy": {
"onErrorOnly": true,
"captureOn": [
"error",
"fail",
"timeout",
"404",
"500",
"blocked"
]
},
"description": "설정 > 직책관리 목록/검색/상세 기능 검증",
"baseUrl": "https://dev.codebridge-x.com",
"menuNavigation": {
"level1": "설정",
"level2": "직책관리",
"expectedUrl": "/settings/titles",
"searchWithinParent": true,
"closeOtherMenus": true
},
"auth": {
"username": "TestUser5",
"password": "password123!"
},
"steps": [
{
"id": 1,
"name": "메뉴 진입: 설정 > 직책관리",
"action": "menu_navigate",
"level1": "설정",
"level2": "직책관리",
"expected": {
"url_contains": "/settings"
}
},
{
"id": 2,
"name": "URL 검증",
"action": "verify_url",
"expected": {
"url_contains": "/settings/titles"
}
},
{
"id": 3,
"name": "페이지 로드 대기",
"action": "wait",
"duration": 1500
},
{
"id": 4,
"name": "페이지 구조 검증",
"action": "evaluate",
"script": "(() => { const body = document.body.innerText; const hasTitle = body.includes('직책'); const tables = document.querySelectorAll('table'); const inputs = document.querySelectorAll('input:not([type=\"hidden\"])'); const btns = Array.from(document.querySelectorAll('button')).filter(b => ['추가', '등록', '신규'].some(t => b.innerText?.includes(t))); return 'Has 직책: ' + hasTitle + ', Tables: ' + tables.length + ', Inputs: ' + inputs.length + ', Add btns: ' + btns.length; })()"
},
{
"id": 5,
"name": "통계 카드 확인",
"action": "evaluate",
"script": "(() => {\n const cards = document.querySelectorAll('[class*=\"card\"], [class*=\"Card\"], [class*=\"stat\"], [class*=\"Stat\"], [class*=\"summary\"]');\n const texts = Array.from(cards).map(c => c.innerText?.substring(0, 30)).filter(Boolean);\n return texts.length > 0 ? 'Stats: ' + texts.length + ' cards found' : 'No stat cards (ok)';\n })()"
},
{
"id": 6,
"name": "직책관리 페이지 확인",
"action": "verify_detail",
"checks": [
"visible_text:직책"
]
},
{
"id": 7,
"name": "설정 페이지 확인",
"action": "verify_detail",
"checks": [
"visible_text:설정"
]
},
{
"id": 8,
"name": "추가 버튼 클릭",
"action": "click_if_exists",
"target": "추가"
},
{
"id": 9,
"name": "모달/폼 대기",
"action": "wait",
"duration": 1000
},
{
"id": 10,
"name": "직책명 입력 필드 확인",
"action": "evaluate",
"script": "(() => { const modal = document.querySelector('[role=\"dialog\"], [aria-modal=\"true\"], [class*=\"modal\"]:not([class*=\"tooltip\"]), [class*=\"Modal\"], [class*=\"Sheet\"]'); const isVis = el => !!el && el.getBoundingClientRect().width > 0; const scope = isVis(modal) ? modal : document; const inputs = scope.querySelectorAll('input:not([type=\"hidden\"]), textarea'); const nameInput = Array.from(inputs).find(i => i.placeholder?.includes('직책') || i.name?.includes('title') || i.name?.includes('name')); return 'Inputs: ' + inputs.length + ', Name input: ' + !!nameInput; })()"
},
{
"id": "10-1",
"name": "모달 닫기",
"action": "close_modal_if_open"
},
{
"id": 11,
"name": "콘솔 에러 확인",
"action": "verify_element",
"target": "body"
},
{
"id": 12,
"name": "직책관리 최종 확인",
"action": "verify_detail",
"checks": [
"visible_text:직책"
]
}
]
}