@arcadialdev/arcality 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/.agents/skills/e2e-testing-expert/SKILL.md +28 -0
  2. package/.agents/skills/frontend-design/LICENSE.txt +177 -0
  3. package/.agents/skills/frontend-design/SKILL.md +42 -0
  4. package/.agents/skills/nodejs-backend-patterns/SKILL.md +639 -0
  5. package/.agents/skills/nodejs-backend-patterns/references/advanced-patterns.md +430 -0
  6. package/.agents/skills/playwright-best-practices/LICENSE.md +7 -0
  7. package/.agents/skills/playwright-best-practices/README.md +147 -0
  8. package/.agents/skills/playwright-best-practices/SKILL.md +303 -0
  9. package/.agents/skills/playwright-best-practices/advanced/authentication-flows.md +360 -0
  10. package/.agents/skills/playwright-best-practices/advanced/authentication.md +871 -0
  11. package/.agents/skills/playwright-best-practices/advanced/clock-mocking.md +364 -0
  12. package/.agents/skills/playwright-best-practices/advanced/mobile-testing.md +409 -0
  13. package/.agents/skills/playwright-best-practices/advanced/multi-context.md +288 -0
  14. package/.agents/skills/playwright-best-practices/advanced/multi-user.md +393 -0
  15. package/.agents/skills/playwright-best-practices/advanced/network-advanced.md +452 -0
  16. package/.agents/skills/playwright-best-practices/advanced/third-party.md +464 -0
  17. package/.agents/skills/playwright-best-practices/architecture/pom-vs-fixtures.md +363 -0
  18. package/.agents/skills/playwright-best-practices/architecture/test-architecture.md +369 -0
  19. package/.agents/skills/playwright-best-practices/architecture/when-to-mock.md +383 -0
  20. package/.agents/skills/playwright-best-practices/browser-apis/browser-apis.md +391 -0
  21. package/.agents/skills/playwright-best-practices/browser-apis/iframes.md +403 -0
  22. package/.agents/skills/playwright-best-practices/browser-apis/service-workers.md +504 -0
  23. package/.agents/skills/playwright-best-practices/browser-apis/websockets.md +403 -0
  24. package/.agents/skills/playwright-best-practices/core/annotations.md +424 -0
  25. package/.agents/skills/playwright-best-practices/core/assertions-waiting.md +361 -0
  26. package/.agents/skills/playwright-best-practices/core/configuration.md +452 -0
  27. package/.agents/skills/playwright-best-practices/core/fixtures-hooks.md +417 -0
  28. package/.agents/skills/playwright-best-practices/core/global-setup.md +434 -0
  29. package/.agents/skills/playwright-best-practices/core/locators.md +242 -0
  30. package/.agents/skills/playwright-best-practices/core/page-object-model.md +315 -0
  31. package/.agents/skills/playwright-best-practices/core/projects-dependencies.md +453 -0
  32. package/.agents/skills/playwright-best-practices/core/test-data.md +492 -0
  33. package/.agents/skills/playwright-best-practices/core/test-suite-structure.md +361 -0
  34. package/.agents/skills/playwright-best-practices/core/test-tags.md +298 -0
  35. package/.agents/skills/playwright-best-practices/debugging/console-errors.md +420 -0
  36. package/.agents/skills/playwright-best-practices/debugging/debugging.md +504 -0
  37. package/.agents/skills/playwright-best-practices/debugging/error-testing.md +360 -0
  38. package/.agents/skills/playwright-best-practices/debugging/flaky-tests.md +496 -0
  39. package/.agents/skills/playwright-best-practices/frameworks/angular.md +530 -0
  40. package/.agents/skills/playwright-best-practices/frameworks/nextjs.md +469 -0
  41. package/.agents/skills/playwright-best-practices/frameworks/react.md +531 -0
  42. package/.agents/skills/playwright-best-practices/frameworks/vue.md +574 -0
  43. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/ci-cd.md +468 -0
  44. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/docker.md +283 -0
  45. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/github-actions.md +546 -0
  46. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/gitlab.md +397 -0
  47. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/other-providers.md +521 -0
  48. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/parallel-sharding.md +371 -0
  49. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/performance.md +453 -0
  50. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/reporting.md +424 -0
  51. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/test-coverage.md +497 -0
  52. package/.agents/skills/playwright-best-practices/testing-patterns/accessibility.md +359 -0
  53. package/.agents/skills/playwright-best-practices/testing-patterns/api-testing.md +719 -0
  54. package/.agents/skills/playwright-best-practices/testing-patterns/browser-extensions.md +506 -0
  55. package/.agents/skills/playwright-best-practices/testing-patterns/canvas-webgl.md +493 -0
  56. package/.agents/skills/playwright-best-practices/testing-patterns/component-testing.md +500 -0
  57. package/.agents/skills/playwright-best-practices/testing-patterns/drag-drop.md +576 -0
  58. package/.agents/skills/playwright-best-practices/testing-patterns/electron.md +509 -0
  59. package/.agents/skills/playwright-best-practices/testing-patterns/file-operations.md +377 -0
  60. package/.agents/skills/playwright-best-practices/testing-patterns/file-upload-download.md +562 -0
  61. package/.agents/skills/playwright-best-practices/testing-patterns/forms-validation.md +561 -0
  62. package/.agents/skills/playwright-best-practices/testing-patterns/graphql-testing.md +331 -0
  63. package/.agents/skills/playwright-best-practices/testing-patterns/i18n.md +508 -0
  64. package/.agents/skills/playwright-best-practices/testing-patterns/performance-testing.md +476 -0
  65. package/.agents/skills/playwright-best-practices/testing-patterns/security-testing.md +430 -0
  66. package/.agents/skills/playwright-best-practices/testing-patterns/visual-regression.md +634 -0
  67. package/.env.example +21 -0
  68. package/README.md +30 -0
  69. package/bin/arcality.mjs +86 -0
  70. package/package.json +66 -0
  71. package/playwright.config.ts +12 -0
  72. package/scripts/cleanup-qmsdev.mjs +63 -0
  73. package/scripts/discover-view.mjs +52 -0
  74. package/scripts/extract-view.mjs +64 -0
  75. package/scripts/gen-and-run.mjs +838 -0
  76. package/scripts/init.mjs +290 -0
  77. package/scripts/migrate-to-central-out.mjs +157 -0
  78. package/scripts/postinstall.mjs +63 -0
  79. package/scripts/rebrand-report.mjs +241 -0
  80. package/scripts/setup.mjs +166 -0
  81. package/src/KnowledgeService.ts +239 -0
  82. package/src/arcalityClient.mjs +266 -0
  83. package/src/configLoader.mjs +179 -0
  84. package/src/configManager.mjs +172 -0
  85. package/src/consoleBanner.ts +32 -0
  86. package/src/envSetup.ts +205 -0
  87. package/src/index.ts +25 -0
  88. package/src/projectInspector.ts +42 -0
  89. package/src/services/collectiveMemoryService.ts +178 -0
  90. package/src/testRunner.ts +201 -0
  91. package/tests/_helpers/ArcalityReporter.ts +490 -0
  92. package/tests/_helpers/agentic-runner.spec.ts +741 -0
  93. package/tests/_helpers/ai-agent-helper.ts +1573 -0
  94. package/tests/_helpers/discover-view.spec.ts +238 -0
  95. package/tests/_helpers/extract-view.spec.ts +118 -0
  96. package/tests/_helpers/qa-tools.ts +333 -0
  97. package/tests/_helpers/smart-action.spec.ts +1458 -0
