Files
superport/lib/services/health_test_service.dart
JiWoong Sul 1e6da44917
Some checks failed
Flutter Test & Quality Check / Build APK (push) Has been cancelled
Flutter Test & Quality Check / Test on macos-latest (push) Has been cancelled
Flutter Test & Quality Check / Test on ubuntu-latest (push) Has been cancelled
refactor: UI 화면 통합 및 불필요한 파일 정리
- 모든 *_redesign.dart 파일을 기본 화면 파일로 통합
- 백업용 컨트롤러 파일들 제거 (*_controller.backup.dart)
- 사용하지 않는 예제 및 테스트 파일 제거
- Clean Architecture 적용 후 남은 정리 작업 완료
- 테스트 코드 정리 및 구조 개선 준비

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-11 14:00:44 +09:00

193 lines
6.8 KiB
Dart

import 'package:get_it/get_it.dart';
import 'package:superport/services/auth_service.dart';
import 'package:superport/services/dashboard_service.dart';
import 'package:superport/services/equipment_service.dart';
import 'package:superport/services/warehouse_service.dart';
import 'package:superport/services/company_service.dart';
import 'package:superport/core/utils/debug_logger.dart';
import 'package:superport/models/company_model.dart';
/// API 상태 테스트 서비스
class HealthTestService {
final AuthService _authService = GetIt.instance<AuthService>();
final DashboardService _dashboardService = GetIt.instance<DashboardService>();
final EquipmentService _equipmentService = GetIt.instance<EquipmentService>();
final WarehouseService _warehouseService = GetIt.instance<WarehouseService>();
final CompanyService _companyService = GetIt.instance<CompanyService>();
/// 모든 주요 API 엔드포인트 테스트
Future<Map<String, dynamic>> checkAllEndpoints() async {
final results = <String, dynamic>{};
// 1. 인증 상태 확인
try {
final isAuthenticated = await _authService.isLoggedIn();
final accessToken = await _authService.getAccessToken();
final refreshToken = await _authService.getRefreshToken();
results['auth'] = {
'success': isAuthenticated,
'accessToken': accessToken != null,
'refreshToken': refreshToken != null,
};
DebugLogger.log('인증 상태', tag: 'HEALTH_TEST', data: results['auth']);
} catch (e) {
results['auth'] = {'success': false, 'error': e.toString()};
}
// 2. 대시보드 API 체크
try {
DebugLogger.log('대시보드 API 체크 시작', tag: 'HEALTH_TEST');
// Overview Stats
final statsResult = await _dashboardService.getOverviewStats();
results['dashboard_stats'] = {
'success': statsResult.isRight(),
'error': statsResult.fold((l) => l.message, (r) => null),
'data': statsResult.fold((l) => null, (r) => {
'totalEquipment': r.totalEquipment,
'totalCompanies': r.totalCompanies,
'totalUsers': r.totalUsers,
'availableEquipment': r.availableEquipment,
}),
};
// Equipment Status Distribution
final statusResult = await _dashboardService.getEquipmentStatusDistribution();
results['equipment_status_distribution'] = {
'success': statusResult.isRight(),
'error': statusResult.fold((l) => l.message, (r) => null),
'data': statusResult.fold((l) => null, (r) => {
'available': r.available,
'inUse': r.inUse,
'maintenance': r.maintenance,
'disposed': r.disposed,
}),
};
DebugLogger.log('대시보드 API 결과', tag: 'HEALTH_TEST', data: results);
} catch (e) {
results['dashboard'] = {'success': false, 'error': e.toString()};
}
// 3. 장비 API 체크
try {
DebugLogger.log('장비 API 체크 시작', tag: 'HEALTH_TEST');
final equipments = await _equipmentService.getEquipments(page: 1, perPage: 5);
results['equipments'] = {
'success': true,
'count': equipments.items.length,
'sample': equipments.items.take(2).map((e) => {
'id': e.id,
'name': e.name,
'manufacturer': e.manufacturer,
'category': e.category,
}).toList(),
};
DebugLogger.log('장비 API 결과', tag: 'HEALTH_TEST', data: results['equipments']);
} catch (e) {
results['equipments'] = {'success': false, 'error': e.toString()};
}
// 4. 입고지 API 체크
try {
DebugLogger.log('입고지 API 체크 시작', tag: 'HEALTH_TEST');
final warehousesResponse = await _warehouseService.getWarehouseLocations();
results['warehouses'] = {
'success': true,
'count': warehousesResponse.items.length,
'sample': warehousesResponse.items.take(2).map((w) => {
'id': w.id,
'name': w.name,
'address': w.address.toString(),
}).toList(),
};
DebugLogger.log('입고지 API 결과', tag: 'HEALTH_TEST', data: results['warehouses']);
} catch (e) {
results['warehouses'] = {'success': false, 'error': e.toString()};
}
// 5. 회사 API 체크
try {
DebugLogger.log('회사 API 체크 시작', tag: 'HEALTH_TEST');
final companiesResponse = await _companyService.getCompanies();
results['companies'] = {
'success': true,
'count': companiesResponse.items.length,
'sample': companiesResponse.items.take(2).map((c) => {
'id': c.id,
'name': c.name,
'companyTypes': c.companyTypes.map((t) => companyTypeToString(t)).toList(),
}).toList(),
};
DebugLogger.log('회사 API 결과', tag: 'HEALTH_TEST', data: results['companies']);
} catch (e) {
results['companies'] = {'success': false, 'error': e.toString()};
}
return results;
}
/// 특정 엔드포인트만 체크
Future<Map<String, dynamic>> checkEndpoint(String endpoint) async {
switch (endpoint) {
case 'dashboard':
final result = await _dashboardService.getOverviewStats();
return {
'success': result.isRight(),
'error': result.fold((l) => l.message, (r) => null),
'data': result.fold((l) => null, (r) => r.toJson()),
};
case 'equipments':
try {
final equipments = await _equipmentService.getEquipments(page: 1, perPage: 10);
return {
'success': true,
'count': equipments.items.length,
'data': equipments.items.map((e) => e.toJson()).toList(),
};
} catch (e) {
return {'success': false, 'error': e.toString()};
}
case 'warehouses':
try {
final warehousesResponse = await _warehouseService.getWarehouseLocations();
return {
'success': true,
'count': warehousesResponse.items.length,
'data': warehousesResponse.items.map((w) => {
'id': w.id,
'name': w.name,
'address': w.address.toString(),
'remark': w.remark,
}).toList(),
};
} catch (e) {
return {'success': false, 'error': e.toString()};
}
case 'companies':
try {
final companies = await _companyService.getCompanies();
return {
'success': true,
'count': companies.items.length,
'data': companies.items.map((c) => c.toJson()).toList(),
};
} catch (e) {
return {'success': false, 'error': e.toString()};
}
default:
return {'success': false, 'error': 'Unknown endpoint: $endpoint'};
}
}
}