playwright
28
总安装量
28
周安装量
#7417
全站排名
安装命令
npx skills add https://github.com/mindrally/skills --skill playwright
Agent 安装分布
claude-code
22
gemini-cli
19
antigravity
19
opencode
17
cursor
17
codex
15
Skill 文档
Playwright Testing Best Practices
You are a Senior QA Automation Engineer expert in TypeScript, JavaScript, and Playwright end-to-end testing.
Test Design Principles
Test Structure
- Create descriptive test names that clearly explain expected behavior
- Use Playwright fixtures (
test,page,expect) for test isolation - Implement
test.beforeEachandtest.afterEachfor clean state management - Keep tests DRY by extracting reusable logic into helper functions
import { test, expect } from '@playwright/test';
test.describe('User Authentication', () => {
test.beforeEach(async ({ page }) => {
await page.goto('/login');
});
test('should login successfully with valid credentials', async ({ page }) => {
await page.getByLabel('Email').fill('user@example.com');
await page.getByLabel('Password').fill('password123');
await page.getByRole('button', { name: 'Sign In' }).click();
await expect(page.getByRole('heading', { name: 'Dashboard' })).toBeVisible();
});
});
Locator Strategy
Recommended Locators
page.getByRole()– Best for accessibility and user perspectivepage.getByLabel()– For form inputs with labelspage.getByText()– For elements with visible textpage.getByTestId()– Whendata-testidattributes existpage.getByPlaceholder()– For inputs with placeholder text
// Recommended
await page.getByRole('button', { name: 'Submit' }).click();
await page.getByLabel('Email address').fill('test@example.com');
// Avoid
await page.locator('.btn-primary').click();
Assertions and Waits
Web-First Assertions
Prefer web-first assertions that automatically wait and retry:
toBeVisible()– Element is visibletoHaveText()– Element has specific texttoHaveValue()– Input has specific valuetoHaveURL()– Page URL assertion
// Recommended - web-first assertions
await expect(page.getByRole('alert')).toBeVisible();
await expect(page).toHaveURL('/dashboard');
// Avoid - hardcoded timeouts
await page.waitForTimeout(5000); // Never do this
Waiting Best Practices
- Avoid hardcoded timeouts
- Use
page.waitForLoadState()for navigation - Use
page.waitForResponse()for API calls
Configuration
import { defineConfig, devices } from '@playwright/test';
export default defineConfig({
testDir: './tests',
fullyParallel: true,
retries: process.env.CI ? 2 : 0,
use: {
baseURL: 'http://localhost:3000',
trace: 'on-first-retry',
screenshot: 'only-on-failure',
},
projects: [
{ name: 'chromium', use: { ...devices['Desktop Chrome'] } },
{ name: 'firefox', use: { ...devices['Desktop Firefox'] } },
{ name: 'mobile', use: { ...devices['iPhone 13'] } },
],
});
Best Practices
- Focus on critical user paths reflecting real behavior
- Keep tests independent and deterministic
- Add JSDoc comments for helper functions
- Implement proper error handling and logging