@@ -0,0 +1,303 @@
1
+ ---
2
+ name: playwright-best-practices
3
+ description: Use when writing Playwright tests, fixing flaky tests, debugging failures, implementing Page Object Model, configuring CI/CD, optimizing performance, mocking APIs, handling authentication or OAuth, testing accessibility (axe-core), file uploads/downloads, date/time mocking, WebSockets, geolocation, permissions, multi-tab/popup flows, mobile/responsive layouts, touch gestures, GraphQL, error handling, offline mode, multi-user collaboration, third-party services (payments, email verification), console error monitoring, global setup/teardown, test annotations (skip, fixme, slow), test tags (@smoke, @fast, @critical, filtering with --grep), project dependencies, security testing (XSS, CSRF, auth), performance budgets (Web Vitals, Lighthouse), iframes, component testing, canvas/WebGL, service workers/PWA, test coverage, i18n/localization, Electron apps, or browser extension testing. Covers E2E, component, API, visual, accessibility, security, Electron, and extension testing.
4
+ license: MIT
5
+ metadata:
6
+ author: currents.dev
7
+ version: "1.1"
8
+ ---
9
+
10
+ # Playwright Best Practices
11
+
12
+ This skill provides comprehensive guidance for all aspects of Playwright test development, from writing new tests to debugging and maintaining existing test suites.
13
+
14
+ ## Activity-Based Reference Guide
15
+
16
+ Consult these references based on what you're doing:
17
+
18
+ ### Writing New Tests
19
+
20
+ **When to use**: Creating new test files, writing test cases, implementing test scenarios
21
+
22
+ | Activity | Reference Files |
23
+ | ----------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------- |
24
+ | **Writing E2E tests** | [test-suite-structure.md](core/test-suite-structure.md), [locators.md](core/locators.md), [assertions-waiting.md](core/assertions-waiting.md) |
25
+ | **Writing component tests** | [component-testing.md](testing-patterns/component-testing.md), [test-suite-structure.md](core/test-suite-structure.md) |
26
+ | **Writing API tests** | [api-testing.md](testing-patterns/api-testing.md), [test-suite-structure.md](core/test-suite-structure.md) |
27
+ | **Writing GraphQL tests** | [graphql-testing.md](testing-patterns/graphql-testing.md), [api-testing.md](testing-patterns/api-testing.md) |
28
+ | **Writing visual regression tests** | [visual-regression.md](testing-patterns/visual-regression.md), [canvas-webgl.md](testing-patterns/canvas-webgl.md) |
29
+ | **Structuring test code with POM** | [page-object-model.md](core/page-object-model.md), [test-suite-structure.md](core/test-suite-structure.md) |
30
+ | **Setting up test data/fixtures** | [fixtures-hooks.md](core/fixtures-hooks.md), [test-data.md](core/test-data.md) |
31
+ | **Handling authentication** | [authentication.md](advanced/authentication.md), [authentication-flows.md](advanced/authentication-flows.md) |
32
+ | **Testing date/time features** | [clock-mocking.md](advanced/clock-mocking.md) |
33
+ | **Testing file upload/download** | [file-operations.md](testing-patterns/file-operations.md), [file-upload-download.md](testing-patterns/file-upload-download.md) |
34
+ | **Testing forms/validation** | [forms-validation.md](testing-patterns/forms-validation.md) |
35
+ | **Testing drag and drop** | [drag-drop.md](testing-patterns/drag-drop.md) |
36
+ | **Testing accessibility** | [accessibility.md](testing-patterns/accessibility.md) |
37
+ | **Testing security (XSS, CSRF)** | [security-testing.md](testing-patterns/security-testing.md) |
38
+ | **Using test annotations** | [annotations.md](core/annotations.md) |
39
+ | **Using test tags** | [test-tags.md](core/test-tags.md) |
40
+ | **Testing iframes** | [iframes.md](browser-apis/iframes.md) |
41
+ | **Testing canvas/WebGL** | [canvas-webgl.md](testing-patterns/canvas-webgl.md) |
42
+ | **Internationalization (i18n)** | [i18n.md](testing-patterns/i18n.md) |
43
+ | **Testing Electron apps** | [electron.md](testing-patterns/electron.md) |
44
+ | **Testing browser extensions** | [browser-extensions.md](testing-patterns/browser-extensions.md) |
45
+
46
+ ### Mobile & Responsive Testing
47
+
48
+ **When to use**: Testing mobile devices, touch interactions, responsive layouts
49
+
50
+ | Activity | Reference Files |
51
+ | ------------------------------- | -------------------------------------------------------------------------------- |
52
+ | **Device emulation** | [mobile-testing.md](advanced/mobile-testing.md) |
53
+ | **Touch gestures (swipe, tap)** | [mobile-testing.md](advanced/mobile-testing.md) |
54
+ | **Viewport/breakpoint testing** | [mobile-testing.md](advanced/mobile-testing.md) |
55
+ | **Mobile-specific UI** | [mobile-testing.md](advanced/mobile-testing.md), [locators.md](core/locators.md) |
56
+
57
+ ### Real-Time & Browser APIs
58
+
59
+ **When to use**: Testing WebSockets, geolocation, permissions, multi-tab flows
60
+
61
+ | Activity | Reference Files |
62
+ | ------------------------------- | ---------------------------------------------------------------------------------------- |
63
+ | **WebSocket/real-time testing** | [websockets.md](browser-apis/websockets.md) |
64
+ | **Geolocation mocking** | [browser-apis.md](browser-apis/browser-apis.md) |
65
+ | **Permission handling** | [browser-apis.md](browser-apis/browser-apis.md) |
66
+ | **Clipboard testing** | [browser-apis.md](browser-apis/browser-apis.md) |
67
+ | **Camera/microphone mocking** | [browser-apis.md](browser-apis/browser-apis.md) |
68
+ | **Multi-tab/popup flows** | [multi-context.md](advanced/multi-context.md) |
69
+ | **OAuth popup handling** | [third-party.md](advanced/third-party.md), [multi-context.md](advanced/multi-context.md) |
70
+
71
+ ### Debugging & Troubleshooting
72
+
73
+ **When to use**: Test failures, element not found, timeouts, unexpected behavior
74
+
75
+ | Activity | Reference Files |
76
+ | ------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------- |
77
+ | **Debugging test failures** | [debugging.md](debugging/debugging.md), [assertions-waiting.md](core/assertions-waiting.md) |
78
+ | **Fixing flaky tests** | [flaky-tests.md](debugging/flaky-tests.md), [debugging.md](debugging/debugging.md), [assertions-waiting.md](core/assertions-waiting.md) |
79
+ | **Debugging flaky parallel runs** | [flaky-tests.md](debugging/flaky-tests.md), [performance.md](infrastructure-ci-cd/performance.md), [fixtures-hooks.md](core/fixtures-hooks.md) |
80
+ | **Ensuring test isolation / avoiding state leak** | [flaky-tests.md](debugging/flaky-tests.md), [fixtures-hooks.md](core/fixtures-hooks.md), [performance.md](infrastructure-ci-cd/performance.md) |
81
+ | **Fixing selector issues** | [locators.md](core/locators.md), [debugging.md](debugging/debugging.md) |
82
+ | **Investigating timeout issues** | [assertions-waiting.md](core/assertions-waiting.md), [debugging.md](debugging/debugging.md) |
83
+ | **Using trace viewer** | [debugging.md](debugging/debugging.md) |
84
+ | **Debugging race conditions** | [flaky-tests.md](debugging/flaky-tests.md), [debugging.md](debugging/debugging.md), [assertions-waiting.md](core/assertions-waiting.md) |
85
+ | **Debugging console/JS errors** | [console-errors.md](debugging/console-errors.md), [debugging.md](debugging/debugging.md) |
86
+
87
+ ### Error & Edge Case Testing
88
+
89
+ **When to use**: Testing error states, offline mode, network failures, validation
90
+
91
+ | Activity | Reference Files |
92
+ | ------------------------------ | ----------------------------------------------------------------------------------------------------- |
93
+ | **Error boundary testing** | [error-testing.md](debugging/error-testing.md) |
94
+ | **Network failure simulation** | [error-testing.md](debugging/error-testing.md), [network-advanced.md](advanced/network-advanced.md) |
95
+ | **Offline mode testing** | [error-testing.md](debugging/error-testing.md), [service-workers.md](browser-apis/service-workers.md) |
96
+ | **Service worker testing** | [service-workers.md](browser-apis/service-workers.md) |
97
+ | **Loading state testing** | [error-testing.md](debugging/error-testing.md) |
98
+ | **Form validation testing** | [error-testing.md](debugging/error-testing.md) |
99
+
100
+ ### Multi-User & Collaboration Testing
101
+
102
+ **When to use**: Testing features involving multiple users, roles, or real-time collaboration
103
+
104
+ | Activity | Reference Files |
105
+ | ------------------------------ | ------------------------------------------------------------------------------------ |
106
+ | **Multiple users in one test** | [multi-user.md](advanced/multi-user.md) |
107
+ | **Real-time collaboration** | [multi-user.md](advanced/multi-user.md), [websockets.md](browser-apis/websockets.md) |
108
+ | **Role-based access testing** | [multi-user.md](advanced/multi-user.md) |
109
+ | **Concurrent action testing** | [multi-user.md](advanced/multi-user.md) |
110
+
111
+ ### Architecture Decisions
112
+
113
+ **When to use**: Choosing test patterns, deciding between approaches, planning test architecture
114
+
115
+ | Activity | Reference Files |
116
+ | ---------------------------- | --------------------------------------------------------- |
117
+ | **POM vs fixtures decision** | [pom-vs-fixtures.md](architecture/pom-vs-fixtures.md) |
118
+ | **Test type selection** | [test-architecture.md](architecture/test-architecture.md) |
119
+ | **Mock vs real services** | [when-to-mock.md](architecture/when-to-mock.md) |
120
+ | **Test suite structure** | [test-suite-structure.md](core/test-suite-structure.md) |
121
+
122
+ ### Framework-Specific Testing
123
+
124
+ **When to use**: Testing React, Angular, Vue, or Next.js applications
125
+
126
+ | Activity | Reference Files |
127
+ | ------------------------- | ----------------------------------- |
128
+ | **Testing React apps** | [react.md](frameworks/react.md) |
129
+ | **Testing Angular apps** | [angular.md](frameworks/angular.md) |
130
+ | **Testing Vue/Nuxt apps** | [vue.md](frameworks/vue.md) |
131
+ | **Testing Next.js apps** | [nextjs.md](frameworks/nextjs.md) |
132
+
133
+ ### Refactoring & Maintenance
134
+
135
+ **When to use**: Improving existing tests, code review, reducing duplication
136
+
137
+ | Activity | Reference Files |
138
+ | ------------------------------------ | ---------------------------------------------------------------------------------------------------------- |
139
+ | **Refactoring to Page Object Model** | [page-object-model.md](core/page-object-model.md), [test-suite-structure.md](core/test-suite-structure.md) |
140
+ | **Improving test organization** | [test-suite-structure.md](core/test-suite-structure.md), [page-object-model.md](core/page-object-model.md) |
141
+ | **Extracting common setup/teardown** | [fixtures-hooks.md](core/fixtures-hooks.md) |
142
+ | **Replacing brittle selectors** | [locators.md](core/locators.md) |
143
+ | **Removing explicit waits** | [assertions-waiting.md](core/assertions-waiting.md) |
144
+ | **Creating test data factories** | [test-data.md](core/test-data.md) |
145
+ | **Configuration setup** | [configuration.md](core/configuration.md) |
146
+
147
+ ### Infrastructure & Configuration
148
+
149
+ **When to use**: Setting up projects, configuring CI/CD, optimizing performance
150
+
151
+ | Activity | Reference Files |
152
+ | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------------ |
153
+ | **Configuring Playwright project** | [configuration.md](core/configuration.md), [projects-dependencies.md](core/projects-dependencies.md) |
154
+ | **Setting up CI/CD pipelines** | [ci-cd.md](infrastructure-ci-cd/ci-cd.md), [github-actions.md](infrastructure-ci-cd/github-actions.md) |
155
+ | **GitHub Actions setup** | [github-actions.md](infrastructure-ci-cd/github-actions.md) |
156
+ | **GitLab CI setup** | [gitlab.md](infrastructure-ci-cd/gitlab.md) |
157
+ | **Other CI providers** | [other-providers.md](infrastructure-ci-cd/other-providers.md) |
158
+ | **Docker/container setup** | [docker.md](infrastructure-ci-cd/docker.md) |
159
+ | **Global setup & teardown** | [global-setup.md](core/global-setup.md) |
160
+ | **Project dependencies** | [projects-dependencies.md](core/projects-dependencies.md) |
161
+ | **Optimizing test performance** | [performance.md](infrastructure-ci-cd/performance.md), [test-suite-structure.md](core/test-suite-structure.md) |
162
+ | **Configuring parallel execution** | [parallel-sharding.md](infrastructure-ci-cd/parallel-sharding.md), [performance.md](infrastructure-ci-cd/performance.md) |
163
+ | **Isolating test data between workers** | [fixtures-hooks.md](core/fixtures-hooks.md), [performance.md](infrastructure-ci-cd/performance.md) |
164
+ | **Test coverage** | [test-coverage.md](infrastructure-ci-cd/test-coverage.md) |
165
+ | **Test reporting/artifacts** | [reporting.md](infrastructure-ci-cd/reporting.md) |
166
+
167
+ ### Advanced Patterns
168
+
169
+ **When to use**: Complex scenarios, API mocking, network interception
170
+
171
+ | Activity | Reference Files |
172
+ | ------------------------------------ | ------------------------------------------------------------------------------------------------------------ |
173
+ | **Mocking API responses** | [test-suite-structure.md](core/test-suite-structure.md), [network-advanced.md](advanced/network-advanced.md) |
174
+ | **Network interception** | [network-advanced.md](advanced/network-advanced.md), [assertions-waiting.md](core/assertions-waiting.md) |
175
+ | **GraphQL mocking** | [network-advanced.md](advanced/network-advanced.md) |
176
+ | **HAR recording/playback** | [network-advanced.md](advanced/network-advanced.md) |
177
+ | **Custom fixtures** | [fixtures-hooks.md](core/fixtures-hooks.md) |
178
+ | **Advanced waiting strategies** | [assertions-waiting.md](core/assertions-waiting.md) |
179
+ | **OAuth/SSO mocking** | [third-party.md](advanced/third-party.md), [multi-context.md](advanced/multi-context.md) |
180
+ | **Payment gateway mocking** | [third-party.md](advanced/third-party.md) |
181
+ | **Email/SMS verification mocking** | [third-party.md](advanced/third-party.md) |
182
+ | **Failing on console errors** | [console-errors.md](debugging/console-errors.md) |
183
+ | **Security testing (XSS, CSRF)** | [security-testing.md](testing-patterns/security-testing.md) |
184
+ | **Performance budgets & Web Vitals** | [performance-testing.md](testing-patterns/performance-testing.md) |
185
+ | **Lighthouse integration** | [performance-testing.md](testing-patterns/performance-testing.md) |
186
+ | **Test annotations (skip, fixme)** | [annotations.md](core/annotations.md) |
187
+ | **Test tags (@smoke, @fast)** | [test-tags.md](core/test-tags.md) |
188
+ | **Test steps for reporting** | [annotations.md](core/annotations.md) |
189
+
190
+ ## Quick Decision Tree
191
+
192
+ ```
193
+ What are you doing?
194
+
195
+ ├─ Writing a new test?
196
+ │ ├─ E2E test → core/test-suite-structure.md, core/locators.md, core/assertions-waiting.md
197
+ │ ├─ Component test → testing-patterns/component-testing.md
198
+ │ ├─ API test → testing-patterns/api-testing.md, core/test-suite-structure.md
199
+ │ ├─ GraphQL test → testing-patterns/graphql-testing.md
200
+ │ ├─ Visual regression → testing-patterns/visual-regression.md
201
+ │ ├─ Visual/canvas test → testing-patterns/canvas-webgl.md, core/test-suite-structure.md
202
+ │ ├─ Accessibility test → testing-patterns/accessibility.md
203
+ │ ├─ Mobile/responsive test → advanced/mobile-testing.md
204
+ │ ├─ i18n/locale test → testing-patterns/i18n.md
205
+ │ ├─ Electron app test → testing-patterns/electron.md
206
+ │ ├─ Browser extension test → testing-patterns/browser-extensions.md
207
+ │ ├─ Multi-user test → advanced/multi-user.md
208
+ │ ├─ Form validation test → testing-patterns/forms-validation.md
209
+ │ └─ Drag and drop test → testing-patterns/drag-drop.md
210
+
211
+ ├─ Testing specific features?
212
+ │ ├─ File upload/download → testing-patterns/file-operations.md, testing-patterns/file-upload-download.md
213
+ │ ├─ Date/time dependent → advanced/clock-mocking.md
214
+ │ ├─ WebSocket/real-time → browser-apis/websockets.md
215
+ │ ├─ Geolocation/permissions → browser-apis/browser-apis.md
216
+ │ ├─ OAuth/SSO mocking → advanced/third-party.md, advanced/multi-context.md
217
+ │ ├─ Payments/email/SMS → advanced/third-party.md
218
+ │ ├─ iFrames → browser-apis/iframes.md
219
+ │ ├─ Canvas/WebGL/charts → testing-patterns/canvas-webgl.md
220
+ │ ├─ Service workers/PWA → browser-apis/service-workers.md
221
+ │ ├─ i18n/localization → testing-patterns/i18n.md
222
+ │ ├─ Security (XSS, CSRF) → testing-patterns/security-testing.md
223
+ │ └─ Performance/Web Vitals → testing-patterns/performance-testing.md
224
+
225
+ ├─ Architecture decisions?
226
+ │ ├─ POM vs fixtures → architecture/pom-vs-fixtures.md
227
+ │ ├─ Test type selection → architecture/test-architecture.md
228
+ │ ├─ Mock vs real services → architecture/when-to-mock.md
229
+ │ └─ Test suite structure → core/test-suite-structure.md
230
+
231
+ ├─ Framework-specific testing?
232
+ │ ├─ React app → frameworks/react.md
233
+ │ ├─ Angular app → frameworks/angular.md
234
+ │ ├─ Vue/Nuxt app → frameworks/vue.md
235
+ │ └─ Next.js app → frameworks/nextjs.md
236
+
237
+ ├─ Authentication testing?
238
+ │ ├─ Basic auth patterns → advanced/authentication.md
239
+ │ └─ Complex flows (MFA, reset) → advanced/authentication-flows.md
240
+
241
+ ├─ Test is failing/flaky?
242
+ │ ├─ Flaky test investigation → debugging/flaky-tests.md
243
+ │ ├─ Element not found → core/locators.md, debugging/debugging.md
244
+ │ ├─ Timeout issues → core/assertions-waiting.md, debugging/debugging.md
245
+ │ ├─ Race conditions → debugging/flaky-tests.md, debugging/debugging.md
246
+ │ ├─ Flaky only with multiple workers → debugging/flaky-tests.md, infrastructure-ci-cd/performance.md
247
+ │ ├─ State leak / isolation → debugging/flaky-tests.md, core/fixtures-hooks.md
248
+ │ ├─ Console/JS errors → debugging/console-errors.md, debugging/debugging.md
249
+ │ └─ General debugging → debugging/debugging.md
250
+
251
+ ├─ Testing error scenarios?
252
+ │ ├─ Network failures → debugging/error-testing.md, advanced/network-advanced.md
253
+ │ ├─ Offline (unexpected) → debugging/error-testing.md
254
+ │ ├─ Offline-first/PWA → browser-apis/service-workers.md
255
+ │ ├─ Error boundaries → debugging/error-testing.md
256
+ │ └─ Form validation → testing-patterns/forms-validation.md, debugging/error-testing.md
257
+
258
+ ├─ Refactoring existing code?
259
+ │ ├─ Implementing POM → core/page-object-model.md
260
+ │ ├─ Improving selectors → core/locators.md
261
+ │ ├─ Extracting fixtures → core/fixtures-hooks.md
262
+ │ ├─ Creating data factories → core/test-data.md
263
+ │ └─ Configuration setup → core/configuration.md
264
+
265
+ ├─ Setting up infrastructure?
266
+ │ ├─ CI/CD → infrastructure-ci-cd/ci-cd.md
267
+ │ ├─ GitHub Actions → infrastructure-ci-cd/github-actions.md
268
+ │ ├─ GitLab CI → infrastructure-ci-cd/gitlab.md
269
+ │ ├─ Other CI providers → infrastructure-ci-cd/other-providers.md
270
+ │ ├─ Docker/containers → infrastructure-ci-cd/docker.md
271
+ │ ├─ Sharding/parallel → infrastructure-ci-cd/parallel-sharding.md
272
+ │ ├─ Reporting/artifacts → infrastructure-ci-cd/reporting.md
273
+ │ ├─ Global setup/teardown → core/global-setup.md
274
+ │ ├─ Project dependencies → core/projects-dependencies.md
275
+ │ ├─ Test performance → infrastructure-ci-cd/performance.md
276
+ │ ├─ Test coverage → infrastructure-ci-cd/test-coverage.md
277
+ │ └─ Project config → core/configuration.md, core/projects-dependencies.md
278
+
279
+ ├─ Organizing tests?
280
+ │ ├─ Skip/fixme/slow tests → core/annotations.md
281
+ │ ├─ Test tags (@smoke, @fast) → core/test-tags.md
282
+ │ ├─ Filtering tests (--grep) → core/test-tags.md
283
+ │ ├─ Test steps → core/annotations.md
284
+ │ └─ Conditional execution → core/annotations.md
285
+
286
+ └─ Running subset of tests?
287
+ ├─ By tag (@smoke, @critical) → core/test-tags.md
288
+ ├─ Exclude slow/flaky tests → core/test-tags.md
289
+ ├─ PR vs nightly tests → core/test-tags.md, infrastructure-ci-cd/ci-cd.md
290
+ └─ Project-specific filtering → core/test-tags.md, core/configuration.md
291
+ ```
292
+
293
+ ## Test Validation Loop
294
+
295
+ After writing or modifying tests:
296
+
297
+ 1. **Run tests**: `npx playwright test --reporter=list`
298
+ 2. **If tests fail**:
299
+ - Review error output and trace (`npx playwright show-trace`)
300
+ - Fix locators, waits, or assertions
301
+ - Re-run tests
302
+ 3. **Only proceed when all tests pass**
303
+ 4. **Run multiple times** for critical tests: `npx playwright test --repeat-each=5`
@@ -0,0 +1,360 @@
1
+ # Complex Authentication Flow Patterns
2
+
3
+ ## Table of Contents
4
+
5
+ 1. [Email Verification Flows](#email-verification-flows)
6
+ 2. [Password Reset](#password-reset)
7
+ 3. [Session Timeout](#session-timeout)
8
+ 4. [Remember Me Persistence](#remember-me-persistence)
9
+ 5. [Logout Patterns](#logout-patterns)
10
+ 6. [Tips](#tips)
11
+ 7. [Related](#related)
12
+
13
+ > **When to use**: Testing email verification, password reset, session timeout/expiration, or remember-me functionality. For basic auth setup (storage state, OAuth mocking, MFA, role-based access), see [authentication.md](authentication.md).
14
+
15
+ ---
16
+
17
+ ## Email Verification Flows
18
+
19
+ ### Capturing Verification Tokens
20
+
21
+ Intercept API responses to capture verification tokens for testing:
22
+
23
+ ```typescript
24
+ test('completes registration with email verification', async ({ page }) => {
25
+ let capturedToken = '';
26
+
27
+ await page.route('**/api/auth/register', async (route) => {
28
+ const response = await route.fetch();
29
+ const body = await response.json();
30
+ capturedToken = body.verificationToken;
31
+ await route.fulfill({ response });
32
+ });
33
+
34
+ await page.goto('/register');
35
+ await page.getByLabel('Name').fill('New User');
36
+ await page.getByLabel('Email').fill('newuser@test.com');
37
+ await page.getByLabel('Password', { exact: true }).fill('SecurePass!');
38
+ await page.getByLabel('Confirm password').fill('SecurePass!');
39
+ await page.getByRole('button', { name: 'Create account' }).click();
40
+
41
+ await expect(page.getByText('Check your inbox')).toBeVisible();
42
+
43
+ expect(capturedToken).toBeTruthy();
44
+ await page.goto(`/verify?token=${capturedToken}`);
45
+
46
+ await expect(page.getByText('Email confirmed')).toBeVisible();
47
+ });
48
+ ```
49
+
50
+ ### Fully Mocked Verification
51
+
52
+ ```typescript
53
+ test('verifies email with mocked endpoints', async ({ page }) => {
54
+ const mockToken = 'test-verification-abc123';
55
+
56
+ await page.route('**/api/auth/register', async (route) => {
57
+ await route.fulfill({
58
+ status: 200,
59
+ contentType: 'application/json',
60
+ body: JSON.stringify({ message: 'Verification sent', verificationToken: mockToken }),
61
+ });
62
+ });
63
+
64
+ await page.route(`**/api/auth/verify?token=${mockToken}`, async (route) => {
65
+ await route.fulfill({
66
+ status: 200,
67
+ contentType: 'application/json',
68
+ body: JSON.stringify({ verified: true }),
69
+ });
70
+ });
71
+
72
+ await page.goto('/register');
73
+ await page.getByLabel('Email').fill('test@example.com');
74
+ await page.getByLabel('Password', { exact: true }).fill('Password123!');
75
+ await page.getByRole('button', { name: 'Sign up' }).click();
76
+
77
+ await expect(page.getByText('Check your inbox')).toBeVisible();
78
+
79
+ await page.goto(`/verify?token=${mockToken}`);
80
+ await expect(page.getByText('Email confirmed')).toBeVisible();
81
+ });
82
+ ```
83
+
84
+ ---
85
+
86
+ ## Password Reset
87
+
88
+ ### Complete Reset Flow
89
+
90
+ ```typescript
91
+ test('resets password through email link', async ({ page }) => {
92
+ let resetToken = '';
93
+
94
+ await page.route('**/api/auth/forgot-password', async (route) => {
95
+ const response = await route.fetch();
96
+ const body = await response.json();
97
+ resetToken = body.resetToken;
98
+ await route.fulfill({ response });
99
+ });
100
+
101
+ await page.goto('/forgot-password');
102
+ await page.getByLabel('Email').fill('user@test.com');
103
+ await page.getByRole('button', { name: 'Send link' }).click();
104
+
105
+ await expect(page.getByText('Reset email sent')).toBeVisible();
106
+
107
+ expect(resetToken).toBeTruthy();
108
+ await page.goto(`/reset-password?token=${resetToken}`);
109
+
110
+ await page.getByLabel('New password', { exact: true }).fill('NewPassword456!');
111
+ await page.getByLabel('Confirm password').fill('NewPassword456!');
112
+ await page.getByRole('button', { name: 'Update password' }).click();
113
+
114
+ await expect(page.getByText('Password updated')).toBeVisible();
115
+ });
116
+ ```
117
+
118
+ ### Expired Token Handling
119
+
120
+ ```typescript
121
+ test('shows error for expired reset token', async ({ page }) => {
122
+ await page.goto('/reset-password?token=expired-token');
123
+
124
+ await page.getByLabel('New password', { exact: true }).fill('NewPass!');
125
+ await page.getByLabel('Confirm password').fill('NewPass!');
126
+ await page.getByRole('button', { name: 'Update password' }).click();
127
+
128
+ await expect(page.getByRole('alert')).toContainText(/expired|invalid/i);
129
+ });
130
+ ```
131
+
132
+ ### Password Strength Validation
133
+
134
+ ```typescript
135
+ test('enforces password requirements on reset', async ({ page }) => {
136
+ await page.goto('/reset-password?token=valid-token');
137
+
138
+ await page.getByLabel('New password', { exact: true }).fill('weak');
139
+ await page.getByLabel('Confirm password').fill('weak');
140
+ await page.getByRole('button', { name: 'Update password' }).click();
141
+
142
+ await expect(page.getByText(/at least 8 characters/i)).toBeVisible();
143
+ });
144
+ ```
145
+
146
+ ---
147
+
148
+ ## Session Timeout
149
+
150
+ ### Detecting Expired Sessions
151
+
152
+ ```typescript
153
+ test('redirects to signin after session expires', async ({ page, context }) => {
154
+ await page.goto('/signin');
155
+ await page.getByLabel('Email').fill('user@test.com');
156
+ await page.getByLabel('Password').fill('Password!');
157
+ await page.getByRole('button', { name: 'Sign in' }).click();
158
+ await expect(page).toHaveURL('/home');
159
+
160
+ const cookies = await context.cookies();
161
+ const sessionCookie = cookies.find((c) => c.name.includes('session'));
162
+
163
+ if (sessionCookie) {
164
+ await context.clearCookies({ name: sessionCookie.name });
165
+ }
166
+
167
+ await page.goto('/profile');
168
+ await expect(page).toHaveURL(/\/signin/);
169
+ await expect(page.getByText(/session.*expired|sign in again/i)).toBeVisible();
170
+ });
171
+ ```
172
+
173
+ ### Session Extension Warning
174
+
175
+ ```typescript
176
+ test('shows warning before session expires', async ({ page }) => {
177
+ await page.route('**/api/auth/session', async (route) => {
178
+ await route.fulfill({
179
+ status: 200,
180
+ contentType: 'application/json',
181
+ body: JSON.stringify({ valid: true, expiresIn: 60 }),
182
+ });
183
+ });
184
+
185
+ await page.goto('/home');
186
+
187
+ await expect(page.getByText(/session.*expir/i)).toBeVisible({ timeout: 10000 });
188
+ await expect(page.getByRole('button', { name: /extend|stay signed in/i })).toBeVisible();
189
+ });
190
+ ```
191
+
192
+ ### Session Extension Action
193
+
194
+ ```typescript
195
+ test('extends session when user clicks extend', async ({ page }) => {
196
+ let sessionExtended = false;
197
+
198
+ await page.route('**/api/auth/session', async (route) => {
199
+ await route.fulfill({
200
+ status: 200,
201
+ contentType: 'application/json',
202
+ body: JSON.stringify({ valid: true, expiresIn: 60 }),
203
+ });
204
+ });
205
+
206
+ await page.route('**/api/auth/refresh', async (route) => {
207
+ sessionExtended = true;
208
+ await route.fulfill({
209
+ status: 200,
210
+ contentType: 'application/json',
211
+ body: JSON.stringify({ valid: true, expiresIn: 3600 }),
212
+ });
213
+ });
214
+
215
+ await page.goto('/home');
216
+
217
+ await expect(page.getByRole('button', { name: /extend|stay signed in/i })).toBeVisible({
218
+ timeout: 10000,
219
+ });
220
+ await page.getByRole('button', { name: /extend|stay signed in/i }).click();
221
+
222
+ expect(sessionExtended).toBe(true);
223
+ await expect(page.getByText(/session.*expir/i)).not.toBeVisible();
224
+ });
225
+ ```
226
+
227
+ ---
228
+
229
+ ## Remember Me Persistence
230
+
231
+ ### Persistent Session
232
+
233
+ ```typescript
234
+ test('persists session with remember me enabled', async ({ browser }) => {
235
+ const ctx1 = await browser.newContext();
236
+ const page1 = await ctx1.newPage();
237
+
238
+ await page1.goto('/signin');
239
+ await page1.getByLabel('Email').fill('user@test.com');
240
+ await page1.getByLabel('Password').fill('Password!');
241
+ await page1.getByLabel('Keep me signed in').check();
242
+ await page1.getByRole('button', { name: 'Sign in' }).click();
243
+
244
+ await expect(page1).toHaveURL('/home');
245
+
246
+ const state = await ctx1.storageState();
247
+ await ctx1.close();
248
+
249
+ const ctx2 = await browser.newContext({ storageState: state });
250
+ const page2 = await ctx2.newPage();
251
+
252
+ await page2.goto('/home');
253
+ await expect(page2).toHaveURL('/home');
254
+ await expect(page2.getByText('Welcome')).toBeVisible();
255
+
256
+ await ctx2.close();
257
+ });
258
+ ```
259
+
260
+ ### Session-Only Login
261
+
262
+ ```typescript
263
+ test('session-only login does not persist across browser restarts', async ({ browser }) => {
264
+ const ctx1 = await browser.newContext();
265
+ const page1 = await ctx1.newPage();
266
+
267
+ await page1.goto('/signin');
268
+ await page1.getByLabel('Email').fill('user@test.com');
269
+ await page1.getByLabel('Password').fill('Password!');
270
+ // Leave "Remember me" unchecked
271
+ await expect(page1.getByLabel('Keep me signed in')).not.toBeChecked();
272
+ await page1.getByRole('button', { name: 'Sign in' }).click();
273
+
274
+ await expect(page1).toHaveURL('/home');
275
+
276
+ // Only keep persistent cookies (filter out session cookies)
277
+ const cookies = await ctx1.cookies();
278
+ await ctx1.close();
279
+
280
+ const persistentCookies = cookies.filter((c) => c.expires > 0);
281
+ const ctx2 = await browser.newContext();
282
+ await ctx2.addCookies(persistentCookies);
283
+ const page2 = await ctx2.newPage();
284
+
285
+ await page2.goto('/home');
286
+
287
+ // Should redirect to login since session was not persisted
288
+ await expect(page2).toHaveURL(/\/signin/);
289
+
290
+ await ctx2.close();
291
+ });
292
+ ```
293
+
294
+ ---
295
+
296
+ ## Logout Patterns
297
+
298
+ ### Standard Logout with Session Cleanup
299
+
300
+ ```typescript
301
+ test.use({ storageState: '.auth/user.json' });
302
+
303
+ test('logs out and clears session', async ({ page, context }) => {
304
+ await page.goto('/home');
305
+
306
+ await page.getByRole('button', { name: /account|menu/i }).click();
307
+ await page.getByRole('menuitem', { name: 'Sign out' }).click();
308
+
309
+ await expect(page).toHaveURL('/signin');
310
+
311
+ const cookies = await context.cookies();
312
+ const sessionCookies = cookies.filter((c) => c.name.includes('session') || c.name.includes('token'));
313
+ expect(sessionCookies).toHaveLength(0);
314
+
315
+ await page.goto('/home');
316
+ await expect(page).toHaveURL(/\/signin/);
317
+ });
318
+ ```
319
+
320
+ ### Logout from All Devices
321
+
322
+ ```typescript
323
+ test('logs out from all devices', async ({ page }) => {
324
+ let logoutAllCalled = false;
325
+
326
+ await page.route('**/api/auth/logout-all', async (route) => {
327
+ logoutAllCalled = true;
328
+ await route.fulfill({
329
+ status: 200,
330
+ contentType: 'application/json',
331
+ body: JSON.stringify({ message: 'Logged out everywhere' }),
332
+ });
333
+ });
334
+
335
+ await page.goto('/settings/security');
336
+
337
+ await page.getByRole('button', { name: 'Sign out everywhere' }).click();
338
+ await page.getByRole('dialog').getByRole('button', { name: 'Confirm' }).click();
339
+
340
+ expect(logoutAllCalled).toBe(true);
341
+ await expect(page).toHaveURL(/\/signin/);
342
+ });
343
+ ```
344
+
345
+ ---
346
+
347
+ ## Tips
348
+
349
+ 1. **Configure shorter session timeouts in test environments** — Enables testing timeout behavior without slow tests
350
+ 2. **Test token expiration edge cases** — Expired tokens, invalid tokens, already-used tokens
351
+ 3. **Verify cleanup on logout** — Check both cookies and localStorage are cleared
352
+ 4. **Test the full flow end-to-end** — Password reset should verify login with new password works
353
+
354
+ ---
355
+
356
+ ## Related
357
+
358
+ - [authentication.md](authentication.md) — Storage state, OAuth mocking, MFA, role-based access, API login
359
+ - [fixtures-hooks.md](../core/fixtures-hooks.md) — Creating auth fixtures
360
+ - [third-party.md](./third-party.md) — Mocking external auth providers