| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346 |
- import { test, expect } from '../../utils/test-setup';
- test.describe('路线管理 E2E 测试', () => {
- test.beforeEach(async ({ adminLoginPage, routeManagementPage }) => {
- // 以管理员身份登录后台
- await adminLoginPage.goto();
- await adminLoginPage.login('admin', 'admin123');
- await routeManagementPage.goto();
- });
- test('查看路线列表', async ({ routeManagementPage }) => {
- await routeManagementPage.expectToBeVisible();
- const routeCount = await routeManagementPage.getRouteCount();
- expect(routeCount).toBeGreaterThan(0);
- });
- test('搜索路线', async ({ routeManagementPage }) => {
- // 先获取所有路线
- const initialCount = await routeManagementPage.getRouteCount();
- // 搜索存在的路线
- await routeManagementPage.searchRoutes('北京');
- const searchedCount = await routeManagementPage.getRouteCount();
- expect(searchedCount).toBeGreaterThan(0);
- expect(searchedCount).toBeLessThanOrEqual(initialCount);
- // 搜索不存在的路线
- await routeManagementPage.searchRoutes('nonexistentroute12345');
- const emptyCount = await routeManagementPage.getRouteCount();
- expect(emptyCount).toBe(0);
- // 清除搜索
- await routeManagementPage.searchRoutes('');
- const normalCount = await routeManagementPage.getRouteCount();
- expect(normalCount).toBeGreaterThan(0);
- });
- test('按车型筛选', async ({ routeManagementPage }) => {
- // 筛选大巴车型
- await routeManagementPage.filterByVehicleType('大巴');
- const busCount = await routeManagementPage.getRouteCount();
- expect(busCount).toBeGreaterThanOrEqual(0);
- // 筛选中巴车型
- await routeManagementPage.filterByVehicleType('中巴');
- const vanCount = await routeManagementPage.getRouteCount();
- expect(vanCount).toBeGreaterThanOrEqual(0);
- // 筛选小车车型
- await routeManagementPage.filterByVehicleType('小车');
- const carCount = await routeManagementPage.getRouteCount();
- expect(carCount).toBeGreaterThanOrEqual(0);
- // 重置筛选 - 通过选择全部车型选项
- await routeManagementPage.vehicleTypeFilter.click();
- await routeManagementPage.page.getByRole('option', { name: '全部车型' }).click();
- const allCount = await routeManagementPage.getRouteCount();
- expect(allCount).toBeGreaterThan(0);
- });
- test('创建新路线', async ({ routeManagementPage }) => {
- const testRouteName = `测试路线_${Date.now()}`;
- await routeManagementPage.createRoute({
- name: testRouteName,
- startPoint: '北京',
- endPoint: '上海',
- vehicleType: 'bus',
- price: 200,
- seatCount: 40,
- departureTime: '2025-01-01 08:00',
- activityId: 1
- });
- // 验证路线创建成功
- await routeManagementPage.expectRouteExists(testRouteName);
- });
- test('编辑路线信息', async ({ routeManagementPage }) => {
- const testRouteName = `编辑路线_${Date.now()}`;
- // 先创建测试路线
- await routeManagementPage.createRoute({
- name: testRouteName,
- startPoint: '北京',
- endPoint: '上海',
- vehicleType: 'bus',
- price: 200,
- seatCount: 40,
- departureTime: '2025-01-01 08:00',
- activityId: 1
- });
- // 编辑路线信息
- await routeManagementPage.editRoute(testRouteName, {
- name: `${testRouteName}_更新`,
- startPoint: '广州',
- endPoint: '深圳',
- vehicleType: 'van',
- price: 150,
- seatCount: 20,
- departureTime: '2025-01-02 09:00'
- });
- // 验证路线信息已更新
- await routeManagementPage.expectRouteExists(`${testRouteName}_更新`);
- });
- test('删除路线', async ({ routeManagementPage }) => {
- const testRouteName = `删除路线_${Date.now()}`;
- // 先创建测试路线
- await routeManagementPage.createRoute({
- name: testRouteName,
- startPoint: '北京',
- endPoint: '上海',
- vehicleType: 'bus',
- price: 200,
- seatCount: 40,
- departureTime: '2025-01-01 08:00',
- activityId: 1
- });
- // 验证路线存在
- await routeManagementPage.expectRouteExists(testRouteName);
- // 删除路线
- await routeManagementPage.deleteRoute(testRouteName);
- // 验证路线已被删除
- await routeManagementPage.expectRouteNotExists(testRouteName);
- });
- test('启用/禁用路线', async ({ routeManagementPage }) => {
- const testRouteName = `状态路线_${Date.now()}`;
- // 先创建测试路线
- await routeManagementPage.createRoute({
- name: testRouteName,
- startPoint: '北京',
- endPoint: '上海',
- vehicleType: 'bus',
- price: 200,
- seatCount: 40,
- departureTime: '2025-01-01 08:00',
- activityId: 1
- });
- // 验证路线存在
- await routeManagementPage.expectRouteExists(testRouteName);
- // 获取初始状态
- const initialStatus = await routeManagementPage.getRouteStatus(testRouteName);
- expect(initialStatus).toMatch(/启用|禁用/);
- // 切换状态
- await routeManagementPage.toggleRouteStatus(testRouteName);
- // 验证状态已切换
- const newStatus = await routeManagementPage.getRouteStatus(testRouteName);
- expect(newStatus).not.toBe(initialStatus);
- // 再次切换状态
- await routeManagementPage.toggleRouteStatus(testRouteName);
- // 验证状态恢复
- const finalStatus = await routeManagementPage.getRouteStatus(testRouteName);
- expect(finalStatus).toBe(initialStatus);
- });
- test('路线分页功能', async ({ routeManagementPage }) => {
- // 确保有足够多的路线来测试分页
- const initialCount = await routeManagementPage.getRouteCount();
- if (initialCount < 10) {
- // 创建一些测试路线
- for (let i = 0; i < 5; i++) {
- await routeManagementPage.createRoute({
- name: `分页测试路线_${Date.now()}_${i}`,
- startPoint: `城市${i}`,
- endPoint: `城市${i + 1}`,
- vehicleType: i % 3 === 0 ? 'bus' : i % 3 === 1 ? 'van' : 'car',
- price: 100 + i * 20,
- seatCount: 30 + i * 5,
- departureTime: `2025-01-01 0${8 + i}:00`,
- activityId: 1
- });
- }
- }
- // 验证分页控件可见
- await expect(routeManagementPage.pagination).toBeVisible();
- });
- test('完整路线管理工作流 - 登录→创建→编辑→启用/禁用→删除', async ({ adminLoginPage, routeManagementPage, page }) => {
- const testRouteName = `工作流路线_${Date.now()}`;
- // 1. 登录系统
- await adminLoginPage.goto();
- await adminLoginPage.login('admin', 'admin123');
- // 验证登录成功,跳转到Dashboard
- await expect(page).toHaveURL(/.*dashboard/);
- await expect(page.locator('text=仪表盘')).toBeVisible();
- // 2. 导航到路线管理页面
- await routeManagementPage.goto();
- await routeManagementPage.expectToBeVisible();
- // 3. 创建新路线
- await routeManagementPage.createRoute({
- name: testRouteName,
- startPoint: '北京',
- endPoint: '上海',
- vehicleType: 'bus',
- price: 200,
- seatCount: 40,
- departureTime: '2025-01-01 08:00',
- activityId: 1
- });
- // 验证路线创建成功
- await routeManagementPage.expectRouteExists(testRouteName);
- // 4. 搜索并编辑路线
- await routeManagementPage.searchRoutes(testRouteName);
- await routeManagementPage.editRoute(testRouteName, {
- name: `${testRouteName}_更新`,
- startPoint: '广州',
- endPoint: '深圳',
- vehicleType: 'van',
- price: 150,
- seatCount: 20,
- departureTime: '2025-01-02 09:00'
- });
- // 验证路线信息已更新
- await routeManagementPage.expectRouteExists(`${testRouteName}_更新`);
- // 5. 启用/禁用路线
- await routeManagementPage.toggleRouteStatus(`${testRouteName}_更新`);
- const statusAfterToggle = await routeManagementPage.getRouteStatus(`${testRouteName}_更新`);
- expect(statusAfterToggle).toMatch(/启用|禁用/);
- // 6. 删除路线
- await routeManagementPage.deleteRoute(`${testRouteName}_更新`);
- // 验证路线已被删除
- await routeManagementPage.expectRouteNotExists(`${testRouteName}_更新`);
- // 7. 返回Dashboard验证状态
- await page.goto('/admin/dashboard');
- await expect(page.locator('text=仪表盘')).toBeVisible();
- await expect(page.locator('text=欢迎回来')).toBeVisible();
- });
- test('边界条件测试 - 空搜索和特殊字符', async ({ routeManagementPage }) => {
- // 测试空搜索
- await routeManagementPage.searchRoutes('');
- const normalCount = await routeManagementPage.getRouteCount();
- expect(normalCount).toBeGreaterThan(0);
- // 测试特殊字符搜索
- await routeManagementPage.searchRoutes('@#$%');
- const specialCharCount = await routeManagementPage.getRouteCount();
- expect(specialCharCount).toBe(0);
- // 清除搜索
- await routeManagementPage.searchRoutes('');
- const restoredCount = await routeManagementPage.getRouteCount();
- expect(restoredCount).toBeGreaterThan(0);
- });
- test('响应式布局 - 桌面端', async ({ routeManagementPage, page }) => {
- await page.setViewportSize({ width: 1200, height: 800 });
- await routeManagementPage.expectToBeVisible();
- // 验证桌面端布局元素
- await expect(routeManagementPage.searchInput).toBeVisible();
- await expect(routeManagementPage.createRouteButton).toBeVisible();
- await expect(routeManagementPage.routeTable).toBeVisible();
- });
- test('响应式布局 - 移动端', async ({ routeManagementPage, page }) => {
- await page.setViewportSize({ width: 375, height: 667 });
- await routeManagementPage.expectToBeVisible();
- // 验证移动端布局
- await expect(routeManagementPage.pageTitle).toBeVisible();
- await expect(routeManagementPage.searchInput).toBeVisible();
- });
- test('价格和座位数验证', async ({ routeManagementPage }) => {
- const testRouteName = `验证路线_${Date.now()}`;
- // 创建路线并验证价格和座位数显示
- await routeManagementPage.createRoute({
- name: testRouteName,
- startPoint: '北京',
- endPoint: '上海',
- vehicleType: 'bus',
- price: 250,
- seatCount: 45,
- departureTime: '2025-01-01 08:00',
- activityId: 1
- });
- // 验证路线存在
- await routeManagementPage.expectRouteExists(testRouteName);
- // 验证价格和座位数在表格中正确显示
- const routeRow = await routeManagementPage.getRouteByName(testRouteName);
- expect(routeRow).not.toBeNull();
- await expect(routeRow!).toContainText('¥250');
- await expect(routeRow!).toContainText('45');
- });
- test('车型显示验证', async ({ routeManagementPage }) => {
- const testRouteName = `车型路线_${Date.now()}`;
- // 创建不同车型的路线
- const vehicleTypes = ['bus', 'van', 'car'];
- const vehicleTypeNames = ['大巴', '中巴', '小车'];
- for (let i = 0; i < vehicleTypes.length; i++) {
- const routeName = `${testRouteName}_${vehicleTypes[i]}`;
- await routeManagementPage.createRoute({
- name: routeName,
- startPoint: '城市A',
- endPoint: '城市B',
- vehicleType: vehicleTypes[i] as 'bus' | 'van' | 'car',
- price: 100,
- seatCount: 30,
- departureTime: '2025-01-01 08:00',
- activityId: 1
- });
- // 验证车型正确显示
- await routeManagementPage.expectRouteExists(routeName);
- const routeRow = await routeManagementPage.getRouteByName(routeName);
- expect(routeRow).not.toBeNull();
- await expect(routeRow!).toContainText(vehicleTypeNames[i]);
- }
- });
- });
|