Files
sam-hotfix/Fail-bad-debt-collection_2026-03-07_21-08-02.md

126 lines
14 KiB
Markdown
Raw Normal View History

# ❌ E2E 테스트 실패: 대손채권회수 테스트
**테스트 ID**: bad-debt-collection | **실행**: 2026-03-07_21-08-02 | **결과**: FAIL
**소요 시간**: 140.4초
## 테스트 요약
| 전체 | 성공 | 실패 | 경고 | 성공률 |
|------|------|------|------|--------|
| 51 | 1 | 32 | 18 | 2% |
## 실패 스텝
| # | 스텝 | Phase | 에러 |
|---|------|-------|------|
| step-1 | 2단계 메뉴 진입: 회계관리 > 악성채권추심관리 | - | Element not found: 악성채권추심관리 [context: btn:60,input:1,text:not-on-page] |
| step-3 | 필터 및 검색 기능 테스트 | - | Select not found: 상태 필터 [context: btn:60,input:1,text:not-on-page] |
| step-5 | 첫 번째 행 체크박스 선택 | - | Element not found: 첫 번째 행 체크박스 [context: btn:60,input:1,text:not-on-page] |
| step-7 | 수정 버튼 클릭 | - | Element not found: 수정 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-11 | 기본 정보 섹션 - 거래처명 입력 | - | Input not found: 거래처명 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 거래처명 입력 필드 |
| step-12 | 기본 정보 섹션 - 대표자명 입력 | - | Input not found: 대표자명 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 대표자명 입력 필드 |
| step-13 | 기본 정보 섹션 - 악성채권 등록 토글 | - | Element not found: 악성채권 등록 Switch [context: btn:60,input:1,text:not-on-page] |
| step-14 | 기본 정보 섹션 - 업태/업종 입력 | - | Input not found: 업태 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 업태 입력 필드 [con |
| step-15 | 연락처 정보 섹션 - 우편번호 찾기 버튼 | - | Element not found: 우편번호 찾기 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-16 | 연락처 정보 섹션 - 주소 입력 | - | Input not found: 상세주소 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 상세주소 입력 필드 |
| step-17 | 연락처 정보 섹션 - 전화번호 입력 | - | Input not found: 전화번호 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 전화번호 입력 필드 |
| step-18 | 연락처 정보 섹션 - 모바일 입력 | - | Input not found: 모바일 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 모바일 입력 필드 [c |
| step-19 | 연락처 정보 섹션 - 팩스 입력 | - | Input not found: 팩스 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 팩스 입력 필드 [con |
| step-20 | 연락처 정보 섹션 - 이메일 입력 | - | Input not found: 이메일 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 이메일 입력 필드 [c |
| step-21 | 담당자 정보 섹션 - 담당자명 입력 | - | Input not found: 담당자명 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 담당자명 입력 필드 |
| step-22 | 담당자 정보 섹션 - 담당자 전화 입력 | - | Input not found: 담당자 전화 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 담당자 전화 입력 |
| step-26 | 악성 채권 정보 섹션 - 미수금 입력 | - | Input not found: 미수금 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 미수금 입력 필드 [c |
| step-27 | 악성 채권 정보 섹션 - 상태 선택 | - | Element not found: 상태 드롭다운 [context: btn:60,input:1,text:not-on-page]; Select not found: 상태 옵션 [cont |
| step-28 | 악성 채권 정보 섹션 - 연체일수 입력 | - | Input not found: 연체일수 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 연체일수 입력 필드 |
| step-29 | 악성 채권 정보 섹션 - 본사 담당자 선택 | - | Element not found: 본사 담당자 드롭다운 [context: btn:60,input:1,text:not-on-page]; Select not found: 담당자 옵션 |
| step-30 | 악성 채권 정보 섹션 - 악성채권 발생일 입력 | - | Input not found: 악성채권 발생일 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 악성채권 발생 |
| step-31 | 악성 채권 정보 섹션 - 악성채권 종료일 입력 | - | Input not found: 악성채권 종료일 입력 필드 [context: btn:60,input:1,text:not-on-page]; Input not found: 악성채권 종료 |
| step-33 | 이동 버튼 - 수취 어음 현황 클릭 | - | Element not found: 수취 어음 현황 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-36 | 이동 버튼 - 거래처 미수금 현황 클릭 | - | Element not found: 거래처 미수금 현황 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-40 | 메모 섹션 - 메모 입력 | - | Input not found: 메모 입력 Textarea [context: btn:60,input:1,text:not-on-page]; Input not found: 메모 입력 T |
| step-41 | 메모 섹션 - 메모 추가 버튼 클릭 | - | Element not found: 메모 추가 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-43 | 메모 섹션 - 추가 메모 입력 | - | Input not found: 메모 입력 Textarea [context: btn:60,input:1,text:not-on-page]; Input not found: 메모 입력 T |
| step-45 | 메모 섹션 - 메모 삭제 | - | Element not found: 첫 번째 메모 삭제 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-46 | 저장 버튼 클릭 | - | Element not found: 저장 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-47 | 저장 확인 다이얼로그 - 취소 버튼 | - | Element not found: 다이얼로그 취소 버튼 [context: btn:60,input:1,text:not-on-page] |
| step-48 | 저장 버튼 재클릭 및 확인 | - | Element not found: 저장 버튼 [context: btn:60,input:1,text:not-on-page]; Element not found: 다이얼로그 저장 버튼 |
| step-50 | 목록으로 돌아가기 | - | Element not found: 뒤로가기 버튼 [context: btn:60,input:1,text:not-on-page] |
## 전체 스텝 결과
| # | 스텝 | Phase | 상태 | 소요시간 | 비고 |
|---|------|-------|------|---------|------|
| step-0 | 사이드바 초기화 | - | ✅ | 514ms | eval_type:undefined/isPromise:false/val:undefined / Waited 500ms |
| step-1 | 2단계 메뉴 진입: 회계관리 > 악성채권추심관리 | - | ❌ | 10488ms | Found: 회계관리 / Clicked: 회계관리 / Waited 500ms / scrollAndFind: "악성채권추심관리" not found |
| step-2 | 페이지 구조 확인 | - | ⚠️ | 1513ms | Element not found: 페이지 구조 |
| step-3 | 필터 및 검색 기능 테스트 | - | ❌ | 4031ms | Select not found: 상태 필터 [context: btn:60,input:1,text:not-on-page] / Waited 1000 |
| step-4 | 체크박스 선택 전 작업 버튼 확인 | - | ⚠️ | 1514ms | Element not found: 작업 컬럼 |
| step-5 | 첫 번째 행 체크박스 선택 | - | ❌ | 2529ms | Element not found: 첫 번째 행 체크박스 [context: btn:60,input:1,text:not-on-page] / Wait |
| step-6 | 수정 버튼 표시 확인 | - | ⚠️ | 1504ms | Element not found: 작업 컬럼 버튼 |
| step-7 | 수정 버튼 클릭 | - | ❌ | 2544ms | Element not found: 수정 버튼 [context: btn:60,input:1,text:not-on-page] / Waited 100 |
| step-8 | 수정 페이지 구조 확인 | - | ⚠️ | 1509ms | Element not found: 페이지 섹션 및 버튼 |
| step-9 | 기본 정보 섹션 - 사업자등록번호 (읽기전용) | - | ⚠️ | 1534ms | Element not found: 사업자등록번호 필드 |
| step-10 | 기본 정보 섹션 - 거래처 코드 (읽기전용) | - | ⚠️ | 1521ms | Element not found: 거래처 코드 필드 |
| step-11 | 기본 정보 섹션 - 거래처명 입력 | - | ❌ | 3036ms | Input not found: 거래처명 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input n |
| step-12 | 기본 정보 섹션 - 대표자명 입력 | - | ❌ | 3029ms | Input not found: 대표자명 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input n |
| step-13 | 기본 정보 섹션 - 악성채권 등록 토글 | - | ❌ | 2523ms | Element not found: 악성채권 등록 Switch [context: btn:60,input:1,text:not-on-page] / W |
| step-14 | 기본 정보 섹션 - 업태/업종 입력 | - | ❌ | 6056ms | Input not found: 업태 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input not |
| step-15 | 연락처 정보 섹션 - 우편번호 찾기 버튼 | - | ❌ | 2519ms | Element not found: 우편번호 찾기 버튼 [context: btn:60,input:1,text:not-on-page] / Waite |
| step-16 | 연락처 정보 섹션 - 주소 입력 | - | ❌ | 3029ms | Unknown action type: escape / Input not found: 상세주소 입력 필드 [context: btn:60,input |
| step-17 | 연락처 정보 섹션 - 전화번호 입력 | - | ❌ | 3010ms | Input not found: 전화번호 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input n |
| step-18 | 연락처 정보 섹션 - 모바일 입력 | - | ❌ | 3017ms | Input not found: 모바일 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input no |
| step-19 | 연락처 정보 섹션 - 팩스 입력 | - | ❌ | 3027ms | Input not found: 팩스 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input not |
| step-20 | 연락처 정보 섹션 - 이메일 입력 | - | ❌ | 3031ms | Input not found: 이메일 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input no |
| step-21 | 담당자 정보 섹션 - 담당자명 입력 | - | ❌ | 3035ms | Input not found: 담당자명 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input n |
| step-22 | 담당자 정보 섹션 - 담당자 전화 입력 | - | ❌ | 3031ms | Input not found: 담당자 전화 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input |
| step-23 | 필요 서류 섹션 - 사업자등록증 업로드 확인 | - | ⚠️ | 1513ms | Element not found: 사업자등록증 파일 입력 |
| step-24 | 필요 서류 섹션 - 세금계산서 업로드 확인 | - | ⚠️ | 1521ms | Element not found: 세금계산서 파일 입력 |
| step-25 | 필요 서류 섹션 - 추가 서류 추가 버튼 확인 | - | ⚠️ | 1516ms | Element not found: 추가 서류 추가 버튼 |
| step-26 | 악성 채권 정보 섹션 - 미수금 입력 | - | ❌ | 3028ms | Input not found: 미수금 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input no |
| step-27 | 악성 채권 정보 섹션 - 상태 선택 | - | ❌ | 3043ms | Element not found: 상태 드롭다운 [context: btn:60,input:1,text:not-on-page] / Select n |
| step-28 | 악성 채권 정보 섹션 - 연체일수 입력 | - | ❌ | 3036ms | Input not found: 연체일수 입력 필드 [context: btn:60,input:1,text:not-on-page] / Input n |
| step-29 | 악성 채권 정보 섹션 - 본사 담당자 선택 | - | ❌ | 3031ms | Element not found: 본사 담당자 드롭다운 [context: btn:60,input:1,text:not-on-page] / Sele |
| step-30 | 악성 채권 정보 섹션 - 악성채권 발생일 입력 | - | ❌ | 3023ms | Input not found: 악성채권 발생일 입력 필드 [context: btn:60,input:1,text:not-on-page] / Inp |
| step-31 | 악성 채권 정보 섹션 - 악성채권 종료일 입력 | - | ❌ | 3024ms | Input not found: 악성채권 종료일 입력 필드 [context: btn:60,input:1,text:not-on-page] / Inp |
| step-32 | 이동 버튼 - 수취 어음 현황 버튼 확인 | - | ⚠️ | 1531ms | Element not found: 수취 어음 현황 버튼 |
| step-33 | 이동 버튼 - 수취 어음 현황 클릭 | - | ❌ | 2535ms | Element not found: 수취 어음 현황 버튼 [context: btn:60,input:1,text:not-on-page] / Wait |
| step-34 | 이동 후 뒤로가기 (수취 어음 현황 → 대손채권회수 수정) | - | ⚠️ | 1003ms | Unknown action type: back / Waited 1000ms |
| step-35 | 이동 버튼 - 거래처 미수금 현황 버튼 확인 | - | ⚠️ | 1515ms | Element not found: 거래처 미수금 현황 버튼 |
| step-36 | 이동 버튼 - 거래처 미수금 현황 클릭 | - | ❌ | 2520ms | Element not found: 거래처 미수금 현황 버튼 [context: btn:60,input:1,text:not-on-page] / Wa |
| step-37 | 이동 후 뒤로가기 (거래처 미수금 현황 → 대손채권회수 수정) | - | ⚠️ | 1007ms | Unknown action type: back / Waited 1000ms |
| step-38 | 메모 섹션 - 메모 입력 필드 확인 | - | ⚠️ | 1517ms | Element not found: 메모 입력 Textarea |
| step-39 | 메모 섹션 - 메모 추가 버튼 확인 | - | ⚠️ | 1511ms | Element not found: 메모 추가 버튼 |
| step-40 | 메모 섹션 - 메모 입력 | - | ❌ | 3051ms | Input not found: 메모 입력 Textarea [context: btn:60,input:1,text:not-on-page] / Inp |
| step-41 | 메모 섹션 - 메모 추가 버튼 클릭 | - | ❌ | 2525ms | Element not found: 메모 추가 버튼 [context: btn:60,input:1,text:not-on-page] / Waited |
| step-42 | 메모 섹션 - 추가된 메모 확인 | - | ⚠️ | 1536ms | Element not found: 메모 리스트 |
| step-43 | 메모 섹션 - 추가 메모 입력 | - | ❌ | 5582ms | Input not found: 메모 입력 Textarea [context: btn:60,input:1,text:not-on-page] / Inp |
| step-44 | 메모 섹션 - 메모 삭제 버튼 확인 | - | ⚠️ | 1508ms | Element not found: 메모 삭제 버튼 |
| step-45 | 메모 섹션 - 메모 삭제 | - | ❌ | 2519ms | Element not found: 첫 번째 메모 삭제 버튼 [context: btn:60,input:1,text:not-on-page] / Wa |
| step-46 | 저장 버튼 클릭 | - | ❌ | 2535ms | Element not found: 저장 버튼 [context: btn:60,input:1,text:not-on-page] / Waited 100 |
| step-47 | 저장 확인 다이얼로그 - 취소 버튼 | - | ❌ | 2534ms | Element not found: 다이얼로그 취소 버튼 [context: btn:60,input:1,text:not-on-page] / Wait |
| step-48 | 저장 버튼 재클릭 및 확인 | - | ❌ | 5057ms | Element not found: 저장 버튼 [context: btn:60,input:1,text:not-on-page] / Waited 100 |
| step-49 | 상세 페이지 확인 | - | ⚠️ | 1514ms | Element not found: 페이지 모드 및 버튼 |
| step-50 | 목록으로 돌아가기 | - | ❌ | 2526ms | Element not found: 뒤로가기 버튼 [context: btn:60,input:1,text:not-on-page] / Waited 1 |
## API 요약
| 총 호출 | 성공 | 실패 | 평균 응답 | 느린 호출(>2s) |
|---------|------|------|----------|--------------|
| 8 | 8 | 0 | 104ms | 0 |
## 페이지 건강 검사
| 항목 | 결과 |
|------|------|
| 상태 | ✅ 정상 |
| URL | https://dev.codebridge-x.com/accounting/bad-debt-collection |
## 자동 진단
| 항목 | 내용 |
|------|------|
| 근본 원인 | **unknown** |
| 스크린샷 | diag_bad-debt-collection_2026-03-07_21-08-02.png |
### 페이지 상태
| 항목 | 값 |
|------|----|
| DOM 노드 | 800 |
| 테이블 행 | 5 |
| API 호출 수 | 8 |
| 로딩 스피너 | No |