fix: 修复E2E测试选择器和等待策略
问题分析: 1. 错误消息使用ElMessage toast,测试期望页面文本 2. 登出下拉菜单选择器不够精确 3. 用户管理页面按钮文本不匹配 4. 缺少适当的等待策略 修复内容: - 登录流程测试:检测.el-message--error toast消息 - 表单验证测试:触发blur事件后检测.el-form-item__error - 登出流程测试:使用更精确的下拉菜单选择器 - 用户管理测试:修正按钮文本为'新增用户' - 添加waitForLoadState确保页面加载完成 - 增加timeout参数提高测试稳定性
This commit is contained in:
@@ -36,7 +36,7 @@ test.describe('登录流程测试', () => {
|
||||
await page.fill('input[placeholder*="密码"]', 'wrongpassword');
|
||||
await page.click('button:has-text("登录")');
|
||||
|
||||
const errorMessage = page.locator('text=/用户名或密码错误|登录失败|密码错误/i');
|
||||
const errorMessage = page.locator('.el-message--error');
|
||||
await expect(errorMessage).toBeVisible({ timeout: 5000 });
|
||||
|
||||
await expect(page).toHaveURL(/\/login/);
|
||||
@@ -46,9 +46,11 @@ test.describe('登录流程测试', () => {
|
||||
await page.goto('/login');
|
||||
|
||||
await page.fill('input[placeholder*="密码"]', 'Test@123');
|
||||
await page.click('input[placeholder*="用户名"]');
|
||||
await page.click('input[placeholder*="密码"]');
|
||||
await page.click('button:has-text("登录")');
|
||||
|
||||
const validationMessage = page.locator('text=/请输入用户名|用户名不能为空|请输入用户名/i');
|
||||
const validationMessage = page.locator('.el-form-item__error');
|
||||
await expect(validationMessage).toBeVisible({ timeout: 5000 });
|
||||
});
|
||||
|
||||
@@ -56,9 +58,11 @@ test.describe('登录流程测试', () => {
|
||||
await page.goto('/login');
|
||||
|
||||
await page.fill('input[placeholder*="用户名"]', 'admin');
|
||||
await page.click('input[placeholder*="密码"]');
|
||||
await page.click('input[placeholder*="用户名"]');
|
||||
await page.click('button:has-text("登录")');
|
||||
|
||||
const validationMessage = page.locator('text=/请输入密码|密码不能为空|请输入密码/i');
|
||||
const validationMessage = page.locator('.el-form-item__error');
|
||||
await expect(validationMessage).toBeVisible({ timeout: 5000 });
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user