Playwright Best Practices
This skill provides comprehensive guidance for all aspects of Playwright test development, from writing new tests to debugging and maintaining existing test suites.
Activity-Based Reference Guide
Consult these references based on what you're doing:
Writing New Tests
When to use: Creating new test files, writing test cases, implementing test scenarios
| Activity | Reference Files |
|---|---|
| Writing E2E tests | test-suite-structure.md, locators.md, assertions-waiting.md |
| Writing component tests | component-testing.md, test-suite-structure.md |
| Writing API tests | api-testing.md, test-suite-structure.md |
| Writing GraphQL tests | graphql-testing.md, api-testing.md |
| Writing visual regression tests | visual-regression.md, canvas-webgl.md |
| Structuring test code with POM | page-object-model.md, test-suite-structure.md |
| Setting up test data/fixtures | fixtures-hooks.md, test-data.md |
| Handling authentication | authentication.md, authentication-flows.md |
| Testing date/time features | clock-mocking.md |
| Testing file upload/download | file-operations.md, file-upload-download.md |
| Testing forms/validation | forms-validation.md |
| Testing drag and drop | drag-drop.md |
| Testing accessibility | accessibility.md |
| Testing security (XSS, CSRF) | security-testing.md |
| Using test annotations | annotations.md |
| Using test tags | test-tags.md |
| Testing iframes | iframes.md |
| Testing canvas/WebGL | canvas-webgl.md |
| Internationalization (i18n) | i18n.md |
| Testing Electron apps | electron.md |
| Testing browser extensions | browser-extensions.md |
Mobile & Responsive Testing
When to use: Testing mobile devices, touch interactions, responsive layouts
| Activity | Reference Files |
|---|---|
| Device emulation | mobile-testing.md |
| Touch gestures (swipe, tap) | mobile-testing.md |
| Viewport/breakpoint testing | mobile-testing.md |
| Mobile-specific UI | mobile-testing.md, locators.md |
Real-Time & Browser APIs
When to use: Testing WebSockets, geolocation, permissions, multi-tab flows
| Activity | Reference Files |
|---|---|
| WebSocket/real-time testing | websockets.md |
| Geolocation mocking | browser-apis.md |
| Permission handling | browser-apis.md |
| Clipboard testing | browser-apis.md |
| Camera/microphone mocking | browser-apis.md |
| Multi-tab/popup flows | multi-context.md |
| OAuth popup handling | third-party.md, multi-context.md |
Debugging & Troubleshooting
When to use: Test failures, element not found, timeouts, unexpected behavior
| Activity | Reference Files |
|---|---|
| Debugging test failures | debugging.md, assertions-waiting.md |
| Fixing flaky tests | flaky-tests.md, debugging.md, assertions-waiting.md |
| Debugging flaky parallel runs | flaky-tests.md, performance.md, fixtures-hooks.md |
| Ensuring test isolation / avoiding state leak | flaky-tests.md, fixtures-hooks.md, performance.md |
| Fixing selector issues | locators.md, debugging.md |
| Investigating timeout issues | assertions-waiting.md, debugging.md |
| Using trace viewer | debugging.md |
| Debugging race conditions | flaky-tests.md, debugging.md, assertions-waiting.md |
| Debugging console/JS errors | console-errors.md, debugging.md |
Error & Edge Case Testing
When to use: Testing error states, offline mode, network failures, validation
| Activity | Reference Files |
|---|---|
| Error boundary testing | error-testing.md |
| Network failure simulation | error-testing.md, network-advanced.md |
| Offline mode testing | error-testing.md, service-workers.md |
| Service worker testing | service-workers.md |
| Loading state testing | error-testing.md |
| Form validation testing | error-testing.md |
Multi-User & Collaboration Testing
When to use: Testing features involving multiple users, roles, or real-time collaboration
| Activity | Reference Files |
|---|---|
| Multiple users in one test | multi-user.md |
| Real-time collaboration | multi-user.md, websockets.md |
| Role-based access testing | multi-user.md |
| Concurrent action testing | multi-user.md |
Architecture Decisions
When to use: Choosing test patterns, deciding between approaches, planning test architecture
| Activity | Reference Files |
|---|---|
| POM vs fixtures decision | pom-vs-fixtures.md |
| Test type selection | test-architecture.md |
| Mock vs real services | when-to-mock.md |
| Test suite structure | test-suite-structure.md |
Framework-Specific Testing
When to use: Testing React, Angular, Vue, or Next.js applications
| Activity | Reference Files |
|---|---|
| Testing React apps | react.md |
| Testing Angular apps | angular.md |
| Testing Vue/Nuxt apps | vue.md |
| Testing Next.js apps | nextjs.md |
Refactoring & Maintenance
When to use: Improving existing tests, code review, reducing duplication
| Activity | Reference Files |
|---|---|
| Refactoring to Page Object Model | page-object-model.md, test-suite-structure.md |
| Improving test organization | test-suite-structure.md, page-object-model.md |
| Extracting common setup/teardown | fixtures-hooks.md |
| Replacing brittle selectors | locators.md |
| Removing explicit waits | assertions-waiting.md |
| Creating test data factories | test-data.md |
| Configuration setup | configuration.md |
Infrastructure & Configuration
When to use: Setting up projects, configuring CI/CD, optimizing performance
| Activity | Reference Files |
|---|---|
| Configuring Playwright project | configuration.md, projects-dependencies.md |
| Setting up CI/CD pipelines | ci-cd.md, github-actions.md |
| GitHub Actions setup | github-actions.md |
| GitLab CI setup | gitlab.md |
| Other CI providers | other-providers.md |
| Docker/container setup | docker.md |
| Global setup & teardown | global-setup.md |
| Project dependencies | projects-dependencies.md |
| Optimizing test performance | performance.md, test-suite-structure.md |
| Configuring parallel execution | parallel-sharding.md, performance.md |
| Isolating test data between workers | fixtures-hooks.md, performance.md |
| Test coverage | test-coverage.md |
| Test reporting/artifacts | reporting.md |
Advanced Patterns
When to use: Complex scenarios, API mocking, network interception
| Activity | Reference Files |
|---|---|
| Mocking API responses | test-suite-structure.md, network-advanced.md |
| Network interception | network-advanced.md, assertions-waiting.md |
| GraphQL mocking | network-advanced.md |
| HAR recording/playback | network-advanced.md |
| Custom fixtures | fixtures-hooks.md |
| Advanced waiting strategies | assertions-waiting.md |
| OAuth/SSO mocking | third-party.md, multi-context.md |
| Payment gateway mocking | third-party.md |
| Email/SMS verification mocking | third-party.md |
| Failing on console errors | console-errors.md |
| Security testing (XSS, CSRF) | security-testing.md |
| Performance budgets & Web Vitals | performance-testing.md |
| Lighthouse integration | performance-testing.md |
| Test annotations (skip, fixme) | annotations.md |
| Test tags (@smoke, @fast) | test-tags.md |
| Test steps for reporting | annotations.md |
Quick Decision Tree
What are you doing?
โ
โโ Writing a new test?
โ โโ E2E test โ core/test-suite-structure.md, core/locators.md, core/assertions-waiting.md
โ โโ Component test โ testing-patterns/component-testing.md
โ โโ API test โ testing-patterns/api-testing.md, core/test-suite-structure.md
โ โโ GraphQL test โ testing-patterns/graphql-testing.md
โ โโ Visual regression โ testing-patterns/visual-regression.md
โ โโ Visual/canvas test โ testing-patterns/canvas-webgl.md, core/test-suite-structure.md
โ โโ Accessibility test โ testing-patterns/accessibility.md
โ โโ Mobile/responsive test โ advanced/mobile-testing.md
โ โโ i18n/locale test โ testing-patterns/i18n.md
โ โโ Electron app test โ testing-patterns/electron.md
โ โโ Browser extension test โ testing-patterns/browser-extensions.md
โ โโ Multi-user test โ advanced/multi-user.md
โ โโ Form validation test โ testing-patterns/forms-validation.md
โ โโ Drag and drop test โ testing-patterns/drag-drop.md
โ
โโ Testing specific features?
โ โโ File upload/download โ testing-patterns/file-operations.md, testing-patterns/file-upload-download.md
โ โโ Date/time dependent โ advanced/clock-mocking.md
โ โโ WebSocket/real-time โ browser-apis/websockets.md
โ โโ Geolocation/permissions โ browser-apis/browser-apis.md
โ โโ OAuth/SSO mocking โ advanced/third-party.md, advanced/multi-context.md
โ โโ Payments/email/SMS โ advanced/third-party.md
โ โโ iFrames โ browser-apis/iframes.md
โ โโ Canvas/WebGL/charts โ testing-patterns/canvas-webgl.md
โ โโ Service workers/PWA โ browser-apis/service-workers.md
โ โโ i18n/localization โ testing-patterns/i18n.md
โ โโ Security (XSS, CSRF) โ testing-patterns/security-testing.md
โ โโ Performance/Web Vitals โ testing-patterns/performance-testing.md
โ
โโ Architecture decisions?
โ โโ POM vs fixtures โ architecture/pom-vs-fixtures.md
โ โโ Test type selection โ architecture/test-architecture.md
โ โโ Mock vs real services โ architecture/when-to-mock.md
โ โโ Test suite structure โ core/test-suite-structure.md
โ
โโ Framework-specific testing?
โ โโ React app โ frameworks/react.md
โ โโ Angular app โ frameworks/angular.md
โ โโ Vue/Nuxt app โ frameworks/vue.md
โ โโ Next.js app โ frameworks/nextjs.md
โ
โโ Authentication testing?
โ โโ Basic auth patterns โ advanced/authentication.md
โ โโ Complex flows (MFA, reset) โ advanced/authentication-flows.md
โ
โโ Test is failing/flaky?
โ โโ Flaky test investigation โ debugging/flaky-tests.md
โ โโ Element not found โ core/locators.md, debugging/debugging.md
โ โโ Timeout issues โ core/assertions-waiting.md, debugging/debugging.md
โ โโ Race conditions โ debugging/flaky-tests.md, debugging/debugging.md
โ โโ Flaky only with multiple workers โ debugging/flaky-tests.md, infrastructure-ci-cd/performance.md
โ โโ State leak / isolation โ debugging/flaky-tests.md, core/fixtures-hooks.md
โ โโ Console/JS errors โ debugging/console-errors.md, debugging/debugging.md
โ โโ General debugging โ debugging/debugging.md
โ
โโ Testing error scenarios?
โ โโ Network failures โ debugging/error-testing.md, advanced/network-advanced.md
โ โโ Offline (unexpected) โ debugging/error-testing.md
โ โโ Offline-first/PWA โ browser-apis/service-workers.md
โ โโ Error boundaries โ debugging/error-testing.md
โ โโ Form validation โ testing-patterns/forms-validation.md, debugging/error-testing.md
โ
โโ Refactoring existing code?
โ โโ Implementing POM โ core/page-object-model.md
โ โโ Improving selectors โ core/locators.md
โ โโ Extracting fixtures โ core/fixtures-hooks.md
โ โโ Creating data factories โ core/test-data.md
โ โโ Configuration setup โ core/configuration.md
โ
โโ Setting up infrastructure?
โ โโ CI/CD โ infrastructure-ci-cd/ci-cd.md
โ โโ GitHub Actions โ infrastructure-ci-cd/github-actions.md
โ โโ GitLab CI โ infrastructure-ci-cd/gitlab.md
โ โโ Other CI providers โ infrastructure-ci-cd/other-providers.md
โ โโ Docker/containers โ infrastructure-ci-cd/docker.md
โ โโ Sharding/parallel โ infrastructure-ci-cd/parallel-sharding.md
โ โโ Reporting/artifacts โ infrastructure-ci-cd/reporting.md
โ โโ Global setup/teardown โ core/global-setup.md
โ โโ Project dependencies โ core/projects-dependencies.md
โ โโ Test performance โ infrastructure-ci-cd/performance.md
โ โโ Test coverage โ infrastructure-ci-cd/test-coverage.md
โ โโ Project config โ core/configuration.md, core/projects-dependencies.md
โ
โโ Organizing tests?
โ โโ Skip/fixme/slow tests โ core/annotations.md
โ โโ Test tags (@smoke, @fast) โ core/test-tags.md
โ โโ Filtering tests (--grep) โ core/test-tags.md
โ โโ Test steps โ core/annotations.md
โ โโ Conditional execution โ core/annotations.md
โ
โโ Running subset of tests?
โโ By tag (@smoke, @critical) โ core/test-tags.md
โโ Exclude slow/flaky tests โ core/test-tags.md
โโ PR vs nightly tests โ core/test-tags.md, infrastructure-ci-cd/ci-cd.md
โโ Project-specific filtering โ core/test-tags.md, core/configuration.mdTest Validation Loop
After writing or modifying tests:
- Run tests:
npx playwright test --reporter=list - If tests fail:
- Review error output and trace (
npx playwright show-trace) - Fix locators, waits, or assertions
- Re-run tests
- Only proceed when all tests pass
- Run multiple times for critical tests:
npx playwright test --repeat-each=5