@tomei/sso 0.35.2 → 0.35.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/.commitlintrc.json +22 -22
  2. package/.eslintrc +16 -16
  3. package/.eslintrc.js +35 -35
  4. package/.gitlab-ci.yml +16 -16
  5. package/.husky/commit-msg +15 -15
  6. package/.husky/pre-commit +7 -7
  7. package/.prettierrc +4 -4
  8. package/Jenkinsfile +57 -57
  9. package/README.md +23 -23
  10. package/__tests__/unit/components/group/group.spec.ts +79 -79
  11. package/__tests__/unit/components/group-object-privilege/group-object-privilege.spec.ts +88 -88
  12. package/__tests__/unit/components/group-privilege/group-privilege.spec.ts +68 -68
  13. package/__tests__/unit/components/group-reporting-user/group-reporting-user.spec.ts +66 -66
  14. package/__tests__/unit/components/group-system-access/group-system-access.spec.ts +83 -83
  15. package/__tests__/unit/components/login-user/l.spec.ts +746 -746
  16. package/__tests__/unit/components/login-user/login.spec.ts +1164 -1164
  17. package/__tests__/unit/components/password-hash/password-hash.service.spec.ts +31 -31
  18. package/__tests__/unit/components/system/system.spec.ts +254 -254
  19. package/__tests__/unit/components/system-privilege/system-privilege.spec.ts +83 -83
  20. package/__tests__/unit/components/user-group/user-group.spec.ts +86 -86
  21. package/__tests__/unit/components/user-object-privilege/user-object-privilege.spec.ts +78 -78
  22. package/__tests__/unit/components/user-privilege/user-privilege.spec.ts +72 -72
  23. package/__tests__/unit/components/user-system-access/user-system-access.spec.ts +89 -89
  24. package/__tests__/unit/redis-client/redis.service.spec.ts +23 -23
  25. package/__tests__/unit/session/session.service.spec.ts +47 -47
  26. package/__tests__/unit/system-privilege/system-privilage.spec.ts +91 -91
  27. package/coverage/clover.xml +1452 -1452
  28. package/coverage/coverage-final.json +47 -47
  29. package/coverage/lcov-report/base.css +224 -224
  30. package/coverage/lcov-report/block-navigation.js +87 -87
  31. package/coverage/lcov-report/components/group/group.repository.ts.html +117 -117
  32. package/coverage/lcov-report/components/group/group.ts.html +327 -327
  33. package/coverage/lcov-report/components/group/index.html +130 -130
  34. package/coverage/lcov-report/components/group-object-privilege/group-object-privilege.repository.ts.html +117 -117
  35. package/coverage/lcov-report/components/group-object-privilege/group-object-privilege.ts.html +321 -321
  36. package/coverage/lcov-report/components/group-object-privilege/index.html +130 -130
  37. package/coverage/lcov-report/components/group-privilege/group-privilege.repository.ts.html +117 -117
  38. package/coverage/lcov-report/components/group-privilege/group-privilege.ts.html +303 -303
  39. package/coverage/lcov-report/components/group-privilege/index.html +130 -130
  40. package/coverage/lcov-report/components/group-reporting-user/group-reporting-user.repository.ts.html +117 -117
  41. package/coverage/lcov-report/components/group-reporting-user/group-reporting-user.ts.html +327 -327
  42. package/coverage/lcov-report/components/group-reporting-user/index.html +130 -130
  43. package/coverage/lcov-report/components/group-system-access/group-system-access.repository.ts.html +117 -117
  44. package/coverage/lcov-report/components/group-system-access/group-system-access.ts.html +309 -309
  45. package/coverage/lcov-report/components/group-system-access/index.html +130 -130
  46. package/coverage/lcov-report/components/login-history/index.html +115 -115
  47. package/coverage/lcov-report/components/login-history/login-history.repository.ts.html +117 -117
  48. package/coverage/lcov-report/components/login-user/index.html +130 -130
  49. package/coverage/lcov-report/components/login-user/login-user.ts.html +5007 -5007
  50. package/coverage/lcov-report/components/login-user/user.repository.ts.html +117 -117
  51. package/coverage/lcov-report/components/password-hash/index.html +115 -115
  52. package/coverage/lcov-report/components/password-hash/password-hash.service.ts.html +126 -126
  53. package/coverage/lcov-report/components/system/index.html +130 -130
  54. package/coverage/lcov-report/components/system/system.repository.ts.html +117 -117
  55. package/coverage/lcov-report/components/system/system.ts.html +909 -909
  56. package/coverage/lcov-report/components/system-privilege/index.html +130 -130
  57. package/coverage/lcov-report/components/system-privilege/system-privilege.repository.ts.html +120 -120
  58. package/coverage/lcov-report/components/system-privilege/system-privilege.ts.html +390 -390
  59. package/coverage/lcov-report/components/user-group/index.html +130 -130
  60. package/coverage/lcov-report/components/user-group/user-group.repository.ts.html +117 -117
  61. package/coverage/lcov-report/components/user-group/user-group.ts.html +354 -354
  62. package/coverage/lcov-report/components/user-object-privilege/index.html +130 -130
  63. package/coverage/lcov-report/components/user-object-privilege/user-object-privilege.repository.ts.html +117 -117
  64. package/coverage/lcov-report/components/user-object-privilege/user-object-privilege.ts.html +312 -312
  65. package/coverage/lcov-report/components/user-privilege/index.html +130 -130
  66. package/coverage/lcov-report/components/user-privilege/user-privilege.repository.ts.html +117 -117
  67. package/coverage/lcov-report/components/user-privilege/user-privilege.ts.html +306 -306
  68. package/coverage/lcov-report/components/user-system-access/index.html +130 -130
  69. package/coverage/lcov-report/components/user-system-access/user-system-access.repository.ts.html +117 -117
  70. package/coverage/lcov-report/components/user-system-access/user-system-access.ts.html +312 -312
  71. package/coverage/lcov-report/enum/group-type.enum.ts.html +108 -108
  72. package/coverage/lcov-report/enum/index.html +160 -160
  73. package/coverage/lcov-report/enum/index.ts.html +93 -93
  74. package/coverage/lcov-report/enum/user-status.enum.ts.html +105 -105
  75. package/coverage/lcov-report/enum/yn.enum.ts.html +96 -96
  76. package/coverage/lcov-report/index.html +370 -370
  77. package/coverage/lcov-report/models/group-object-privilege.entity.ts.html +333 -333
  78. package/coverage/lcov-report/models/group-privilege.entity.ts.html +315 -315
  79. package/coverage/lcov-report/models/group-reporting-user.entity.ts.html +339 -339
  80. package/coverage/lcov-report/models/group-system-access.entity.ts.html +324 -324
  81. package/coverage/lcov-report/models/group.entity.ts.html +435 -435
  82. package/coverage/lcov-report/models/index.html +310 -310
  83. package/coverage/lcov-report/models/login-history.entity.ts.html +252 -252
  84. package/coverage/lcov-report/models/staff.entity.ts.html +411 -411
  85. package/coverage/lcov-report/models/system-privilege.entity.ts.html +354 -354
  86. package/coverage/lcov-report/models/system.entity.ts.html +423 -423
  87. package/coverage/lcov-report/models/user-group.entity.ts.html +354 -354
  88. package/coverage/lcov-report/models/user-object-privilege.entity.ts.html +330 -330
  89. package/coverage/lcov-report/models/user-privilege.entity.ts.html +315 -315
  90. package/coverage/lcov-report/models/user-system-access.entity.ts.html +315 -315
  91. package/coverage/lcov-report/models/user.entity.ts.html +522 -522
  92. package/coverage/lcov-report/prettify.css +1 -1
  93. package/coverage/lcov-report/prettify.js +2 -2
  94. package/coverage/lcov-report/redis-client/index.html +115 -115
  95. package/coverage/lcov-report/redis-client/redis.service.ts.html +240 -240
  96. package/coverage/lcov-report/session/index.html +115 -115
  97. package/coverage/lcov-report/session/session.service.ts.html +246 -246
  98. package/coverage/lcov-report/sorter.js +196 -196
  99. package/coverage/lcov.info +2490 -2490
  100. package/coverage/test-report.xml +128 -128
  101. package/create-sso-user.sql +39 -39
  102. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.d.ts +1 -0
  103. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.js +71 -0
  104. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.js.map +1 -0
  105. package/dist/__tests__/unit/components/login-user/login-user.spec.d.ts +0 -0
  106. package/dist/__tests__/unit/components/login-user/login-user.spec.js +6 -0
  107. package/dist/__tests__/unit/components/login-user/login-user.spec.js.map +1 -0
  108. package/dist/src/components/login-user/user.js +1 -1
  109. package/dist/src/components/login-user/user.js.map +1 -1
  110. package/dist/tsconfig.tsbuildinfo +1 -1
  111. package/jest.config.js +14 -14
  112. package/migrations/20240314080602-create-user-table.js +124 -124
  113. package/migrations/20240314080603-create-user-group-table.js +85 -85
  114. package/migrations/20240314080604-create-user-user-group-table.js +55 -55
  115. package/migrations/20240314080605-create-login-history-table.js +53 -53
  116. package/migrations/20240527064925-create-system-table.js +78 -78
  117. package/migrations/20240527064926-create-system-privilege-table.js +67 -67
  118. package/migrations/20240527065342-create-group-table.js +89 -89
  119. package/migrations/20240527065633-create-group-reporting-user-table.js +76 -76
  120. package/migrations/20240528011551-create-group-system-access-table.js +72 -72
  121. package/migrations/20240528023018-user-system-access-table.js +75 -75
  122. package/migrations/20240528032229-user-privilege-table.js +75 -75
  123. package/migrations/20240528063003-create-group-privilege-table.js +75 -75
  124. package/migrations/20240528063051-create-group-object-privilege-table.js +84 -84
  125. package/migrations/20240528063107-create-user-object-privilege-table.js +83 -83
  126. package/package.json +89 -89
  127. package/sampledotenv +7 -7
  128. package/sonar-project.properties +22 -22
  129. package/src/components/login-user/user.ts +1 -1
  130. package/tsconfig.build.json +5 -5
  131. package/tsconfig.json +22 -22
