{ "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:직책" ] } ] }