disability-person-debug.spec.ts 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. import { test } 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. test.describe.serial('残疾人管理 - 参数错误调试测试', () => {
  9. test.beforeEach(async ({ adminLoginPage, disabilityPersonPage }) => {
  10. // 以管理员身份登录后台
  11. await adminLoginPage.goto();
  12. await adminLoginPage.login(testUsers.admin.username, testUsers.admin.password);
  13. await adminLoginPage.expectLoginSuccess();
  14. await disabilityPersonPage.goto();
  15. });
  16. test('调试: 新增残疾人时的参数错误问题', async ({ disabilityPersonPage, page }) => {
  17. // 生成唯一的测试数据 - 使用数据库中实际存在的省份
  18. const timestamp = Date.now();
  19. const testData = {
  20. name: `调试测试_${timestamp}`,
  21. gender: '男',
  22. idCard: `11010119900101123${timestamp % 10}`,
  23. disabilityId: `5110011990010${timestamp % 10}`,
  24. disabilityType: '视力残疾',
  25. disabilityLevel: '一级',
  26. phone: `1380013800${timestamp % 10}`,
  27. idAddress: '湖北省武汉市测试街道1号',
  28. province: '湖北省',
  29. city: '武汉市'
  30. };
  31. console.log('\n========== 开始调试测试 ==========');
  32. console.log('测试数据:', JSON.stringify(testData, null, 2));
  33. // 1. 打开创建对话框
  34. console.log('\n[步骤1] 打开新增残疾人对话框...');
  35. await disabilityPersonPage.openCreateDialog();
  36. console.log('✓ 对话框已打开');
  37. // 2. 填写表单 - 简化版,只填必填项和能工作的字段
  38. console.log('\n[步骤2] 填写表单...');
  39. await disabilityPersonPage.page.waitForSelector('form#create-form', { state: 'visible', timeout: 5000 });
  40. // 填写基本信息 - 使用键盘选择枚举字段
  41. await disabilityPersonPage.page.getByLabel('姓名 *').fill(testData.name);
  42. // 性别默认是"男",跳过
  43. await disabilityPersonPage.page.getByLabel('身份证号 *').fill(testData.idCard);
  44. await disabilityPersonPage.page.getByLabel('残疾证号 *').fill(testData.disabilityId);
  45. // 使用键盘选择残疾类型(第2个选项是"视力残疾")
  46. const disabilityTypeCombobox = disabilityPersonPage.page.getByRole('combobox', { name: '残疾类型 *' });
  47. await disabilityTypeCombobox.click();
  48. await disabilityPersonPage.page.keyboard.press('ArrowDown'); // 跳过"请选择残疾类型"
  49. await disabilityPersonPage.page.keyboard.press('ArrowDown'); // 选择"视力残疾"
  50. await disabilityPersonPage.page.keyboard.press('Enter');
  51. // 使用键盘选择残疾等级(第2个选项是"一级")
  52. const disabilityLevelCombobox = disabilityPersonPage.page.getByRole('combobox', { name: '残疾等级 *' });
  53. await disabilityLevelCombobox.click();
  54. await disabilityPersonPage.page.keyboard.press('ArrowDown'); // 跳过"请选择残疾等级"
  55. await disabilityPersonPage.page.keyboard.press('ArrowDown'); // 选择"一级"
  56. await disabilityPersonPage.page.keyboard.press('Enter');
  57. await disabilityPersonPage.page.getByLabel('联系电话 *').fill(testData.phone);
  58. await disabilityPersonPage.page.getByLabel('身份证地址 *').fill(testData.idAddress);
  59. // 居住地址 - 异步加载类型,能工作
  60. await disabilityPersonPage.selectRadixOption('省份 *', testData.province);
  61. await disabilityPersonPage.page.waitForTimeout(500);
  62. await disabilityPersonPage.selectRadixOption('城市', testData.city);
  63. console.log('✓ 表单已填写');
  64. // 3. 提交表单并捕获网络请求
  65. console.log('\n[步骤3] 提交表单并监听网络请求...');
  66. const result = await disabilityPersonPage.submitForm();
  67. console.log('\n========== 网络请求分析 ==========');
  68. if (result.responses.length === 0) {
  69. console.log('⚠️ 没有捕获到任何相关网络请求!');
  70. } else {
  71. result.responses.forEach((resp, index) => {
  72. console.log(`\n[请求 ${index + 1}]`);
  73. console.log(' URL:', resp.url);
  74. console.log(' 方法:', resp.method);
  75. console.log(' 状态码:', resp.status);
  76. console.log(' OK:', resp.ok);
  77. console.log(' 状态文本:', resp.statusText);
  78. if (resp.requestBody) {
  79. console.log(' 请求体:', JSON.stringify(resp.requestBody, null, 2));
  80. }
  81. if (resp.responseBody) {
  82. console.log(' 响应体:', JSON.stringify(resp.responseBody, null, 2));
  83. }
  84. // 关键检查:状态码与响应内容
  85. console.log('\n 🔍 状态码分析:');
  86. if (resp.status === 200) {
  87. console.log(' ✓ HTTP 状态码是 200 (成功)');
  88. if (resp.responseBody) {
  89. if (resp.responseBody.message) {
  90. console.log(' 响应消息:', resp.responseBody.message);
  91. }
  92. if (resp.responseBody.error) {
  93. console.log(' ⚠️ 响应包含错误信息:', resp.responseBody.error);
  94. }
  95. }
  96. } else if (resp.status === 201) {
  97. console.log(' ✓ HTTP 状态码是 201 (已创建)');
  98. } else if (resp.status >= 400) {
  99. console.log(' ✗ HTTP 错误状态码:', resp.status);
  100. }
  101. console.log('\n 响应头:', JSON.stringify(resp.responseHeaders, null, 2));
  102. });
  103. }
  104. console.log('\n========== UI 提示分析 ==========');
  105. console.log('有错误提示:', result.hasError);
  106. console.log('有成功提示:', result.hasSuccess);
  107. if (result.errorMessage) {
  108. console.log('❌ 错误消息:', result.errorMessage);
  109. }
  110. if (result.successMessage) {
  111. console.log('✅ 成功消息:', result.successMessage);
  112. }
  113. // 4. 验证数据是否真的创建成功
  114. console.log('\n[步骤4] 验证数据是否创建成功...');
  115. // 关闭对话框(如果还在)
  116. const dialogVisible = await page.locator('[role="dialog"]').isVisible().catch(() => false);
  117. if (dialogVisible) {
  118. await page.keyboard.press('Escape');
  119. await page.waitForTimeout(500);
  120. }
  121. // 刷新页面
  122. await page.reload();
  123. await page.waitForLoadState('networkidle');
  124. await disabilityPersonPage.goto();
  125. // 搜索刚创建的残疾人
  126. await disabilityPersonPage.searchByName(testData.name);
  127. await page.waitForTimeout(1000);
  128. const personExists = await disabilityPersonPage.personExists(testData.name);
  129. console.log('\n========== 最终结论 ==========');
  130. console.log('数据实际创建成功:', personExists);
  131. if (result.hasError && personExists) {
  132. console.log('\n🔴 问题确认!');
  133. console.log(' - 前端显示:创建失败(参数错误)');
  134. console.log(' - 实际情况:数据已成功创建到数据库');
  135. console.log('\n 可能原因:');
  136. console.log(' 1. 前端判断响应状态码的逻辑错误');
  137. console.log(' 2. 后端返回 200 但前端期望 201');
  138. console.log(' 3. 响应数据结构不符合前端预期');
  139. console.log(' 4. 前端错误处理逻辑将成功误判为失败');
  140. } else if (result.hasSuccess && personExists) {
  141. console.log('\n✅ 测试通过:前端显示成功,数据也创建成功');
  142. } else if (!result.hasError && !result.hasSuccess) {
  143. console.log('\n⚠️ 没有任何提示消息');
  144. }
  145. console.log('================================\n');
  146. });
  147. });