tenant-routes.integration.test.ts 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. import { describe, it, expect, beforeEach, vi, afterEach } from 'vitest';
  2. import { testClient } from 'hono/testing';
  3. import { IntegrationTestDatabase, setupIntegrationDatabaseHooksWithEntities } from '@d8d/shared-test-util';
  4. import { JWTUtil } from '@d8d/shared-utils';
  5. import { tenantRoutes } from '../../src/routes';
  6. import { TenantEntityMt } from '../../src/entities';
  7. // 设置集成测试钩子
  8. setupIntegrationDatabaseHooksWithEntities([TenantEntityMt])
  9. describe('租户管理API集成测试', () => {
  10. let client: ReturnType<typeof testClient<typeof tenantRoutes>>;
  11. let superAdminToken: string;
  12. let regularUserToken: string;
  13. beforeEach(async () => {
  14. // 创建测试客户端
  15. client = testClient(tenantRoutes);
  16. // 生成模拟的token
  17. // 超级管理员用户ID为1(租户中间件要求)
  18. superAdminToken = JWTUtil.generateToken({
  19. id: 1,
  20. username: 'superadmin',
  21. tenantId: 1
  22. });
  23. // 普通用户(ID不为1,会被中间件拒绝)
  24. regularUserToken = JWTUtil.generateToken({
  25. id: 2,
  26. username: 'testuser',
  27. tenantId: 1
  28. });
  29. });
  30. afterEach(async () => {
  31. vi.clearAllMocks();
  32. });
  33. describe('创建租户', () => {
  34. it('超级管理员应该能够创建租户', async () => {
  35. const response = await client.index.$post({
  36. json: {
  37. name: '测试租户',
  38. code: 'test-tenant',
  39. contactName: '联系人',
  40. phone: '13800138000',
  41. status: 1
  42. }
  43. }, {
  44. headers: {
  45. Authorization: `Bearer ${superAdminToken}`
  46. }
  47. });
  48. expect(response.status).toBe(201);
  49. if (response.status === 201) {
  50. const data = await response.json();
  51. expect(data.name).toBe('测试租户');
  52. expect(data.code).toBe('test-tenant');
  53. expect(data.status).toBe(1);
  54. }
  55. });
  56. it('普通用户不应该能够创建租户', async () => {
  57. const response = await client.index.$post({
  58. json: {
  59. name: '测试租户',
  60. code: 'test-tenant',
  61. contactName: '联系人',
  62. phone: '13800138000',
  63. status: 1
  64. }
  65. }, {
  66. headers: {
  67. Authorization: `Bearer ${regularUserToken}`
  68. }
  69. });
  70. expect(response.status).toBe(403);
  71. if (response.status === 403) {
  72. const data = await response.json();
  73. expect(data.message).toContain('Access denied');
  74. }
  75. });
  76. it('未认证用户不应该能够创建租户', async () => {
  77. const response = await client.index.$post({
  78. json: {
  79. name: '测试租户',
  80. code: 'test-tenant',
  81. contactName: '联系人',
  82. phone: '13800138000',
  83. status: 1
  84. }
  85. });
  86. expect(response.status).toBe(401);
  87. });
  88. });
  89. describe('获取租户列表', () => {
  90. beforeEach(async () => {
  91. // 创建测试租户数据
  92. const dataSource = await IntegrationTestDatabase.getDataSource();
  93. const tenantRepository = dataSource.getRepository(TenantEntityMt);
  94. await tenantRepository.save([
  95. {
  96. name: '租户A',
  97. code: 'tenant-a',
  98. contactName: '联系人A',
  99. phone: '13800138001',
  100. status: 1,
  101. createdBy: 1
  102. },
  103. {
  104. name: '租户B',
  105. code: 'tenant-b',
  106. contactName: '联系人B',
  107. phone: '13800138002',
  108. status: 2,
  109. createdBy: 1
  110. }
  111. ]);
  112. });
  113. it('超级管理员应该能够获取租户列表', async () => {
  114. const response = await client.index.$get({
  115. query: {}
  116. }, {
  117. headers: {
  118. Authorization: `Bearer ${superAdminToken}`
  119. }
  120. });
  121. console.debug('列表查询响应状态:', response.status);
  122. if (response.status !== 200) {
  123. const errorData = await response.json();
  124. console.debug('错误响应:', errorData);
  125. }
  126. expect(response.status).toBe(200);
  127. if (response.status === 200) {
  128. const data = await response.json();
  129. expect(data.data).toHaveLength(2);
  130. expect(data.pagination.total).toBe(2);
  131. }
  132. });
  133. it('普通用户不应该能够获取租户列表', async () => {
  134. const response = await client.index.$get({
  135. query: {}
  136. }, {
  137. headers: {
  138. Authorization: `Bearer ${regularUserToken}`
  139. }
  140. });
  141. expect(response.status).toBe(403);
  142. });
  143. });
  144. describe('获取单个租户', () => {
  145. let testTenant: TenantEntityMt;
  146. beforeEach(async () => {
  147. const dataSource = await IntegrationTestDatabase.getDataSource();
  148. const tenantRepository = dataSource.getRepository(TenantEntityMt);
  149. testTenant = await tenantRepository.save({
  150. name: '测试租户',
  151. code: 'test-tenant',
  152. contactName: '联系人',
  153. phone: '13800138000',
  154. status: 1,
  155. createdBy: 1
  156. });
  157. });
  158. it('超级管理员应该能够获取租户详情', async () => {
  159. const response = await client[':id'].$get({
  160. param: { id: testTenant.id }
  161. }, {
  162. headers: {
  163. Authorization: `Bearer ${superAdminToken}`
  164. }
  165. });
  166. expect(response.status).toBe(200);
  167. if (response.status === 200) {
  168. const data = await response.json();
  169. expect(data.name).toBe('测试租户');
  170. expect(data.code).toBe('test-tenant');
  171. }
  172. });
  173. it('普通用户不应该能够获取租户详情', async () => {
  174. const response = await client[':id'].$get({
  175. param: { id: testTenant.id }
  176. }, {
  177. headers: {
  178. Authorization: `Bearer ${regularUserToken}`
  179. }
  180. });
  181. expect(response.status).toBe(403);
  182. });
  183. });
  184. describe('更新租户', () => {
  185. let testTenant: TenantEntityMt;
  186. beforeEach(async () => {
  187. const dataSource = await IntegrationTestDatabase.getDataSource();
  188. const tenantRepository = dataSource.getRepository(TenantEntityMt);
  189. testTenant = await tenantRepository.save({
  190. name: '测试租户',
  191. code: 'test-tenant',
  192. contactName: '联系人',
  193. phone: '13800138000',
  194. status: 1,
  195. createdBy: 1
  196. });
  197. });
  198. it('超级管理员应该能够更新租户', async () => {
  199. const response = await client[':id'].$put({
  200. param: { id: testTenant.id },
  201. json: {
  202. name: '更新后的租户',
  203. contactName: '新联系人',
  204. phone: '13900139000',
  205. status: 2
  206. }
  207. }, {
  208. headers: {
  209. Authorization: `Bearer ${superAdminToken}`
  210. }
  211. });
  212. expect(response.status).toBe(200);
  213. if (response.status === 200) {
  214. const data = await response.json();
  215. expect(data.name).toBe('更新后的租户');
  216. expect(data.contactName).toBe('新联系人');
  217. expect(data.status).toBe(2);
  218. }
  219. });
  220. it('普通用户不应该能够更新租户', async () => {
  221. const response = await client[':id'].$put({
  222. param: { id: testTenant.id },
  223. json: {
  224. name: '更新后的租户'
  225. }
  226. }, {
  227. headers: {
  228. Authorization: `Bearer ${regularUserToken}`
  229. }
  230. });
  231. expect(response.status).toBe(403);
  232. });
  233. });
  234. describe('删除租户', () => {
  235. let testTenant: TenantEntityMt;
  236. beforeEach(async () => {
  237. const dataSource = await IntegrationTestDatabase.getDataSource();
  238. const tenantRepository = dataSource.getRepository(TenantEntityMt);
  239. testTenant = await tenantRepository.save({
  240. name: '测试租户',
  241. code: 'test-tenant',
  242. contactName: '联系人',
  243. phone: '13800138000',
  244. status: 1,
  245. createdBy: 1
  246. });
  247. });
  248. it('超级管理员应该能够删除租户', async () => {
  249. const response = await client[':id'].$delete({
  250. param: { id: testTenant.id }
  251. }, {
  252. headers: {
  253. Authorization: `Bearer ${superAdminToken}`
  254. }
  255. });
  256. expect(response.status).toBe(204);
  257. });
  258. it('普通用户不应该能够删除租户', async () => {
  259. const response = await client[':id'].$delete({
  260. param: { id: testTenant.id }
  261. }, {
  262. headers: {
  263. Authorization: `Bearer ${regularUserToken}`
  264. }
  265. });
  266. expect(response.status).toBe(403);
  267. });
  268. });
  269. });