Files
novalon-website/e2e/pages/FrontendNewsPage.ts
T
张翔 cda168cf60 feat: 创建Page Object Model基础结构
新增文件:
- e2e/pages/AdminLoginPage.ts - 管理员登录页面对象
- e2e/pages/AdminContentPage.ts - 内容管理页面对象
- e2e/pages/AdminUserPage.ts - 用户管理页面对象
- e2e/pages/FrontendNewsPage.ts - 前端新闻页面对象
- e2e/pages/FrontendProductPage.ts - 前端产品页面对象
- e2e/pages/index.ts - 导出索引文件

功能特性:
- 封装页面交互逻辑,减少测试代码重复
- 提供清晰的API接口,提升测试可读性
- 支持内容创建、删除、验证等核心操作
- 统一等待策略,提升测试稳定性
2026-04-09 13:17:37 +08:00

30 lines
811 B
TypeScript

import { Page, expect } from '@playwright/test';
export class FrontendNewsPage {
constructor(private page: Page) {}
async goto() {
await this.page.goto('/news');
await this.page.waitForLoadState('networkidle');
}
async expectNewsVisible(title: string) {
const newsCard = this.page.locator(`text="${title}"`);
await expect(newsCard).toBeVisible();
}
async expectNewsNotVisible(title: string) {
const newsCard = this.page.locator(`text="${title}"`);
await expect(newsCard).not.toBeVisible();
}
async clickNews(title: string) {
await this.page.locator(`text="${title}"`).click();
await this.page.waitForLoadState('networkidle');
}
async expectNewsDetailVisible(content: string) {
await expect(this.page.locator(`text=${content}`)).toBeVisible();
}
}