users.spec.ts 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  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. test.describe.serial('用户管理 E2E 测试', () => {
  9. test.beforeEach(async ({ adminLoginPage, userManagementPage }) => {
  10. // 以管理员身份登录后台
  11. await adminLoginPage.goto();
  12. await adminLoginPage.login(testUsers.admin.username, testUsers.admin.password);
  13. await userManagementPage.goto();
  14. });
  15. test('查看用户列表', async ({ userManagementPage }) => {
  16. await userManagementPage.expectToBeVisible();
  17. const userCount = await userManagementPage.getUserCount();
  18. expect(userCount).toBeGreaterThan(0);
  19. });
  20. test('搜索用户', async ({ userManagementPage }) => {
  21. await userManagementPage.searchUsers('admin');
  22. const userCount = await userManagementPage.getUserCount();
  23. expect(userCount).toBeGreaterThan(0);
  24. // 验证搜索结果包含admin用户
  25. const adminUser = await userManagementPage.getUserByUsername('admin');
  26. expect(adminUser).not.toBeNull();
  27. });
  28. test('创建新用户', async ({ userManagementPage }) => {
  29. const testUsername = `testuser_${Date.now()}`;
  30. const testPassword = 'Test123!@#';
  31. await userManagementPage.createUser({
  32. username: testUsername,
  33. password: testPassword,
  34. nickname: '测试用户',
  35. email: `${testUsername}@example.com`,
  36. phone: '13800138000',
  37. name: '测试用户'
  38. });
  39. // 验证用户创建成功
  40. await userManagementPage.expectUserExists(testUsername);
  41. });
  42. test('编辑用户信息', async ({ userManagementPage }) => {
  43. const testUsername = `edituser_${Date.now()}`;
  44. const testPassword = 'Test123!@#';
  45. // 先创建测试用户
  46. await userManagementPage.createUser({
  47. username: testUsername,
  48. password: testPassword,
  49. nickname: '原始昵称',
  50. email: `${testUsername}@example.com`
  51. });
  52. // 编辑用户信息
  53. await userManagementPage.editUser(testUsername, {
  54. nickname: '更新后的昵称',
  55. email: `updated_${testUsername}@example.com`,
  56. phone: '13900139000',
  57. name: '更新姓名'
  58. });
  59. // 验证用户信息已更新
  60. const userRow = await userManagementPage.getUserByUsername(testUsername);
  61. expect(userRow).not.toBeNull();
  62. await expect(userRow!).toContainText('更新后的昵称');
  63. await expect(userRow!).toContainText(`updated_${testUsername}@example.com`);
  64. });
  65. test('删除用户', async ({ userManagementPage }) => {
  66. const testUsername = `deleteuser_${Date.now()}`;
  67. const testPassword = 'Test123!@#';
  68. // 先创建测试用户
  69. await userManagementPage.createUser({
  70. username: testUsername,
  71. password: testPassword,
  72. nickname: '待删除用户',
  73. email: `${testUsername}@example.com`
  74. });
  75. // 验证用户存在
  76. await userManagementPage.expectUserExists(testUsername);
  77. // 删除用户
  78. await userManagementPage.deleteUser(testUsername);
  79. // 验证用户已被删除
  80. await userManagementPage.expectUserNotExists(testUsername);
  81. });
  82. test('用户分页功能', async ({ userManagementPage }) => {
  83. // 确保有足够多的用户来测试分页
  84. const initialCount = await userManagementPage.getUserCount();
  85. if (initialCount < 10) {
  86. // 创建一些测试用户
  87. for (let i = 0; i < 5; i++) {
  88. await userManagementPage.createUser({
  89. username: `pagetest_${Date.now()}_${i}`,
  90. password: 'Test123!@#',
  91. nickname: `分页测试用户 ${i}`
  92. });
  93. }
  94. }
  95. // 搜索并验证分页控件可见
  96. await userManagementPage.searchUsers('');
  97. await expect(userManagementPage.pagination).toBeVisible();
  98. });
  99. test('创建用户验证 - 用户名已存在', async ({ userManagementPage }) => {
  100. // 尝试创建已存在的用户
  101. await userManagementPage.createUser({
  102. username: 'admin',
  103. password: 'Test123!@#',
  104. nickname: '重复用户'
  105. });
  106. // 应该显示错误消息
  107. await expect(userManagementPage.page.locator('text=创建失败')).toBeVisible();
  108. });
  109. test('响应式布局 - 桌面端', async ({ userManagementPage, page }) => {
  110. await page.setViewportSize({ width: 1200, height: 800 });
  111. await userManagementPage.expectToBeVisible();
  112. // 验证桌面端布局元素
  113. await expect(userManagementPage.searchInput).toBeVisible();
  114. await expect(userManagementPage.createUserButton).toBeVisible();
  115. await expect(userManagementPage.userTable).toBeVisible();
  116. });
  117. test('响应式布局 - 移动端', async ({ userManagementPage, page }) => {
  118. await page.setViewportSize({ width: 375, height: 667 });
  119. await userManagementPage.expectToBeVisible();
  120. // 验证移动端布局
  121. await expect(userManagementPage.pageTitle).toBeVisible();
  122. await expect(userManagementPage.searchInput).toBeVisible();
  123. });
  124. test('完整用户管理工作流 - 登录→创建→编辑→删除', async ({ adminLoginPage, userManagementPage, page }) => {
  125. const testUsername = `workflow_${Date.now()}`;
  126. const testPassword = 'Test123!@#';
  127. // 1. 登录系统
  128. await adminLoginPage.goto();
  129. await adminLoginPage.login(testUsers.admin.username, testUsers.admin.password);
  130. // 验证登录成功,跳转到Dashboard
  131. await expect(page).toHaveURL(/.*dashboard/);
  132. await expect(page.locator('text=仪表盘')).toBeVisible();
  133. // 2. 导航到用户管理页面
  134. await userManagementPage.goto();
  135. await userManagementPage.expectToBeVisible();
  136. // 3. 创建新用户
  137. await userManagementPage.createUser({
  138. username: testUsername,
  139. password: testPassword,
  140. nickname: '工作流测试用户',
  141. email: `${testUsername}@example.com`,
  142. phone: '13800138000',
  143. name: '工作流测试'
  144. });
  145. // 验证用户创建成功
  146. await userManagementPage.expectUserExists(testUsername);
  147. // 4. 搜索并编辑用户
  148. await userManagementPage.searchUsers(testUsername);
  149. await userManagementPage.editUser(testUsername, {
  150. nickname: '更新后的工作流用户',
  151. email: `updated_${testUsername}@example.com`,
  152. phone: '13900139000',
  153. name: '更新工作流测试'
  154. });
  155. // 验证用户信息已更新
  156. await userManagementPage.expectUserExists(testUsername);
  157. const userRow = await userManagementPage.getUserByUsername(testUsername);
  158. expect(userRow).not.toBeNull();
  159. // 5. 删除用户
  160. await userManagementPage.deleteUser(testUsername);
  161. // 验证用户已被删除
  162. await userManagementPage.expectUserNotExists(testUsername);
  163. // 6. 返回Dashboard验证状态
  164. await page.goto('/admin/dashboard');
  165. await expect(page.locator('text=仪表盘')).toBeVisible();
  166. await expect(page.locator('text=欢迎回来')).toBeVisible();
  167. });
  168. test('边界条件测试 - 批量操作和错误处理', async ({ userManagementPage }) => {
  169. // 测试空搜索
  170. await userManagementPage.searchUsers('nonexistentuser12345');
  171. const emptyCount = await userManagementPage.getUserCount();
  172. expect(emptyCount).toBe(0);
  173. // 验证空状态提示 - 检查用户计数为0
  174. await expect(userManagementPage.page.locator('text=共 0 位用户')).toBeVisible();
  175. // 测试特殊字符搜索
  176. await userManagementPage.searchUsers('@#$%');
  177. const specialCharCount = await userManagementPage.getUserCount();
  178. expect(specialCharCount).toBe(0);
  179. // 清除搜索
  180. await userManagementPage.searchUsers('');
  181. const normalCount = await userManagementPage.getUserCount();
  182. expect(normalCount).toBeGreaterThan(0);
  183. });
  184. });