feat: 결재·마스터 실연동 업데이트

This commit is contained in:
JiWoong Sul
2025-10-14 18:10:24 +09:00
parent 1325109fba
commit 8067416c09
66 changed files with 2129 additions and 222 deletions

View File

@@ -2,8 +2,11 @@ import 'package:flutter_test/flutter_test.dart';
import 'package:mocktail/mocktail.dart';
import 'package:superport_v2/core/common/models/paginated_result.dart';
import 'package:superport_v2/core/permissions/permission_manager.dart';
import 'package:superport_v2/features/masters/group/domain/entities/group.dart';
import 'package:superport_v2/features/masters/group/domain/repositories/group_repository.dart';
import 'package:superport_v2/features/masters/group_permission/domain/entities/group_permission.dart';
import 'package:superport_v2/features/masters/group_permission/domain/repositories/group_permission_repository.dart';
import 'package:superport_v2/features/masters/user/domain/entities/user.dart';
import 'package:superport_v2/features/masters/user/domain/repositories/user_repository.dart';
import 'package:superport_v2/features/masters/user/presentation/controllers/user_controller.dart';
@@ -12,12 +15,17 @@ class _MockUserRepository extends Mock implements UserRepository {}
class _MockGroupRepository extends Mock implements GroupRepository {}
class _MockGroupPermissionRepository extends Mock
implements GroupPermissionRepository {}
class _FakeUserInput extends Fake implements UserInput {}
void main() {
late UserController controller;
late _MockUserRepository userRepository;
late _MockGroupRepository groupRepository;
late _MockGroupPermissionRepository permissionRepository;
late PermissionManager permissionManager;
final sampleUser = UserAccount(
id: 1,
@@ -44,9 +52,43 @@ void main() {
setUp(() {
userRepository = _MockUserRepository();
groupRepository = _MockGroupRepository();
permissionRepository = _MockGroupPermissionRepository();
permissionManager = PermissionManager();
when(
() => permissionRepository.list(
page: any(named: 'page'),
pageSize: any(named: 'pageSize'),
groupId: any(named: 'groupId'),
menuId: any(named: 'menuId'),
isActive: any(named: 'isActive'),
includeDeleted: any(named: 'includeDeleted'),
),
).thenAnswer(
(_) async => PaginatedResult<GroupPermission>(
items: [
GroupPermission(
id: 1,
group: GroupPermissionGroup(id: 1, groupName: '관리자'),
menu: GroupPermissionMenu(
id: 10,
menuCode: 'DASHBOARD',
menuName: '대시보드',
path: '/dashboard',
),
canCreate: true,
canRead: true,
),
],
page: 1,
pageSize: 200,
total: 1,
),
);
controller = UserController(
userRepository: userRepository,
groupRepository: groupRepository,
permissionRepository: permissionRepository,
permissionManager: permissionManager,
);
});
@@ -58,6 +100,8 @@ void main() {
query: any(named: 'query'),
isDefault: any(named: 'isDefault'),
isActive: any(named: 'isActive'),
includePermissions: any(named: 'includePermissions'),
includeEmployees: any(named: 'includeEmployees'),
),
).thenAnswer(
(_) async => PaginatedResult<Group>(
@@ -82,6 +126,8 @@ void main() {
query: any(named: 'query'),
isDefault: any(named: 'isDefault'),
isActive: any(named: 'isActive'),
includePermissions: any(named: 'includePermissions'),
includeEmployees: any(named: 'includeEmployees'),
),
).thenAnswer(
(_) async => PaginatedResult<Group>(
@@ -195,6 +241,24 @@ void main() {
verify(() => userRepository.delete(1)).called(1);
});
test('delete 이후 권한 동기화를 시도한다', () async {
when(() => userRepository.delete(any())).thenAnswer((_) async {});
await controller.fetch();
await controller.delete(sampleUser.id!);
verify(
() => permissionRepository.list(
page: any(named: 'page'),
pageSize: any(named: 'pageSize'),
groupId: sampleUser.group!.id,
menuId: any(named: 'menuId'),
isActive: any(named: 'isActive'),
includeDeleted: any(named: 'includeDeleted'),
),
).called(greaterThanOrEqualTo(1));
});
test('restore 성공', () async {
when(
() => userRepository.restore(any()),