083de31fc5
问题: - 按钮文本不匹配:测试查找"新建",实际是"新增角色" - 菜单结构不匹配:测试点击父菜单,实际需要点击子菜单 - 菜单名称不匹配:测试查找"系统监控",实际是"审计中心" - 重复登录逻辑:部分测试用例仍在尝试登录 修复: - admin-complete-workflow.spec.ts: 修复按钮文本 - audit-workflow.spec.ts: 修复菜单名称 - system-config-workflow.spec.ts: 修复菜单导航 - file-management-workflow.spec.ts: 修复菜单导航 - user-permission-boundary.spec.ts: 移除重复登录逻辑 优势: - 测试用例与实际页面匹配 - 提高测试稳定性 - 减少测试失败
83 lines
2.9 KiB
TypeScript
83 lines
2.9 KiB
TypeScript
import { test, expect } from '@playwright/test';
|
|
|
|
test.describe('审计工作流', () => {
|
|
test('执行操作并查看操作日志', async ({ page }) => {
|
|
await test.step('执行用户管理操作', async () => {
|
|
await page.goto('/users');
|
|
await page.waitForTimeout(1000);
|
|
});
|
|
|
|
await test.step('执行角色管理操作', async () => {
|
|
await page.goto('/roles');
|
|
await page.waitForTimeout(1000);
|
|
});
|
|
|
|
await test.step('执行菜单管理操作', async () => {
|
|
await page.goto('/menus');
|
|
await page.waitForTimeout(1000);
|
|
});
|
|
|
|
await test.step('导航到操作日志', async () => {
|
|
await page.goto('/dashboard');
|
|
await page.locator('text=审计中心').click();
|
|
await page.locator('text=操作日志').click();
|
|
await expect(page.locator('table')).toBeVisible();
|
|
});
|
|
|
|
await test.step('验证操作日志记录', async () => {
|
|
await page.waitForTimeout(2000);
|
|
const logContent = await page.locator('table').textContent();
|
|
expect(logContent).toMatch(/用户管理|角色管理|菜单管理/);
|
|
});
|
|
});
|
|
|
|
test('查看登录日志', async ({ page }) => {
|
|
await test.step('导航到登录日志', async () => {
|
|
await page.goto('/dashboard');
|
|
await page.locator('text=审计中心').click();
|
|
await page.locator('text=登录日志').click();
|
|
});
|
|
|
|
await test.step('验证登录日志显示', async () => {
|
|
await expect(page.locator('table')).toBeVisible();
|
|
const logContent = await page.locator('table').textContent();
|
|
expect(logContent).toContain('admin');
|
|
});
|
|
});
|
|
|
|
test('搜索和筛选日志', async ({ page }) => {
|
|
await test.step('导航到操作日志', async () => {
|
|
await page.goto('/dashboard');
|
|
await page.locator('text=系统监控').click();
|
|
await page.locator('text=操作日志').click();
|
|
await expect(page.locator('table')).toBeVisible();
|
|
});
|
|
|
|
await test.step('按模块筛选', async () => {
|
|
const moduleSelect = page.locator('.el-select:has-text("模块")');
|
|
if (await moduleSelect.isVisible()) {
|
|
await moduleSelect.click();
|
|
await page.locator('.el-select-dropdown__item:has-text("用户管理")').click();
|
|
await page.waitForTimeout(1000);
|
|
}
|
|
});
|
|
|
|
await test.step('按时间范围筛选', async () => {
|
|
const dateRangePicker = page.locator('.el-date-editor');
|
|
if (await dateRangePicker.isVisible()) {
|
|
await dateRangePicker.click();
|
|
await page.waitForTimeout(500);
|
|
}
|
|
});
|
|
|
|
await test.step('搜索特定内容', async () => {
|
|
const searchInput = page.locator('input[placeholder*="搜索"]');
|
|
if (await searchInput.isVisible()) {
|
|
await searchInput.fill('admin');
|
|
await page.locator('button:has-text("搜索")').click();
|
|
await page.waitForTimeout(1000);
|
|
}
|
|
});
|
|
});
|
|
});
|