disability-person-note.spec.ts 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. import { test, expect } from '../../utils/test-setup';
  2. import { readFileSync } from 'fs';
  3. import { join, dirname } from 'path';
  4. import { fileURLToPath } from 'url';
  5. const __filename = fileURLToPath(import.meta.url);
  6. const __dirname = dirname(__filename);
  7. const testUsers = JSON.parse(readFileSync(join(__dirname, '../../fixtures/test-users.json'), 'utf-8'));
  8. // 超时配置
  9. const TIMEOUTS = {
  10. SHORT: 300,
  11. MEDIUM: 500,
  12. LONG: 1000,
  13. VERY_SHORT: 200,
  14. } as const;
  15. /**
  16. * 生成唯一的测试数据
  17. */
  18. function generateUniqueTestData(suffix: string) {
  19. const randomPart = Math.floor(Math.random() * Number.MAX_SAFE_INTEGER);
  20. const timestamp = Date.now();
  21. return {
  22. name: `备注${suffix}_${timestamp}_${randomPart}`,
  23. gender: randomPart % 2 === 0 ? '男' : '女',
  24. idCard: `42010119900101${String(randomPart % 10000).padStart(4, '0')}`,
  25. disabilityId: `511001199001${String(randomPart % 10000).padStart(4, '0')}`,
  26. disabilityType: ['视力残疾', '听力残疾', '言语残疾', '肢体残疾', '智力残疾', '精神残疾'][randomPart % 6],
  27. disabilityLevel: ['一级', '二级', '三级', '四级'][randomPart % 4],
  28. phone: `138${String(randomPart % 100000000).padStart(8, '0')}`,
  29. idAddress: `湖北省武汉市测试街道${randomPart % 100}号`,
  30. province: '湖北省',
  31. city: '武汉市'
  32. };
  33. }
  34. test.describe('残疾人管理 - 备注管理功能', () => {
  35. // 测试级别的时间戳,用于生成唯一数据
  36. const TEST_TIMESTAMP = Date.now();
  37. const TEST_PREFIX = `note_${TEST_TIMESTAMP}`;
  38. // 测试级别的数据存储,避免可变全局状态
  39. let createdTestData: Array<{ name: string; idCard: string }> = [];
  40. test.beforeEach(async ({ adminLoginPage, disabilityPersonPage }) => {
  41. // 每次测试前重置数据存储
  42. createdTestData = [];
  43. // 以管理员身份登录后台
  44. await adminLoginPage.goto();
  45. await adminLoginPage.login(testUsers.admin.username, testUsers.admin.password);
  46. await adminLoginPage.expectLoginSuccess();
  47. await disabilityPersonPage.goto();
  48. });
  49. test.afterEach(async ({ disabilityPersonPage, page }) => {
  50. // 清理测试数据(添加超时保护以避免 afterEach 超过 60 秒)
  51. for (const data of createdTestData) {
  52. try {
  53. await disabilityPersonPage.goto().catch(() => {});
  54. await disabilityPersonPage.searchByName(data.name);
  55. // 为每个清理操作设置较短的超时时间
  56. const deleteButton = page.getByRole('button', { name: '删除' }).first();
  57. if (await deleteButton.count({ timeout: TIMEOUTS.VERY_LONG }) > 0) {
  58. await deleteButton.click({ timeout: TIMEOUTS.DIALOG });
  59. await page.getByRole('button', { name: '确认' }).click({ timeout: TIMEOUTS.DIALOG }).catch(() => {});
  60. await page.waitForTimeout(TIMEOUTS.SHORT);
  61. }
  62. } catch (error) {
  63. console.debug(` ⚠ 清理数据失败: ${data.name}`, error);
  64. }
  65. }
  66. createdTestData.length = 0;
  67. });
  68. test('应该成功添加简单备注', async ({ disabilityPersonPage }) => {
  69. const testData = generateUniqueTestData('简单备注');
  70. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  71. console.debug('\n========== 添加简单备注测试 ==========');
  72. // 打开对话框并填写基本信息
  73. await disabilityPersonPage.openCreateDialog();
  74. await disabilityPersonPage.fillBasicForm(testData);
  75. // 滚动到备注管理区域
  76. await disabilityPersonPage.scrollToSection('备注管理');
  77. // 添加备注
  78. const noteContent = `这是一条测试备注_${testData.name}`;
  79. await disabilityPersonPage.addNote(noteContent);
  80. // 验证备注出现在列表中
  81. const noteList = await disabilityPersonPage.getNoteList();
  82. expect(noteList).toHaveLength(1);
  83. expect(noteList[0]).toContain(noteContent);
  84. console.debug(' ✓ 备注已添加');
  85. console.debug('✅ 添加简单备注测试通过');
  86. });
  87. test('应该成功添加长文本备注', async ({ disabilityPersonPage }) => {
  88. const testData = generateUniqueTestData('长文本备注');
  89. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  90. console.debug('\n========== 添加长文本备注测试 ==========');
  91. // 打开对话框并填写基本信息
  92. await disabilityPersonPage.openCreateDialog();
  93. await disabilityPersonPage.fillBasicForm(testData);
  94. // 滚动到备注管理区域
  95. await disabilityPersonPage.scrollToSection('备注管理');
  96. // 添加长文本备注
  97. const longNote = `这是一条很长的备注内容_${testData.name}`.repeat(10);
  98. await disabilityPersonPage.addNote(longNote);
  99. // 验证备注出现在列表中 - 验证完整内容和长度
  100. const noteList = await disabilityPersonPage.getNoteList();
  101. expect(noteList).toHaveLength(1);
  102. expect(noteList[0].length).toBe(longNote.length);
  103. expect(noteList[0]).toBe(longNote);
  104. console.debug(' ✓ 长文本备注已添加');
  105. console.debug('✅ 添加长文本备注测试通过');
  106. });
  107. test('应该成功编辑备注', async ({ disabilityPersonPage }) => {
  108. const testData = generateUniqueTestData('编辑备注');
  109. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  110. console.debug('\n========== 编辑备注测试 ==========');
  111. // 打开对话框并填写基本信息
  112. await disabilityPersonPage.openCreateDialog();
  113. await disabilityPersonPage.fillBasicForm(testData);
  114. // 滚动到备注管理区域
  115. await disabilityPersonPage.scrollToSection('备注管理');
  116. // 添加原始备注
  117. const originalNote = `原始备注_${testData.name}`;
  118. await disabilityPersonPage.addNote(originalNote);
  119. // 编辑备注
  120. const updatedNote = `更新后的备注_${testData.name}`;
  121. await disabilityPersonPage.editNote(0, updatedNote);
  122. // 验证更新后的内容 - 确保旧文本完全被替换
  123. const noteList = await disabilityPersonPage.getNoteList();
  124. expect(noteList[0]).toBe(updatedNote);
  125. expect(noteList[0]).not.toContain(originalNote);
  126. console.debug(' ✓ 备注已编辑');
  127. console.debug('✅ 编辑备注测试通过');
  128. });
  129. test('应该成功删除备注', async ({ disabilityPersonPage }) => {
  130. const testData = generateUniqueTestData('删除备注');
  131. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  132. console.debug('\n========== 删除备注测试 ==========');
  133. // 打开对话框并填写基本信息
  134. await disabilityPersonPage.openCreateDialog();
  135. await disabilityPersonPage.fillBasicForm(testData);
  136. // 滚动到备注管理区域
  137. await disabilityPersonPage.scrollToSection('备注管理');
  138. // 添加备注
  139. const noteContent = `待删除备注_${testData.name}`;
  140. await disabilityPersonPage.addNote(noteContent);
  141. // 验证备注存在
  142. let noteList = await disabilityPersonPage.getNoteList();
  143. expect(noteList).toHaveLength(1);
  144. console.debug(' ✓ 备注已添加');
  145. // 删除备注
  146. await disabilityPersonPage.deleteNote(0);
  147. // 验证备注已被删除
  148. noteList = await disabilityPersonPage.getNoteList();
  149. expect(noteList).toHaveLength(0);
  150. console.debug(' ✓ 备注已删除');
  151. console.debug('✅ 删除备注测试通过');
  152. });
  153. test('应该支持添加多条备注', async ({ disabilityPersonPage }) => {
  154. const testData = generateUniqueTestData('多条备注');
  155. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  156. console.debug('\n========== 添加多条备注测试 ==========');
  157. // 打开对话框并填写基本信息
  158. await disabilityPersonPage.openCreateDialog();
  159. await disabilityPersonPage.fillBasicForm(testData);
  160. // 滚动到备注管理区域
  161. await disabilityPersonPage.scrollToSection('备注管理');
  162. // 添加多条备注
  163. await disabilityPersonPage.addNote(`备注1_${testData.name}`);
  164. await disabilityPersonPage.addNote(`备注2_${testData.name}`);
  165. await disabilityPersonPage.addNote(`备注3_${testData.name}`);
  166. // 验证所有备注都显示
  167. const noteList = await disabilityPersonPage.getNoteList();
  168. expect(noteList).toHaveLength(3);
  169. console.debug(' ✓ 已添加 3 条备注');
  170. console.debug('✅ 添加多条备注测试通过');
  171. });
  172. test('应该支持标记特殊需求', async ({ disabilityPersonPage }) => {
  173. const testData = generateUniqueTestData('特殊需求');
  174. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  175. console.debug('\n========== 特殊需求标记测试 ==========');
  176. // 打开对话框并填写基本信息
  177. await disabilityPersonPage.openCreateDialog();
  178. await disabilityPersonPage.fillBasicForm(testData);
  179. // 滚动到备注管理区域
  180. await disabilityPersonPage.scrollToSection('备注管理');
  181. // 添加带特殊需求标记的备注
  182. const noteContent = `特殊需求备注_${testData.name}`;
  183. await disabilityPersonPage.addNote(noteContent, { isSpecialNeeds: true });
  184. // 验证特殊需求开关状态
  185. const isSpecialNeeds = await disabilityPersonPage.getNoteSpecialNeedsStatus(0);
  186. expect(isSpecialNeeds).toBe(true);
  187. console.debug(' ✓ 特殊需求已标记');
  188. console.debug('✅ 特殊需求标记测试通过');
  189. });
  190. test('应该限制最多添加10条备注', async ({ disabilityPersonPage }) => {
  191. const testData = generateUniqueTestData('备注限制');
  192. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  193. console.debug('\n========== 备注数量限制测试 ==========');
  194. // 打开对话框并填写基本信息
  195. await disabilityPersonPage.openCreateDialog();
  196. await disabilityPersonPage.fillBasicForm(testData);
  197. // 滚动到备注管理区域
  198. await disabilityPersonPage.scrollToSection('备注管理');
  199. // 添加10条备注
  200. for (let i = 0; i < 10; i++) {
  201. await disabilityPersonPage.addNote(`备注${i + 1}_${testData.name}`);
  202. }
  203. // 验证有10条备注
  204. const noteList = await disabilityPersonPage.getNoteList();
  205. expect(noteList).toHaveLength(10);
  206. console.debug(' ✓ 已添加 10 条备注');
  207. // 验证添加按钮被禁用
  208. const isDisabled = await disabilityPersonPage.isAddNoteButtonDisabled();
  209. expect(isDisabled).toBe(true);
  210. console.debug(' ✓ 添加按钮已禁用(达到最大数量)');
  211. console.debug('✅ 备注数量限制测试通过');
  212. });
  213. test('完整流程:添加多条备注、编辑、删除', async ({ disabilityPersonPage }) => {
  214. const testData = generateUniqueTestData('完整流程');
  215. createdTestData.push({ name: testData.name, idCard: testData.idCard });
  216. console.debug('\n========== 备注完整流程测试 ==========');
  217. // 打开对话框并填写基本信息
  218. await disabilityPersonPage.openCreateDialog();
  219. await disabilityPersonPage.fillBasicForm(testData);
  220. // 滚动到备注管理区域
  221. await disabilityPersonPage.scrollToSection('备注管理');
  222. // 添加多条备注
  223. await disabilityPersonPage.addNote(`第一条备注_${testData.name}`, { isSpecialNeeds: true });
  224. await disabilityPersonPage.addNote(`第二条备注_${testData.name}`);
  225. await disabilityPersonPage.addNote(`第三条备注_${testData.name}`);
  226. let noteList = await disabilityPersonPage.getNoteList();
  227. expect(noteList).toHaveLength(3);
  228. console.debug(' ✓ 已添加 3 条备注');
  229. // 编辑第一条备注
  230. await disabilityPersonPage.editNote(0, `编辑后的第一条备注_${testData.name}`);
  231. console.debug(' ✓ 第一条备注已编辑');
  232. // 删除第二条备注
  233. await disabilityPersonPage.deleteNote(1);
  234. console.debug(' ✓ 第二条备注已删除');
  235. // 验证最终状态
  236. noteList = await disabilityPersonPage.getNoteList();
  237. expect(noteList).toHaveLength(2);
  238. expect(noteList[0]).toContain('编辑后的第一条备注');
  239. expect(noteList[1]).toContain('第三条备注');
  240. console.debug(' ✓ 最终状态验证通过');
  241. console.debug('✅ 备注完整流程测试通过');
  242. });
  243. });