d14513ff34
删除文件: - e2e/admin-frontend-interaction.spec.ts - e2e/admin-publish-core.spec.ts - e2e/admin-publish.spec.ts - e2e/website-acceptance.spec.ts 原因: - 已被新的测试架构替代 - 新架构采用Page Object Model模式 - 新架构有更清晰的测试分类(smoke/journeys/features) - 新架构提供更好的可维护性和可扩展性 新测试架构: - smoke/ - 冒烟测试 - journeys/ - 用户旅程测试 - features/ - 功能测试 - pages/ - Page Object Model - fixtures/ - 测试固件
79 lines
2.2 KiB
TypeScript
79 lines
2.2 KiB
TypeScript
import { test, expect } from '@playwright/test';
|
|
|
|
test.describe('无障碍测试 @feature @frontend', () => {
|
|
test('首页无障碍检查', async ({ page }) => {
|
|
await page.goto('/');
|
|
|
|
const violations = await page.evaluate(() => {
|
|
return (window as unknown as { axe?: { run: () => unknown[] } }).axe?.run() || [];
|
|
});
|
|
|
|
expect(violations.length).toBe(0);
|
|
});
|
|
|
|
test('导航键盘可访问', async ({ page }) => {
|
|
await page.goto('/');
|
|
|
|
await page.keyboard.press('Tab');
|
|
const focusedElement = page.locator(':focus');
|
|
await expect(focusedElement).toBeVisible();
|
|
});
|
|
|
|
test('图片有alt属性', async ({ page }) => {
|
|
await page.goto('/');
|
|
|
|
const images = page.locator('img');
|
|
const count = await images.count();
|
|
|
|
for (let i = 0; i < count; i++) {
|
|
const img = images.nth(i);
|
|
const alt = await img.getAttribute('alt');
|
|
expect(alt).not.toBeNull();
|
|
}
|
|
});
|
|
|
|
test('表单标签关联正确', async ({ page }) => {
|
|
await page.goto('/contact');
|
|
|
|
const inputs = page.locator('input[type="text"], input[type="email"], textarea');
|
|
const count = await inputs.count();
|
|
|
|
for (let i = 0; i < count; i++) {
|
|
const input = inputs.nth(i);
|
|
const id = await input.getAttribute('id');
|
|
|
|
if (id) {
|
|
const label = page.locator(`label[for="${id}"]`);
|
|
const hasLabel = await label.count() > 0;
|
|
const hasAriaLabel = await input.getAttribute('aria-label');
|
|
|
|
expect(hasLabel || hasAriaLabel).toBeTruthy();
|
|
}
|
|
}
|
|
});
|
|
|
|
test('标题层级正确', async ({ page }) => {
|
|
await page.goto('/');
|
|
|
|
const h1 = page.locator('h1');
|
|
const h1Count = await h1.count();
|
|
expect(h1Count).toBeGreaterThanOrEqual(1);
|
|
expect(h1Count).toBeLessThanOrEqual(1);
|
|
});
|
|
|
|
test('链接有明确的文本', async ({ page }) => {
|
|
await page.goto('/');
|
|
|
|
const links = page.locator('a');
|
|
const count = await links.count();
|
|
|
|
for (let i = 0; i < Math.min(count, 10); i++) {
|
|
const link = links.nth(i);
|
|
const text = await link.textContent();
|
|
const ariaLabel = await link.getAttribute('aria-label');
|
|
|
|
expect(text || ariaLabel).toBeTruthy();
|
|
}
|
|
});
|
|
});
|