- .env.development.example과 lib/core/config/environment.dart, lib/core/permissions/permission_manager.dart에서 PERMISSION__ 폴백을 view 전용으로 좁히고 기본 정책을 명시적으로 거부하도록 재정비했다 - lib/core/navigation/*, lib/core/routing/app_router.dart, lib/widgets/app_shell.dart, lib/main.dart에서 메뉴 매니페스트·카탈로그를 도입해 /menus 응답을 캐싱하고 라우터·사이드바·Breadcrumb가 동일 menu_code/route_path를 쓰도록 리팩터링했다 - lib/core/permissions/permission_resources.dart와 그룹 권한/메뉴 마스터 모듈을 menu_code 기반 CRUD 및 Catalog 경로 정합성 검사로 전환하고 PermissionSynchronizer·PermissionBootstrapper를 확장했다 - test/helpers/test_permissions.dart, test/widgets/app_shell_test.dart 등 신규 구조를 반영하는 테스트·골든과 doc/frontend_menu_permission_tasks.md 문서를 보강했다
116 lines
3.5 KiB
Dart
116 lines
3.5 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:get_it/get_it.dart';
|
|
import 'package:shadcn_ui/shadcn_ui.dart';
|
|
|
|
import 'package:superport_v2/core/config/environment.dart';
|
|
import 'package:superport_v2/core/navigation/route_paths.dart';
|
|
import 'package:superport_v2/core/permissions/permission_manager.dart';
|
|
import 'package:superport_v2/core/theme/superport_shad_theme.dart';
|
|
import 'package:superport_v2/features/inventory/rental/presentation/pages/rental_page.dart';
|
|
|
|
import '../../helpers/inventory_test_stubs.dart';
|
|
|
|
void main() {
|
|
TestWidgetsFlutterBinding.ensureInitialized();
|
|
|
|
setUpAll(() async {
|
|
await Environment.initialize();
|
|
});
|
|
|
|
setUp(() {
|
|
registerInventoryTestStubs(
|
|
const InventoryTestStubConfig(registerProductRepository: true),
|
|
);
|
|
});
|
|
|
|
tearDown(() async {
|
|
await GetIt.I.reset();
|
|
});
|
|
|
|
testWidgets('대여 등록 모달은 번호 입력 없이 자동 생성 안내를 제공한다', (tester) async {
|
|
final view = tester.view;
|
|
view.physicalSize = const Size(1280, 900);
|
|
view.devicePixelRatio = 1.0;
|
|
addTearDown(() {
|
|
view.resetPhysicalSize();
|
|
view.resetDevicePixelRatio();
|
|
});
|
|
|
|
await tester.pumpWidget(
|
|
MaterialApp(
|
|
home: ScaffoldMessenger(
|
|
child: PermissionScope(
|
|
manager: PermissionManager(),
|
|
child: ShadTheme(
|
|
data: SuperportShadTheme.light(),
|
|
child: Scaffold(
|
|
body: RentalPage(
|
|
routeUri: Uri.parse(inventoryRentalsRoutePath),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
await tester.pumpAndSettle();
|
|
|
|
await tester.tap(find.widgetWithText(ShadButton, '대여 등록'));
|
|
await tester.pumpAndSettle();
|
|
|
|
expect(find.text('저장 시 자동 생성'), findsAtLeastNWidgets(2));
|
|
|
|
await tester.tap(find.widgetWithText(ShadButton, '저장'));
|
|
await tester.pump();
|
|
|
|
expect(find.text('거래번호를 입력하세요.'), findsNothing);
|
|
expect(find.text('결재번호를 입력하세요.'), findsNothing);
|
|
expect(find.textContaining('자동완성에서 선택'), findsOneWidget);
|
|
expect(find.text('최소 1개의 고객사를 선택하세요.'), findsOneWidget);
|
|
});
|
|
|
|
testWidgets('대여 상세의 수정 버튼은 수정 모달을 연다', (tester) async {
|
|
final view = tester.view;
|
|
view.physicalSize = const Size(1280, 900);
|
|
view.devicePixelRatio = 1.0;
|
|
addTearDown(() {
|
|
view.resetPhysicalSize();
|
|
view.resetDevicePixelRatio();
|
|
});
|
|
|
|
await tester.pumpWidget(
|
|
MaterialApp(
|
|
home: ScaffoldMessenger(
|
|
child: PermissionScope(
|
|
manager: PermissionManager(),
|
|
child: ShadTheme(
|
|
data: SuperportShadTheme.light(),
|
|
child: Scaffold(
|
|
body: RentalPage(
|
|
routeUri: Uri.parse(inventoryRentalsRoutePath),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
await tester.pumpAndSettle();
|
|
|
|
await tester.tap(find.text('TX-20240305-030').first);
|
|
await tester.pumpAndSettle();
|
|
|
|
expect(find.text('대여 상세'), findsOneWidget);
|
|
|
|
final editButton = find.widgetWithText(ShadButton, '수정').last;
|
|
await tester.ensureVisible(editButton);
|
|
await tester.tap(editButton);
|
|
await tester.pump();
|
|
await tester.pumpAndSettle(const Duration(milliseconds: 500));
|
|
|
|
expect(find.text('대여 수정'), findsOneWidget);
|
|
expect(find.widgetWithText(ShadButton, '저장'), findsWidgets);
|
|
});
|
|
}
|