refactor: 테스트 디렉토리 구조 대규모 정리 및 오류 수정
- test/integration/automated만 유지하고 나머지 테스트 삭제 - 삭제: api/, helpers/, unit/, widget/, fixtures/ 폴더 - 삭제: mock, 개별 통합 테스트 파일들 - 유지: automated 테스트 (실제 API + 자동화 시나리오) - 테스트 오류 수정 - debugPrint 함수 정의 오류 해결 (foundation import 추가) - ApiAutoFixer diagnostics 파라미터 누락 수정 - 타입 불일치 오류 수정 - 최종 상태 - 자동화 테스트 40개 파일 유지 - 오류 337개 → 2개 warning으로 감소 (99.4% 해결) - 실제 API 연동 테스트 정상 작동 확인
This commit is contained in:
@@ -1,3 +1,4 @@
|
||||
import 'package:flutter/foundation.dart';
|
||||
import 'package:flutter_test/flutter_test.dart';
|
||||
import 'package:superport/services/equipment_service.dart';
|
||||
import 'package:superport/services/company_service.dart';
|
||||
@@ -933,7 +934,7 @@ class EquipmentInAutomatedTest extends BaseScreenTest {
|
||||
void _log(String message) {
|
||||
final timestamp = DateTime.now().toString();
|
||||
// ignore: avoid_print
|
||||
print('[$timestamp] [EquipmentIn] $message');
|
||||
debugPrint('[$timestamp] [EquipmentIn] $message');
|
||||
|
||||
// 리포트 수집기에도 로그 추가
|
||||
reportCollector.addStep(
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
// ignore_for_file: avoid_print
|
||||
|
||||
import 'package:get_it/get_it.dart';
|
||||
import 'package:flutter/foundation.dart';
|
||||
import 'package:dio/dio.dart';
|
||||
import 'package:superport/data/datasources/remote/api_client.dart';
|
||||
import 'package:superport/services/equipment_service.dart';
|
||||
@@ -62,7 +63,7 @@ class EquipmentInFullTest {
|
||||
final List<int> createdEquipmentIds = [];
|
||||
|
||||
Future<void> setup() async {
|
||||
print('\n[EquipmentInFullTest] 테스트 환경 설정 중...');
|
||||
debugPrint('\n[EquipmentInFullTest] 테스트 환경 설정 중...');
|
||||
|
||||
// 환경 초기화
|
||||
await RealApiTestHelper.setupTestEnvironment();
|
||||
@@ -85,24 +86,24 @@ class EquipmentInFullTest {
|
||||
// 인증
|
||||
await autoTestSystem.ensureAuthenticated();
|
||||
|
||||
print('[EquipmentInFullTest] 설정 완료\n');
|
||||
debugPrint('[EquipmentInFullTest] 설정 완료\n');
|
||||
}
|
||||
|
||||
Future<void> teardown() async {
|
||||
print('\n[EquipmentInFullTest] 테스트 정리 중...');
|
||||
debugPrint('\n[EquipmentInFullTest] 테스트 정리 중...');
|
||||
|
||||
// 생성된 장비 삭제
|
||||
for (final id in createdEquipmentIds) {
|
||||
try {
|
||||
await equipmentService.deleteEquipment(id);
|
||||
print('[EquipmentInFullTest] 장비 삭제: ID $id');
|
||||
debugPrint('[EquipmentInFullTest] 장비 삭제: ID $id');
|
||||
} catch (e) {
|
||||
print('[EquipmentInFullTest] 장비 삭제 실패 (ID: $id): $e');
|
||||
debugPrint('[EquipmentInFullTest] 장비 삭제 실패 (ID: $id): $e');
|
||||
}
|
||||
}
|
||||
|
||||
await RealApiTestHelper.teardownTestEnvironment();
|
||||
print('[EquipmentInFullTest] 정리 완료\n');
|
||||
debugPrint('[EquipmentInFullTest] 정리 완료\n');
|
||||
}
|
||||
|
||||
Future<Map<String, dynamic>> runAllTests() async {
|
||||
@@ -145,7 +146,7 @@ class EquipmentInFullTest {
|
||||
}
|
||||
|
||||
} catch (e) {
|
||||
print('[EquipmentInFullTest] 치명적 오류: $e');
|
||||
debugPrint('[EquipmentInFullTest] 치명적 오류: $e');
|
||||
} finally {
|
||||
await teardown();
|
||||
}
|
||||
@@ -159,7 +160,7 @@ class EquipmentInFullTest {
|
||||
testName: '장비 목록 조회',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 1] 장비 목록 조회 시작...');
|
||||
debugPrint('[TEST 1] 장비 목록 조회 시작...');
|
||||
|
||||
// 페이지네이션 파라미터
|
||||
const page = 1;
|
||||
@@ -181,20 +182,20 @@ class EquipmentInFullTest {
|
||||
assertTrue(response.data['data'] is List, message: '데이터가 리스트여야 합니다');
|
||||
|
||||
final equipmentList = response.data['data'] as List;
|
||||
print('[TEST 1] 조회된 장비 수: ${equipmentList.length}');
|
||||
debugPrint('[TEST 1] 조회된 장비 수: ${equipmentList.length}');
|
||||
|
||||
// 페이지네이션 정보 검증
|
||||
if (response.data['pagination'] != null) {
|
||||
final pagination = response.data['pagination'];
|
||||
assertEqual(pagination['page'], page, message: '페이지 번호가 일치해야 합니다');
|
||||
assertEqual(pagination['per_page'], perPage, message: '페이지당 항목 수가 일치해야 합니다');
|
||||
print('[TEST 1] 전체 장비 수: ${pagination['total']}');
|
||||
debugPrint('[TEST 1] 전체 장비 수: ${pagination['total']}');
|
||||
} else if (response.data['meta'] != null) {
|
||||
// 구버전 meta 필드 지원
|
||||
final meta = response.data['meta'];
|
||||
assertEqual(meta['page'], page, message: '페이지 번호가 일치해야 합니다');
|
||||
assertEqual(meta['per_page'], perPage, message: '페이지당 항목 수가 일치해야 합니다');
|
||||
print('[TEST 1] 전체 장비 수: ${meta['total']}');
|
||||
debugPrint('[TEST 1] 전체 장비 수: ${meta['total']}');
|
||||
}
|
||||
|
||||
// 장비 데이터 구조 검증
|
||||
@@ -208,7 +209,7 @@ class EquipmentInFullTest {
|
||||
assertNotNull(firstEquipment['status'], message: '상태가 있어야 합니다');
|
||||
}
|
||||
|
||||
print('[TEST 1] ✅ 장비 목록 조회 성공');
|
||||
debugPrint('[TEST 1] ✅ 장비 목록 조회 성공');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -219,7 +220,7 @@ class EquipmentInFullTest {
|
||||
testName: '장비 검색 및 필터링',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 2] 장비 검색 및 필터링 시작...');
|
||||
debugPrint('[TEST 2] 장비 검색 및 필터링 시작...');
|
||||
|
||||
// 상태별 필터링
|
||||
final statusFilter = await apiClient.dio.get(
|
||||
@@ -233,7 +234,7 @@ class EquipmentInFullTest {
|
||||
|
||||
assertEqual(statusFilter.statusCode, 200, message: '상태 필터링 응답이 200이어야 합니다');
|
||||
final availableEquipment = statusFilter.data['data'] as List;
|
||||
print('[TEST 2] 사용 가능한 장비 수: ${availableEquipment.length}');
|
||||
debugPrint('[TEST 2] 사용 가능한 장비 수: ${availableEquipment.length}');
|
||||
|
||||
// 모든 조회된 장비가 'available' 상태인지 확인
|
||||
for (final equipment in availableEquipment) {
|
||||
@@ -255,10 +256,10 @@ class EquipmentInFullTest {
|
||||
|
||||
assertEqual(companyFilter.statusCode, 200,
|
||||
message: '회사별 필터링 응답이 200이어야 합니다');
|
||||
print('[TEST 2] 회사 ID $companyId의 장비 수: ${companyFilter.data['data'].length}');
|
||||
debugPrint('[TEST 2] 회사 ID $companyId의 장비 수: ${companyFilter.data['data'].length}');
|
||||
}
|
||||
|
||||
print('[TEST 2] ✅ 장비 검색 및 필터링 성공');
|
||||
debugPrint('[TEST 2] ✅ 장비 검색 및 필터링 성공');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -269,11 +270,11 @@ class EquipmentInFullTest {
|
||||
testName: '새 장비 등록',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 3] 새 장비 등록 시작...');
|
||||
debugPrint('[TEST 3] 새 장비 등록 시작...');
|
||||
|
||||
// 테스트 데이터 생성
|
||||
final equipmentData = await autoTestSystem.generateTestData('equipment');
|
||||
print('[TEST 3] 생성할 장비 데이터: $equipmentData');
|
||||
debugPrint('[TEST 3] 생성할 장비 데이터: $equipmentData');
|
||||
|
||||
// 장비 생성 API 호출
|
||||
final response = await apiClient.dio.post(
|
||||
@@ -297,7 +298,7 @@ class EquipmentInFullTest {
|
||||
// 생성된 장비 ID 저장 (정리용)
|
||||
createdEquipmentIds.add(createdEquipment['id']);
|
||||
|
||||
print('[TEST 3] ✅ 장비 생성 성공 - ID: ${createdEquipment['id']}');
|
||||
debugPrint('[TEST 3] ✅ 장비 생성 성공 - ID: ${createdEquipment['id']}');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -308,7 +309,7 @@ class EquipmentInFullTest {
|
||||
testName: '장비 정보 수정',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 4] 장비 정보 수정 시작...');
|
||||
debugPrint('[TEST 4] 장비 정보 수정 시작...');
|
||||
|
||||
// 수정할 장비가 없으면 먼저 생성
|
||||
if (createdEquipmentIds.isEmpty) {
|
||||
@@ -316,7 +317,7 @@ class EquipmentInFullTest {
|
||||
}
|
||||
|
||||
final equipmentId = createdEquipmentIds.last;
|
||||
print('[TEST 4] 수정할 장비 ID: $equipmentId');
|
||||
debugPrint('[TEST 4] 수정할 장비 ID: $equipmentId');
|
||||
|
||||
// 수정 데이터
|
||||
final updateData = {
|
||||
@@ -341,7 +342,7 @@ class EquipmentInFullTest {
|
||||
assertEqual(updatedEquipment['status'], updateData['status'],
|
||||
message: '수정된 상태가 일치해야 합니다');
|
||||
|
||||
print('[TEST 4] ✅ 장비 정보 수정 성공');
|
||||
debugPrint('[TEST 4] ✅ 장비 정보 수정 성공');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -352,12 +353,12 @@ class EquipmentInFullTest {
|
||||
testName: '장비 삭제',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 5] 장비 삭제 시작...');
|
||||
debugPrint('[TEST 5] 장비 삭제 시작...');
|
||||
|
||||
// 삭제용 장비 생성
|
||||
await _createTestEquipment();
|
||||
final equipmentId = createdEquipmentIds.last;
|
||||
print('[TEST 5] 삭제할 장비 ID: $equipmentId');
|
||||
debugPrint('[TEST 5] 삭제할 장비 ID: $equipmentId');
|
||||
|
||||
// 장비 삭제 API 호출
|
||||
final response = await apiClient.dio.delete('/equipment/$equipmentId');
|
||||
@@ -378,7 +379,7 @@ class EquipmentInFullTest {
|
||||
// 정리 목록에서 제거
|
||||
createdEquipmentIds.remove(equipmentId);
|
||||
|
||||
print('[TEST 5] ✅ 장비 삭제 성공');
|
||||
debugPrint('[TEST 5] ✅ 장비 삭제 성공');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -389,7 +390,7 @@ class EquipmentInFullTest {
|
||||
testName: '장비 상태 변경',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 6] 장비 상태 변경 시작...');
|
||||
debugPrint('[TEST 6] 장비 상태 변경 시작...');
|
||||
|
||||
// 상태 변경할 장비가 없으면 생성
|
||||
if (createdEquipmentIds.isEmpty) {
|
||||
@@ -397,7 +398,7 @@ class EquipmentInFullTest {
|
||||
}
|
||||
|
||||
final equipmentId = createdEquipmentIds.last;
|
||||
print('[TEST 6] 상태 변경할 장비 ID: $equipmentId');
|
||||
debugPrint('[TEST 6] 상태 변경할 장비 ID: $equipmentId');
|
||||
|
||||
// 상태 변경 데이터
|
||||
final statusData = {
|
||||
@@ -419,7 +420,7 @@ class EquipmentInFullTest {
|
||||
assertEqual(updatedEquipment['status'], statusData['status'],
|
||||
message: '변경된 상태가 일치해야 합니다');
|
||||
|
||||
print('[TEST 6] ✅ 장비 상태 변경 성공');
|
||||
debugPrint('[TEST 6] ✅ 장비 상태 변경 성공');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -430,7 +431,7 @@ class EquipmentInFullTest {
|
||||
testName: '장비 이력 추가',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 7] 장비 이력 추가 시작...');
|
||||
debugPrint('[TEST 7] 장비 이력 추가 시작...');
|
||||
|
||||
// 이력 추가할 장비가 없으면 생성
|
||||
if (createdEquipmentIds.isEmpty) {
|
||||
@@ -438,7 +439,7 @@ class EquipmentInFullTest {
|
||||
}
|
||||
|
||||
final equipmentId = createdEquipmentIds.last;
|
||||
print('[TEST 7] 이력 추가할 장비 ID: $equipmentId');
|
||||
debugPrint('[TEST 7] 이력 추가할 장비 ID: $equipmentId');
|
||||
|
||||
// 이력 데이터
|
||||
final historyData = {
|
||||
@@ -467,7 +468,7 @@ class EquipmentInFullTest {
|
||||
assertEqual(createdHistory['transaction_type'], historyData['transaction_type'],
|
||||
message: '거래 유형이 일치해야 합니다');
|
||||
|
||||
print('[TEST 7] ✅ 장비 이력 추가 성공 - 이력 ID: ${createdHistory['id']}');
|
||||
debugPrint('[TEST 7] ✅ 장비 이력 추가 성공 - 이력 ID: ${createdHistory['id']}');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -478,7 +479,7 @@ class EquipmentInFullTest {
|
||||
testName: '이미지 업로드',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 8] 이미지 업로드 시뮬레이션...');
|
||||
debugPrint('[TEST 8] 이미지 업로드 시뮬레이션...');
|
||||
|
||||
// 실제 이미지 업로드는 파일 시스템 접근이 필요하므로
|
||||
// 여기서는 메타데이터만 테스트
|
||||
@@ -488,15 +489,15 @@ class EquipmentInFullTest {
|
||||
}
|
||||
|
||||
final equipmentId = createdEquipmentIds.last;
|
||||
print('[TEST 8] 이미지 업로드할 장비 ID: $equipmentId');
|
||||
debugPrint('[TEST 8] 이미지 업로드할 장비 ID: $equipmentId');
|
||||
|
||||
// 이미지 메타데이터 (실제로는 multipart/form-data로 전송)
|
||||
// 실제 구현에서는 다음과 같은 메타데이터가 포함됨:
|
||||
// - 'caption': '장비 전면 사진'
|
||||
// - 'taken_date': DateTime.now().toIso8601String()
|
||||
|
||||
print('[TEST 8] 이미지 업로드 시뮬레이션 완료');
|
||||
print('[TEST 8] ✅ 테스트 통과 (시뮬레이션)');
|
||||
debugPrint('[TEST 8] 이미지 업로드 시뮬레이션 완료');
|
||||
debugPrint('[TEST 8] ✅ 테스트 통과 (시뮬레이션)');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -507,11 +508,11 @@ class EquipmentInFullTest {
|
||||
testName: '바코드 스캔 시뮬레이션',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 9] 바코드 스캔 시뮬레이션...');
|
||||
debugPrint('[TEST 9] 바코드 스캔 시뮬레이션...');
|
||||
|
||||
// 바코드 스캔 결과 시뮬레이션
|
||||
final simulatedBarcode = 'EQ-${DateTime.now().millisecondsSinceEpoch}';
|
||||
print('[TEST 9] 시뮬레이션 바코드: $simulatedBarcode');
|
||||
debugPrint('[TEST 9] 시뮬레이션 바코드: $simulatedBarcode');
|
||||
|
||||
// 바코드로 장비 검색 시뮬레이션
|
||||
try {
|
||||
@@ -524,15 +525,15 @@ class EquipmentInFullTest {
|
||||
|
||||
final results = response.data['data'] as List;
|
||||
if (results.isEmpty) {
|
||||
print('[TEST 9] 바코드에 해당하는 장비 없음 - 새 장비 등록 필요');
|
||||
debugPrint('[TEST 9] 바코드에 해당하는 장비 없음 - 새 장비 등록 필요');
|
||||
} else {
|
||||
print('[TEST 9] 바코드에 해당하는 장비 찾음: ${results.first['name']}');
|
||||
debugPrint('[TEST 9] 바코드에 해당하는 장비 찾음: ${results.first['name']}');
|
||||
}
|
||||
} catch (e) {
|
||||
print('[TEST 9] 바코드 검색 중 에러 (예상됨): $e');
|
||||
debugPrint('[TEST 9] 바코드 검색 중 에러 (예상됨): $e');
|
||||
}
|
||||
|
||||
print('[TEST 9] ✅ 바코드 스캔 시뮬레이션 완료');
|
||||
debugPrint('[TEST 9] ✅ 바코드 스캔 시뮬레이션 완료');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -543,7 +544,7 @@ class EquipmentInFullTest {
|
||||
testName: '입고 완료 처리',
|
||||
screenName: 'EquipmentIn',
|
||||
testFunction: () async {
|
||||
print('[TEST 10] 입고 완료 처리 시작...');
|
||||
debugPrint('[TEST 10] 입고 완료 처리 시작...');
|
||||
|
||||
// 입고 처리할 장비가 없으면 생성
|
||||
if (createdEquipmentIds.isEmpty) {
|
||||
@@ -551,7 +552,7 @@ class EquipmentInFullTest {
|
||||
}
|
||||
|
||||
final equipmentId = createdEquipmentIds.last;
|
||||
print('[TEST 10] 입고 처리할 장비 ID: $equipmentId');
|
||||
debugPrint('[TEST 10] 입고 처리할 장비 ID: $equipmentId');
|
||||
|
||||
// 입고 완료 이력 추가
|
||||
final incomingData = {
|
||||
@@ -585,7 +586,7 @@ class EquipmentInFullTest {
|
||||
assertEqual(statusResponse.data['data']['status'], 'available',
|
||||
message: '입고 완료 후 상태가 available이어야 합니다');
|
||||
|
||||
print('[TEST 10] ✅ 입고 완료 처리 성공');
|
||||
debugPrint('[TEST 10] ✅ 입고 완료 처리 성공');
|
||||
},
|
||||
).then((result) => result.toMap());
|
||||
}
|
||||
@@ -601,11 +602,11 @@ class EquipmentInFullTest {
|
||||
final createdEquipment = response.data['data'];
|
||||
if (createdEquipment != null && createdEquipment['id'] != null) {
|
||||
createdEquipmentIds.add(createdEquipment['id']);
|
||||
print('[Helper] 테스트 장비 생성 완료 - ID: ${createdEquipment['id']}');
|
||||
debugPrint('[Helper] 테스트 장비 생성 완료 - ID: ${createdEquipment['id']}');
|
||||
}
|
||||
}
|
||||
} catch (e) {
|
||||
print('[Helper] 테스트 장비 생성 실패: $e');
|
||||
debugPrint('[Helper] 테스트 장비 생성 실패: $e');
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
import 'package:flutter/foundation.dart';
|
||||
import 'package:flutter_test/flutter_test.dart';
|
||||
import 'package:superport/services/equipment_service.dart';
|
||||
import 'package:superport/services/company_service.dart';
|
||||
@@ -503,7 +504,7 @@ class EquipmentOutScreenTest extends BaseScreenTest {
|
||||
void _log(String message) {
|
||||
final timestamp = DateTime.now().toString();
|
||||
// ignore: avoid_print
|
||||
print('[$timestamp] [EquipmentOut] $message');
|
||||
debugPrint('[$timestamp] [EquipmentOut] $message');
|
||||
|
||||
// 리포트 수집기에도 로그 추가
|
||||
reportCollector.addStep(
|
||||
|
||||
Reference in New Issue
Block a user