feat: Phase 3 시나리오 60개 추가 (워크플로우 5, 성능 20, 엣지케이스 15, 접근성 20)
- workflow-*: 다중 모듈 비즈니스 워크플로우 5종 - perf-*: 20개 주요 페이지 성능 측정 시나리오 - edge-*: 폼 검증, 경계값, 특수문자, 빠른 클릭 등 15종 - a11y-*: WCAG 2.1 AA 접근성 검사 20개 페이지
This commit is contained in:
58
edge-rapid-click-delete.json
Normal file
58
edge-rapid-click-delete.json
Normal file
@@ -0,0 +1,58 @@
|
||||
{
|
||||
"id": "edge-rapid-click-delete",
|
||||
"name": "엣지 케이스: 삭제 버튼 연타 (게시판 > 자유게시판)",
|
||||
"version": "1.0.0",
|
||||
"auth": {
|
||||
"role": "admin"
|
||||
},
|
||||
"menuNavigation": {
|
||||
"level1": "게시판",
|
||||
"level2": "자유게시판"
|
||||
},
|
||||
"screenshotPolicy": {
|
||||
"captureOnFail": true,
|
||||
"captureOnPass": false
|
||||
},
|
||||
"steps": [
|
||||
{
|
||||
"id": 1,
|
||||
"name": "페이지 로드 대기",
|
||||
"action": "wait",
|
||||
"timeout": 3000
|
||||
},
|
||||
{
|
||||
"id": 2,
|
||||
"name": "테이블 로드 대기",
|
||||
"action": "wait_for_table",
|
||||
"timeout": 5000
|
||||
},
|
||||
{
|
||||
"id": 3,
|
||||
"name": "첫 번째 행 클릭",
|
||||
"action": "click_first_row",
|
||||
"timeout": 5000
|
||||
},
|
||||
{
|
||||
"id": 4,
|
||||
"name": "상세 페이지 대기",
|
||||
"action": "wait",
|
||||
"timeout": 2000
|
||||
},
|
||||
{
|
||||
"id": 5,
|
||||
"name": "삭제 버튼 연타 (5회, 50ms 간격)",
|
||||
"action": "evaluate",
|
||||
"script": "(async()=>{const w=ms=>new Promise(r=>setTimeout(r,ms));const R={phase:'RAPID_CLICK_DELETE'};const btn=Array.from(document.querySelectorAll('button')).find(b=>{ const t=b.innerText?.trim()||''; return(/삭제|제거|Delete/.test(t))&&b.offsetParent!==null&&!b.disabled;});if(!btn){R.err='삭제 버튼 없음';R.ok=true;return JSON.stringify(R);}R.btnText=btn.innerText?.trim();let clickCount=0;for(let i=0;i<5;i++){btn.click();clickCount++;await w(50);}R.clickCount=clickCount;await w(2000);const dialogs=document.querySelectorAll('[role=\"alertdialog\"],[role=\"dialog\"]');const visDialog=Array.from(dialogs).find(d=>d.offsetParent!==null);R.confirmDialogShown=!!visDialog;if(visDialog){R.dialogText=visDialog.innerText?.trim().substring(0,100);}if(visDialog){ const cancelBtn=Array.from(visDialog.querySelectorAll('button')).find(b=>/취소|Cancel|아니오|닫기/.test(b.innerText?.trim())); if(cancelBtn){cancelBtn.click();await w(500);R.cancelled=true;} else{document.dispatchEvent(new KeyboardEvent('keydown',{key:'Escape',bubbles:true}));await w(500);R.cancelled=true;}}R.ok=true;return JSON.stringify(R);})()",
|
||||
"timeout": 15000,
|
||||
"phase": "RAPID_CLICK_DELETE"
|
||||
},
|
||||
{
|
||||
"id": 6,
|
||||
"name": "연타 후 상태 확인",
|
||||
"action": "evaluate",
|
||||
"script": "(async()=>{const w=ms=>new Promise(r=>setTimeout(r,ms));const R={phase:'RAPID_DELETE_RESULT'};await w(2000);const dialogs=document.querySelectorAll('[role=\"dialog\"],[role=\"alertdialog\"],[aria-modal=\"true\"]');const visibleDialogs=Array.from(dialogs).filter(d=>d.offsetParent!==null);R.dialogCount=visibleDialogs.length;const toasts=document.querySelectorAll('[data-sonner-toast],[role=\"status\"],[class*=\"toast\"],[class*=\"Toast\"]');R.toastCount=toasts.length;if(toasts.length>0){R.toastTexts=Array.from(toasts).map(t=>t.innerText?.trim().substring(0,80)).filter(Boolean);}const hasError=document.querySelector('[class*=\"error\"],[class*=\"Error\"],[role=\"alert\"]');R.hasError=!!hasError;R.url=location.pathname+location.search;R.pageStable=!document.querySelector('.loading,.spinner,[class*=\"skeleton\"]');R.ok=true;R.info=R.dialogCount<=1&&!R.hasError?'✅ 연타 클릭 후 정상 상태':'⚠️ 연타 클릭 후 비정상 상태 (다중 모달/에러)';return JSON.stringify(R);})()",
|
||||
"timeout": 10000,
|
||||
"phase": "RAPID_DELETE_RESULT"
|
||||
}
|
||||
]
|
||||
}
|
||||
Reference in New Issue
Block a user