@@ -1,89 +1,89 @@
1
- import { GroupObjectPrivilegeRepository } from '../../../../src/components/group-object-privilege/group-object-privilege.repository';
2
- import { GroupObjectPrivilege } from '../../../../src/components/group-object-privilege/group-object-privilege';
3
-
4
- describe('GroupObjectPrivilege', () => {
5
- let groupObjectPrivilege: GroupObjectPrivilege;
6
-
7
- beforeEach(() => {
8
- groupObjectPrivilege = new GroupObjectPrivilege();
9
- });
10
-
11
- it('should create an instance of GroupObjectPrivilege', () => {
12
- expect(groupObjectPrivilege).toBeInstanceOf(GroupObjectPrivilege);
13
- });
14
-
15
- it('should have the correct TableName', () => {
16
- expect(groupObjectPrivilege.TableName).toBe('sso_GroupObjectPrivilege');
17
- });
18
-
19
- it('should have the correct properties', () => {
20
- expect(groupObjectPrivilege.ObjectName).toBeUndefined();
21
- expect(groupObjectPrivilege.GroupObjectPrivilegeId).toBeUndefined();
22
- expect(groupObjectPrivilege.GroupCode).toBeUndefined();
23
- expect(groupObjectPrivilege.PrivilegeCode).toBeUndefined();
24
- expect(groupObjectPrivilege.ObjectId).toBeUndefined();
25
- expect(groupObjectPrivilege.ObjectType).toBeUndefined();
26
- expect(groupObjectPrivilege.CreatedAt).toBeUndefined();
27
- expect(groupObjectPrivilege.UpdatedAt).toBeUndefined();
28
- expect(groupObjectPrivilege.CreatedById).toBeUndefined();
29
- expect(groupObjectPrivilege.UpdatedById).toBeUndefined();
30
- });
31
-
32
- describe('init', () => {
33
- it('should return an instance of GroupObjectPrivilege when GroupObjectPrivilegeId is provided', async () => {
34
- const GroupObjectPrivilegeId = 1;
35
- const mockGroupObjectPrivilegeAttr = {
36
- GroupObjectPrivilegeId,
37
- GroupCode: 'groupCode',
38
- PrivilegeCode: 'privilegeCode',
39
- ObjectId: 'objectId',
40
- ObjectType: 'objectType',
41
- CreatedAt: new Date(),
42
- UpdatedAt: new Date(),
43
- CreatedById: 1,
44
- UpdatedById: 2,
45
- };
46
-
47
- jest.spyOn(GroupObjectPrivilegeRepository.prototype, 'findOne').mockResolvedValueOnce({
48
- get: () => mockGroupObjectPrivilegeAttr,
49
- } as any);
50
-
51
- const result = await GroupObjectPrivilege.init(null, GroupObjectPrivilegeId);
52
-
53
- expect(result).toBeInstanceOf(GroupObjectPrivilege);
54
- expect(result.GroupObjectPrivilegeId).toBe(GroupObjectPrivilegeId);
55
- expect(result.GroupCode).toBe(mockGroupObjectPrivilegeAttr.GroupCode);
56
- expect(result.PrivilegeCode).toBe(mockGroupObjectPrivilegeAttr.PrivilegeCode);
57
- expect(result.ObjectId).toBe(mockGroupObjectPrivilegeAttr.ObjectId);
58
- expect(result.ObjectType).toBe(mockGroupObjectPrivilegeAttr.ObjectType);
59
- expect(result.CreatedAt).toBe(mockGroupObjectPrivilegeAttr.CreatedAt);
60
- expect(result.UpdatedAt).toBe(mockGroupObjectPrivilegeAttr.UpdatedAt);
61
- expect(result.CreatedById).toBe(mockGroupObjectPrivilegeAttr.CreatedById);
62
- expect(result.UpdatedById).toBe(mockGroupObjectPrivilegeAttr.UpdatedById);
63
- });
64
-
65
- it('should throw an error when GroupObjectPrivilegeId is provided but no GroupObjectPrivilege is found', async () => {
66
- const GroupObjectPrivilegeId = 1;
67
- jest.spyOn(GroupObjectPrivilegeRepository.prototype, 'findOne').mockResolvedValueOnce(null);
68
-
69
- await expect(GroupObjectPrivilege.init(null, GroupObjectPrivilegeId)).rejects.toThrowError(
70
- 'GroupObjectPrivilege not found',
71
- );
72
- });
73
-
74
- it('should return a new instance of GroupObjectPrivilege when GroupObjectPrivilegeId is not provided', async () => {
75
- const result = await GroupObjectPrivilege.init();
76
-
77
- expect(result).toBeInstanceOf(GroupObjectPrivilege);
78
- expect(result.GroupObjectPrivilegeId).toBeUndefined();
79
- expect(result.GroupCode).toBeUndefined();
80
- expect(result.PrivilegeCode).toBeUndefined();
81
- expect(result.ObjectId).toBeUndefined();
82
- expect(result.ObjectType).toBeUndefined();
83
- expect(result.CreatedAt).toBeUndefined();
84
- expect(result.UpdatedAt).toBeUndefined();
85
- expect(result.CreatedById).toBeUndefined();
86
- expect(result.UpdatedById).toBeUndefined();
87
- });
88
- });
1
+ import { GroupObjectPrivilegeRepository } from '../../../../src/components/group-object-privilege/group-object-privilege.repository';
2
+ import { GroupObjectPrivilege } from '../../../../src/components/group-object-privilege/group-object-privilege';
3
+
4
+ describe('GroupObjectPrivilege', () => {
5
+ let groupObjectPrivilege: GroupObjectPrivilege;
6
+
7
+ beforeEach(() => {
8
+ groupObjectPrivilege = new GroupObjectPrivilege();
9
+ });
10
+
11
+ it('should create an instance of GroupObjectPrivilege', () => {
12
+ expect(groupObjectPrivilege).toBeInstanceOf(GroupObjectPrivilege);
13
+ });
14
+
15
+ it('should have the correct TableName', () => {
16
+ expect(groupObjectPrivilege.TableName).toBe('sso_GroupObjectPrivilege');
17
+ });
18
+
19
+ it('should have the correct properties', () => {
20
+ expect(groupObjectPrivilege.ObjectName).toBeUndefined();
21
+ expect(groupObjectPrivilege.GroupObjectPrivilegeId).toBeUndefined();
22
+ expect(groupObjectPrivilege.GroupCode).toBeUndefined();
23
+ expect(groupObjectPrivilege.PrivilegeCode).toBeUndefined();
24
+ expect(groupObjectPrivilege.ObjectId).toBeUndefined();
25
+ expect(groupObjectPrivilege.ObjectType).toBeUndefined();
26
+ expect(groupObjectPrivilege.CreatedAt).toBeUndefined();
27
+ expect(groupObjectPrivilege.UpdatedAt).toBeUndefined();
28
+ expect(groupObjectPrivilege.CreatedById).toBeUndefined();
29
+ expect(groupObjectPrivilege.UpdatedById).toBeUndefined();
30
+ });
31
+
32
+ describe('init', () => {
33
+ it('should return an instance of GroupObjectPrivilege when GroupObjectPrivilegeId is provided', async () => {
34
+ const GroupObjectPrivilegeId = 1;
35
+ const mockGroupObjectPrivilegeAttr = {
36
+ GroupObjectPrivilegeId,
37
+ GroupCode: 'groupCode',
38
+ PrivilegeCode: 'privilegeCode',
39
+ ObjectId: 'objectId',
40
+ ObjectType: 'objectType',
41
+ CreatedAt: new Date(),
42
+ UpdatedAt: new Date(),
43
+ CreatedById: 1,
44
+ UpdatedById: 2,
45
+ };
46
+
47
+ jest.spyOn(GroupObjectPrivilegeRepository.prototype, 'findOne').mockResolvedValueOnce({
48
+ get: () => mockGroupObjectPrivilegeAttr,
49
+ } as any);
50
+
51
+ const result = await GroupObjectPrivilege.init(null, GroupObjectPrivilegeId);
52
+
53
+ expect(result).toBeInstanceOf(GroupObjectPrivilege);
54
+ expect(result.GroupObjectPrivilegeId).toBe(GroupObjectPrivilegeId);
55
+ expect(result.GroupCode).toBe(mockGroupObjectPrivilegeAttr.GroupCode);
56
+ expect(result.PrivilegeCode).toBe(mockGroupObjectPrivilegeAttr.PrivilegeCode);
57
+ expect(result.ObjectId).toBe(mockGroupObjectPrivilegeAttr.ObjectId);
58
+ expect(result.ObjectType).toBe(mockGroupObjectPrivilegeAttr.ObjectType);
59
+ expect(result.CreatedAt).toBe(mockGroupObjectPrivilegeAttr.CreatedAt);
60
+ expect(result.UpdatedAt).toBe(mockGroupObjectPrivilegeAttr.UpdatedAt);
61
+ expect(result.CreatedById).toBe(mockGroupObjectPrivilegeAttr.CreatedById);
62
+ expect(result.UpdatedById).toBe(mockGroupObjectPrivilegeAttr.UpdatedById);
63
+ });
64
+
65
+ it('should throw an error when GroupObjectPrivilegeId is provided but no GroupObjectPrivilege is found', async () => {
66
+ const GroupObjectPrivilegeId = 1;
67
+ jest.spyOn(GroupObjectPrivilegeRepository.prototype, 'findOne').mockResolvedValueOnce(null);
68
+
69
+ await expect(GroupObjectPrivilege.init(null, GroupObjectPrivilegeId)).rejects.toThrowError(
70
+ 'GroupObjectPrivilege not found',
71
+ );
72
+ });
73
+
74
+ it('should return a new instance of GroupObjectPrivilege when GroupObjectPrivilegeId is not provided', async () => {
75
+ const result = await GroupObjectPrivilege.init();
76
+
77
+ expect(result).toBeInstanceOf(GroupObjectPrivilege);
78
+ expect(result.GroupObjectPrivilegeId).toBeUndefined();
79
+ expect(result.GroupCode).toBeUndefined();
80
+ expect(result.PrivilegeCode).toBeUndefined();
81
+ expect(result.ObjectId).toBeUndefined();
82
+ expect(result.ObjectType).toBeUndefined();
83
+ expect(result.CreatedAt).toBeUndefined();
84
+ expect(result.UpdatedAt).toBeUndefined();
85
+ expect(result.CreatedById).toBeUndefined();
86
+ expect(result.UpdatedById).toBeUndefined();
87
+ });
88
+ });
89
89
  });
@@ -1,69 +1,69 @@
1
- import { GroupPrivilege } from '../../../../src/components/group-privilege/group-privilege';
2
- import { GroupPrivilegeRepository } from '../../../../src/components/group-privilege/group-privilege.repository';
3
- import { ClassError } from '@tomei/general';
4
-
5
- describe('GroupPrivilege', () => {
6
- afterEach(() => {
7
- jest.restoreAllMocks();
8
- });
9
-
10
- it('should initialize with GroupPrivilegeAttr', async () => {
11
- const mockGroupPrivilegeAttr = {
12
- GroupPrivilegeId: 1,
13
- GroupCode: 'group1',
14
- PrivilegeCode: 'privilege1',
15
- Status: 'active',
16
- CreatedAt: new Date(),
17
- UpdatedAt: new Date(),
18
- CreatedById: 1,
19
- UpdatedById: 1,
20
- };
21
-
22
- const findOneMock = jest
23
- .spyOn(GroupPrivilegeRepository.prototype, 'findOne')
24
- .mockResolvedValueOnce({ get: jest.fn().mockReturnValue(mockGroupPrivilegeAttr) } as any);
25
-
26
- const groupPrivilege = await GroupPrivilege.init(null, 1);
27
-
28
- expect(findOneMock).toBeCalledWith({
29
- where: { GroupPrivilegeId: 1 },
30
- transaction: null,
31
- });
32
- expect(groupPrivilege).toBeInstanceOf(GroupPrivilege);
33
- expect(groupPrivilege.GroupPrivilegeId).toEqual(mockGroupPrivilegeAttr.GroupPrivilegeId);
34
- expect(groupPrivilege.GroupCode).toEqual(mockGroupPrivilegeAttr.GroupCode);
35
- expect(groupPrivilege.PrivilegeCode).toEqual(mockGroupPrivilegeAttr.PrivilegeCode);
36
- expect(groupPrivilege.Status).toEqual(mockGroupPrivilegeAttr.Status);
37
- expect(groupPrivilege.CreatedAt).toEqual(mockGroupPrivilegeAttr.CreatedAt);
38
- expect(groupPrivilege.UpdatedAt).toEqual(mockGroupPrivilegeAttr.UpdatedAt);
39
- expect(groupPrivilege.CreatedById).toEqual(mockGroupPrivilegeAttr.CreatedById);
40
- expect(groupPrivilege.UpdatedById).toEqual(mockGroupPrivilegeAttr.UpdatedById);
41
- });
42
-
43
- it('should throw ClassError when GroupPrivilegeAttr is not found', async () => {
44
- const findOneMock = jest
45
- .spyOn(GroupPrivilegeRepository.prototype, 'findOne')
46
- .mockResolvedValueOnce(null);
47
-
48
- await expect(GroupPrivilege.init(null, 1)).rejects.toThrow(ClassError);
49
-
50
- expect(findOneMock).toBeCalledWith({
51
- where: { GroupPrivilegeId: 1 },
52
- transaction: null,
53
- });
54
- });
55
-
56
- it('should initialize with default values', async () => {
57
- const groupPrivilege = await GroupPrivilege.init();
58
-
59
- expect(groupPrivilege).toBeInstanceOf(GroupPrivilege);
60
- expect(groupPrivilege.GroupPrivilegeId).toBeUndefined();
61
- expect(groupPrivilege.GroupCode).toBeUndefined();
62
- expect(groupPrivilege.PrivilegeCode).toBeUndefined();
63
- expect(groupPrivilege.Status).toBeUndefined();
64
- expect(groupPrivilege.CreatedAt).toBeUndefined();
65
- expect(groupPrivilege.UpdatedAt).toBeUndefined();
66
- expect(groupPrivilege.CreatedById).toBeUndefined();
67
- expect(groupPrivilege.UpdatedById).toBeUndefined();
68
- });
1
+ import { GroupPrivilege } from '../../../../src/components/group-privilege/group-privilege';
2
+ import { GroupPrivilegeRepository } from '../../../../src/components/group-privilege/group-privilege.repository';
3
+ import { ClassError } from '@tomei/general';
4
+
5
+ describe('GroupPrivilege', () => {
6
+ afterEach(() => {
7
+ jest.restoreAllMocks();
8
+ });
9
+
10
+ it('should initialize with GroupPrivilegeAttr', async () => {
11
+ const mockGroupPrivilegeAttr = {
12
+ GroupPrivilegeId: 1,
13
+ GroupCode: 'group1',
14
+ PrivilegeCode: 'privilege1',
15
+ Status: 'active',
16
+ CreatedAt: new Date(),
17
+ UpdatedAt: new Date(),
18
+ CreatedById: 1,
19
+ UpdatedById: 1,
20
+ };
21
+
22
+ const findOneMock = jest
23
+ .spyOn(GroupPrivilegeRepository.prototype, 'findOne')
24
+ .mockResolvedValueOnce({ get: jest.fn().mockReturnValue(mockGroupPrivilegeAttr) } as any);
25
+
26
+ const groupPrivilege = await GroupPrivilege.init(null, 1);
27
+
28
+ expect(findOneMock).toBeCalledWith({
29
+ where: { GroupPrivilegeId: 1 },
30
+ transaction: null,
31
+ });
32
+ expect(groupPrivilege).toBeInstanceOf(GroupPrivilege);
33
+ expect(groupPrivilege.GroupPrivilegeId).toEqual(mockGroupPrivilegeAttr.GroupPrivilegeId);
34
+ expect(groupPrivilege.GroupCode).toEqual(mockGroupPrivilegeAttr.GroupCode);
35
+ expect(groupPrivilege.PrivilegeCode).toEqual(mockGroupPrivilegeAttr.PrivilegeCode);
36
+ expect(groupPrivilege.Status).toEqual(mockGroupPrivilegeAttr.Status);
37
+ expect(groupPrivilege.CreatedAt).toEqual(mockGroupPrivilegeAttr.CreatedAt);
38
+ expect(groupPrivilege.UpdatedAt).toEqual(mockGroupPrivilegeAttr.UpdatedAt);
39
+ expect(groupPrivilege.CreatedById).toEqual(mockGroupPrivilegeAttr.CreatedById);
40
+ expect(groupPrivilege.UpdatedById).toEqual(mockGroupPrivilegeAttr.UpdatedById);
41
+ });
42
+
43
+ it('should throw ClassError when GroupPrivilegeAttr is not found', async () => {
44
+ const findOneMock = jest
45
+ .spyOn(GroupPrivilegeRepository.prototype, 'findOne')
46
+ .mockResolvedValueOnce(null);
47
+
48
+ await expect(GroupPrivilege.init(null, 1)).rejects.toThrow(ClassError);
49
+
50
+ expect(findOneMock).toBeCalledWith({
51
+ where: { GroupPrivilegeId: 1 },
52
+ transaction: null,
53
+ });
54
+ });
55
+
56
+ it('should initialize with default values', async () => {
57
+ const groupPrivilege = await GroupPrivilege.init();
58
+
59
+ expect(groupPrivilege).toBeInstanceOf(GroupPrivilege);
60
+ expect(groupPrivilege.GroupPrivilegeId).toBeUndefined();
61
+ expect(groupPrivilege.GroupCode).toBeUndefined();
62
+ expect(groupPrivilege.PrivilegeCode).toBeUndefined();
63
+ expect(groupPrivilege.Status).toBeUndefined();
64
+ expect(groupPrivilege.CreatedAt).toBeUndefined();
65
+ expect(groupPrivilege.UpdatedAt).toBeUndefined();
66
+ expect(groupPrivilege.CreatedById).toBeUndefined();
67
+ expect(groupPrivilege.UpdatedById).toBeUndefined();
68
+ });
69
69
  });
@@ -1,67 +1,67 @@
1
- import { GroupReportingUser } from '../../../../src/components/group-reporting-user/group-reporting-user';
2
- import { GroupReportingUserRepository } from '../../../../src/components/group-reporting-user/group-reporting-user.repository';
3
- import { ClassError } from '@tomei/general';
4
-
5
- describe('GroupReportingUser', () => {
6
- const mockGroupReportingUserAttr = {
7
- GroupReportingUserId: 1,
8
- GroupCode: 'test',
9
- UserId: 1,
10
- Rank: 1,
11
- Status: 'active',
12
- CreatedById: 1,
13
- CreatedAt: new Date(),
14
- UpdatedById: 1,
15
- UpdatedAt: new Date(),
16
- };
17
-
18
- beforeEach(async () => {
19
- jest.clearAllMocks();
20
- });
21
-
22
-
23
- describe('init', () => {
24
- const mockDbTransaction = {};
25
-
26
- it('should initialize GroupReportingUser without GroupReportingUserId', async () => {
27
- const initGroupReportingUser = await GroupReportingUser.init(mockDbTransaction);
28
- expect(initGroupReportingUser).toBeDefined();
29
- expect(initGroupReportingUser).toBeInstanceOf(GroupReportingUser);
30
- });
31
-
32
- it('should initialize GroupReportingUser with valid GroupReportingUserId', async () => {
33
- const mockFindByPk = jest
34
- .spyOn(GroupReportingUserRepository.prototype, 'findByPk')
35
- .mockResolvedValue({
36
- ...mockGroupReportingUserAttr,
37
- get: () => mockGroupReportingUserAttr,
38
- } as any);
39
-
40
- const initGroupReportingUser = await GroupReportingUser.init(
41
- mockDbTransaction,
42
- '1'
43
- );
44
- expect(initGroupReportingUser).toBeDefined();
45
- expect(initGroupReportingUser).toBeInstanceOf(GroupReportingUser);
46
- expect(mockFindByPk).toHaveBeenCalledWith('1', {
47
- transaction: mockDbTransaction,
48
- });
49
- });
50
-
51
- it('should throw ClassError when GroupReportingUser is not found', async () => {
52
- jest.spyOn(GroupReportingUserRepository.prototype, 'findByPk').mockResolvedValue(null);
53
-
54
- await expect(
55
- GroupReportingUser.init(mockDbTransaction, '1')
56
- ).rejects.toThrowError(ClassError);
57
- });
58
-
59
- it('should throw ClassError when failed to initialize GroupReportingUser', async () => {
60
- jest.spyOn(GroupReportingUserRepository.prototype, 'findByPk').mockRejectedValue(new Error());
61
-
62
- await expect(
63
- GroupReportingUser.init(mockDbTransaction, '1')
64
- ).rejects.toThrowError(ClassError);
65
- });
66
- });
1
+ import { GroupReportingUser } from '../../../../src/components/group-reporting-user/group-reporting-user';
2
+ import { GroupReportingUserRepository } from '../../../../src/components/group-reporting-user/group-reporting-user.repository';
3
+ import { ClassError } from '@tomei/general';
4
+
5
+ describe('GroupReportingUser', () => {
6
+ const mockGroupReportingUserAttr = {
7
+ GroupReportingUserId: 1,
8
+ GroupCode: 'test',
9
+ UserId: 1,
10
+ Rank: 1,
11
+ Status: 'active',
12
+ CreatedById: 1,
13
+ CreatedAt: new Date(),
14
+ UpdatedById: 1,
15
+ UpdatedAt: new Date(),
16
+ };
17
+
18
+ beforeEach(async () => {
19
+ jest.clearAllMocks();
20
+ });
21
+
22
+
23
+ describe('init', () => {
24
+ const mockDbTransaction = {};
25
+
26
+ it('should initialize GroupReportingUser without GroupReportingUserId', async () => {
27
+ const initGroupReportingUser = await GroupReportingUser.init(mockDbTransaction);
28
+ expect(initGroupReportingUser).toBeDefined();
29
+ expect(initGroupReportingUser).toBeInstanceOf(GroupReportingUser);
30
+ });
31
+
32
+ it('should initialize GroupReportingUser with valid GroupReportingUserId', async () => {
33
+ const mockFindByPk = jest
34
+ .spyOn(GroupReportingUserRepository.prototype, 'findByPk')
35
+ .mockResolvedValue({
36
+ ...mockGroupReportingUserAttr,
37
+ get: () => mockGroupReportingUserAttr,
38
+ } as any);
39
+
40
+ const initGroupReportingUser = await GroupReportingUser.init(
41
+ mockDbTransaction,
42
+ '1'
43
+ );
44
+ expect(initGroupReportingUser).toBeDefined();
45
+ expect(initGroupReportingUser).toBeInstanceOf(GroupReportingUser);
46
+ expect(mockFindByPk).toHaveBeenCalledWith('1', {
47
+ transaction: mockDbTransaction,
48
+ });
49
+ });
50
+
51
+ it('should throw ClassError when GroupReportingUser is not found', async () => {
52
+ jest.spyOn(GroupReportingUserRepository.prototype, 'findByPk').mockResolvedValue(null);
53
+
54
+ await expect(
55
+ GroupReportingUser.init(mockDbTransaction, '1')
56
+ ).rejects.toThrowError(ClassError);
57
+ });
58
+
59
+ it('should throw ClassError when failed to initialize GroupReportingUser', async () => {
60
+ jest.spyOn(GroupReportingUserRepository.prototype, 'findByPk').mockRejectedValue(new Error());
61
+
62
+ await expect(
63
+ GroupReportingUser.init(mockDbTransaction, '1')
64
+ ).rejects.toThrowError(ClassError);
65
+ });
66
+ });
67
67
  });
@@ -1,84 +1,84 @@
1
- import { GroupSystemAccess } from '../../../../src/components/group-system-access/group-system-access';
2
- import { GroupSystemAccessRepository } from '../../../../src/components/group-system-access/group-system-access.repository';
3
- import { ClassError } from '@tomei/general';
4
-
5
- describe('GroupSystemAccess', () => {
6
- let groupSystemAccess: GroupSystemAccess;
7
- const groupSystemAccessAttr = {
8
- GroupSystemAccessId: 1,
9
- GroupCode: 'test',
10
- SystemCode: 'test',
11
- Status: 'test',
12
- CreatedById: 1,
13
- CreatedAt: new Date(),
14
- UpdatedById: 1,
15
- UpdatedAt: new Date(),
16
- };
17
-
18
- beforeEach(() => {
19
- jest.resetAllMocks();
20
- groupSystemAccess = new GroupSystemAccess(groupSystemAccessAttr);
21
- });
22
-
23
- it('should create a new GroupSystemAccess instance', () => {
24
- expect(groupSystemAccess).toBeDefined();
25
- expect(groupSystemAccess).toBeInstanceOf(GroupSystemAccess);
26
- expect(groupSystemAccess.GroupSystemAccessId).toBe(groupSystemAccessAttr.GroupSystemAccessId);
27
- expect(groupSystemAccess.GroupCode).toBe(groupSystemAccessAttr.GroupCode);
28
- expect(groupSystemAccess.SystemCode).toBe(groupSystemAccessAttr.SystemCode);
29
- expect(groupSystemAccess.Status).toBe(groupSystemAccessAttr.Status);
30
- expect(groupSystemAccess.CreatedById).toBe(groupSystemAccessAttr.CreatedById);
31
- expect(groupSystemAccess.CreatedAt).toBe(groupSystemAccessAttr.CreatedAt);
32
- expect(groupSystemAccess.UpdatedById).toBe(groupSystemAccessAttr.UpdatedById);
33
- expect(groupSystemAccess.UpdatedAt).toBe(groupSystemAccessAttr.UpdatedAt);
34
- });
35
-
36
- describe('init', () => {
37
- it('should initialize GroupSystemAccess without GroupSystemAccessId', async () => {
38
- const groupSystemAccess = await GroupSystemAccess.init(null);
39
- expect(groupSystemAccess).toBeDefined();
40
- expect(groupSystemAccess).toBeInstanceOf(GroupSystemAccess);
41
- expect(groupSystemAccess.GroupSystemAccessId).toBeUndefined();
42
- expect(groupSystemAccess.GroupCode).toBeUndefined();
43
- expect(groupSystemAccess.SystemCode).toBeUndefined();
44
- expect(groupSystemAccess.Status).toBeUndefined();
45
- expect(groupSystemAccess.CreatedById).toBeUndefined();
46
- expect(groupSystemAccess.CreatedAt).toBeUndefined();
47
- expect(groupSystemAccess.UpdatedById).toBeUndefined();
48
- expect(groupSystemAccess.UpdatedAt).toBeUndefined();
49
- });
50
-
51
- it('should initialize GroupSystemAccess with GroupSystemAccessId', async () => {
52
- const findOneSpy = jest
53
- .spyOn(GroupSystemAccessRepository.prototype, 'findOne')
54
- .mockResolvedValue({
55
- ...groupSystemAccessAttr,
56
- get: () => groupSystemAccessAttr,
57
- } as any);
58
-
59
- const groupSystemAccess = await GroupSystemAccess.init(null, 1);
60
- expect(findOneSpy).toHaveBeenCalledWith({
61
- where: { GroupSystemAccessId: 1 },
62
- transaction: null,
63
- });
64
- expect(groupSystemAccess).toBeDefined();
65
- expect(groupSystemAccess).toBeInstanceOf(GroupSystemAccess);
66
- expect(groupSystemAccess.GroupSystemAccessId).toBe(groupSystemAccessAttr.GroupSystemAccessId);
67
- expect(groupSystemAccess.GroupCode).toBe(groupSystemAccessAttr.GroupCode);
68
- expect(groupSystemAccess.SystemCode).toBe(groupSystemAccessAttr.SystemCode);
69
- expect(groupSystemAccess.Status).toBe(groupSystemAccessAttr.Status);
70
- expect(groupSystemAccess.CreatedById).toBe(groupSystemAccessAttr.CreatedById);
71
- expect(groupSystemAccess.CreatedAt).toBe(groupSystemAccessAttr.CreatedAt);
72
- expect(groupSystemAccess.UpdatedById).toBe(groupSystemAccessAttr.UpdatedById);
73
- expect(groupSystemAccess.UpdatedAt).toBe(groupSystemAccessAttr.UpdatedAt);
74
- });
75
-
76
- it('should throw an error if GroupSystemAccessId is not found', async () => {
77
- jest.spyOn(GroupSystemAccessRepository.prototype, 'findOne').mockResolvedValue(null);
78
-
79
- await expect(GroupSystemAccess.init(null, 1)).rejects.toThrow(
80
- new ClassError('groupSystemAccess', 'groupSystemAccessErrMsg00', 'groupSystemAccess not found'),
81
- );
82
- });
83
- });
1
+ import { GroupSystemAccess } from '../../../../src/components/group-system-access/group-system-access';
2
+ import { GroupSystemAccessRepository } from '../../../../src/components/group-system-access/group-system-access.repository';
3
+ import { ClassError } from '@tomei/general';
4
+
5
+ describe('GroupSystemAccess', () => {
6
+ let groupSystemAccess: GroupSystemAccess;
7
+ const groupSystemAccessAttr = {
8
+ GroupSystemAccessId: 1,
9
+ GroupCode: 'test',
10
+ SystemCode: 'test',
11
+ Status: 'test',
12
+ CreatedById: 1,
13
+ CreatedAt: new Date(),
14
+ UpdatedById: 1,
15
+ UpdatedAt: new Date(),
16
+ };
17
+
18
+ beforeEach(() => {
19
+ jest.resetAllMocks();
20
+ groupSystemAccess = new GroupSystemAccess(groupSystemAccessAttr);
21
+ });
22
+
23
+ it('should create a new GroupSystemAccess instance', () => {
24
+ expect(groupSystemAccess).toBeDefined();
25
+ expect(groupSystemAccess).toBeInstanceOf(GroupSystemAccess);
26
+ expect(groupSystemAccess.GroupSystemAccessId).toBe(groupSystemAccessAttr.GroupSystemAccessId);
27
+ expect(groupSystemAccess.GroupCode).toBe(groupSystemAccessAttr.GroupCode);
28
+ expect(groupSystemAccess.SystemCode).toBe(groupSystemAccessAttr.SystemCode);
29
+ expect(groupSystemAccess.Status).toBe(groupSystemAccessAttr.Status);
30
+ expect(groupSystemAccess.CreatedById).toBe(groupSystemAccessAttr.CreatedById);
31
+ expect(groupSystemAccess.CreatedAt).toBe(groupSystemAccessAttr.CreatedAt);
32
+ expect(groupSystemAccess.UpdatedById).toBe(groupSystemAccessAttr.UpdatedById);
33
+ expect(groupSystemAccess.UpdatedAt).toBe(groupSystemAccessAttr.UpdatedAt);
34
+ });
35
+
36
+ describe('init', () => {
37
+ it('should initialize GroupSystemAccess without GroupSystemAccessId', async () => {
38
+ const groupSystemAccess = await GroupSystemAccess.init(null);
39
+ expect(groupSystemAccess).toBeDefined();
40
+ expect(groupSystemAccess).toBeInstanceOf(GroupSystemAccess);
41
+ expect(groupSystemAccess.GroupSystemAccessId).toBeUndefined();
42
+ expect(groupSystemAccess.GroupCode).toBeUndefined();
43
+ expect(groupSystemAccess.SystemCode).toBeUndefined();
44
+ expect(groupSystemAccess.Status).toBeUndefined();
45
+ expect(groupSystemAccess.CreatedById).toBeUndefined();
46
+ expect(groupSystemAccess.CreatedAt).toBeUndefined();
47
+ expect(groupSystemAccess.UpdatedById).toBeUndefined();
48
+ expect(groupSystemAccess.UpdatedAt).toBeUndefined();
49
+ });
50
+
51
+ it('should initialize GroupSystemAccess with GroupSystemAccessId', async () => {
52
+ const findOneSpy = jest
53
+ .spyOn(GroupSystemAccessRepository.prototype, 'findOne')
54
+ .mockResolvedValue({
55
+ ...groupSystemAccessAttr,
56
+ get: () => groupSystemAccessAttr,
57
+ } as any);
58
+
59
+ const groupSystemAccess = await GroupSystemAccess.init(null, 1);
60
+ expect(findOneSpy).toHaveBeenCalledWith({
61
+ where: { GroupSystemAccessId: 1 },
62
+ transaction: null,
63
+ });
64
+ expect(groupSystemAccess).toBeDefined();
65
+ expect(groupSystemAccess).toBeInstanceOf(GroupSystemAccess);
66
+ expect(groupSystemAccess.GroupSystemAccessId).toBe(groupSystemAccessAttr.GroupSystemAccessId);
67
+ expect(groupSystemAccess.GroupCode).toBe(groupSystemAccessAttr.GroupCode);
68
+ expect(groupSystemAccess.SystemCode).toBe(groupSystemAccessAttr.SystemCode);
69
+ expect(groupSystemAccess.Status).toBe(groupSystemAccessAttr.Status);
70
+ expect(groupSystemAccess.CreatedById).toBe(groupSystemAccessAttr.CreatedById);
71
+ expect(groupSystemAccess.CreatedAt).toBe(groupSystemAccessAttr.CreatedAt);
72
+ expect(groupSystemAccess.UpdatedById).toBe(groupSystemAccessAttr.UpdatedById);
73
+ expect(groupSystemAccess.UpdatedAt).toBe(groupSystemAccessAttr.UpdatedAt);
74
+ });
75
+
76
+ it('should throw an error if GroupSystemAccessId is not found', async () => {
77
+ jest.spyOn(GroupSystemAccessRepository.prototype, 'findOne').mockResolvedValue(null);
78
+
79
+ await expect(GroupSystemAccess.init(null, 1)).rejects.toThrow(
80
+ new ClassError('groupSystemAccess', 'groupSystemAccessErrMsg00', 'groupSystemAccess not found'),
81
+ );
82
+ });
83
+ });
84
84
  });