claude-mpm 5.4.59__py3-none-any.whl → 5.4.62__py3-none-any.whl

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.

Potentially problematic release.


This version of claude-mpm might be problematic. Click here for more details.

Files changed (128) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/CLAUDE_MPM_TEACHER_OUTPUT_STYLE.md +5 -0
  3. claude_mpm/scripts/start_activity_logging.py +0 -0
  4. claude_mpm/services/agents/deployment/agent_template_builder.py +8 -0
  5. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +79 -0
  6. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +178 -0
  7. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
  8. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
  9. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
  10. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
  11. claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
  12. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +112 -0
  13. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +146 -0
  14. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
  15. claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
  16. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +81 -0
  17. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
  18. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
  19. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +152 -0
  20. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
  21. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
  22. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
  23. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
  24. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +119 -0
  25. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +148 -0
  26. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +483 -0
  27. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +452 -0
  28. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +449 -0
  29. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +411 -0
  30. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +14 -0
  31. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +58 -0
  32. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +68 -0
  33. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +69 -0
  34. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +131 -0
  35. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +325 -0
  36. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
  37. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
  38. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +499 -0
  39. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
  40. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
  41. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
  42. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
  43. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
  44. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
  45. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
  46. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
  47. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
  48. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +86 -0
  49. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +43 -0
  50. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +47 -0
  51. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +65 -0
  52. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +30 -0
  53. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +16 -0
  54. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +160 -0
  55. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
  56. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +602 -0
  57. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +915 -0
  58. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +916 -0
  59. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +752 -0
  60. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
  61. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +189 -0
  62. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
  63. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
  64. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
  65. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
  66. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
  67. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
  68. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
  69. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
  70. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
  71. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
  72. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
  73. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
  74. claude_mpm/skills/bundled/pm/pm-delegation-patterns/SKILL.md +167 -0
  75. claude_mpm/skills/bundled/pm/pm-git-file-tracking/SKILL.md +113 -0
  76. claude_mpm/skills/bundled/pm/pm-pr-workflow/SKILL.md +124 -0
  77. claude_mpm/skills/bundled/pm/pm-ticketing-integration/SKILL.md +154 -0
  78. claude_mpm/skills/bundled/pm/pm-verification-protocols/SKILL.md +198 -0
  79. claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
  80. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
  81. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
  82. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
  83. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
  84. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
  85. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
  86. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
  87. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
  88. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
  89. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
  90. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
  91. claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
  92. claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
  93. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
  94. claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
  95. claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
  96. claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
  97. claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
  98. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +119 -0
  99. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
  100. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +145 -0
  101. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +543 -0
  102. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +741 -0
  103. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +470 -0
  104. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +458 -0
  105. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +639 -0
  106. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
  107. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
  108. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
  109. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
  110. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
  111. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +140 -0
  112. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
  113. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
  114. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
  115. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
  116. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +184 -0
  117. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
  118. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
  119. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
  120. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
  121. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
  122. {claude_mpm-5.4.59.dist-info → claude_mpm-5.4.62.dist-info}/METADATA +1 -1
  123. {claude_mpm-5.4.59.dist-info → claude_mpm-5.4.62.dist-info}/RECORD +127 -10
  124. {claude_mpm-5.4.59.dist-info → claude_mpm-5.4.62.dist-info}/WHEEL +0 -0
  125. {claude_mpm-5.4.59.dist-info → claude_mpm-5.4.62.dist-info}/entry_points.txt +0 -0
  126. {claude_mpm-5.4.59.dist-info → claude_mpm-5.4.62.dist-info}/licenses/LICENSE +0 -0
  127. {claude_mpm-5.4.59.dist-info → claude_mpm-5.4.62.dist-info}/licenses/LICENSE-FAQ.md +0 -0
  128. {claude_mpm-5.4.59.dist-info → claude_mpm-5.4.62.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,868 @@
1
+ # Troubleshooting Reference
2
+
3
+ Complete guide to diagnosing and solving common webapp testing problems.
4
+
5
+ ## Table of Contents
6
+
7
+ - [Timeout Issues](#timeout-issues)
8
+ - [Selector Issues](#selector-issues)
9
+ - [Server Issues](#server-issues)
10
+ - [Network Issues](#network-issues)
11
+ - [Environment Issues](#environment-issues)
12
+ - [Playwright-Specific Issues](#playwright-specific-issues)
13
+ - [Performance Issues](#performance-issues)
14
+ - [Debugging Workflow](#debugging-workflow)
15
+
16
+ ## Timeout Issues
17
+
18
+ ### Symptom: page.goto() Timeout
19
+
20
+ **Error message:**
21
+ ```
22
+ TimeoutError: page.goto: Timeout 30000ms exceeded
23
+ ```
24
+
25
+ **Possible causes and solutions:**
26
+
27
+ **1. Server not running**
28
+ ```bash
29
+ # Check server status
30
+ lsof -i :3000 -sTCP:LISTEN
31
+
32
+ # If no output, start server
33
+ python scripts/with_server.py --server "npm start" --port 3000 -- python test.py
34
+ ```
35
+
36
+ **2. Server slow to respond**
37
+ ```bash
38
+ # Check response time
39
+ curl -w "Time: %{time_total}s\n" -o /dev/null -s http://localhost:3000
40
+
41
+ # If slow, increase timeout
42
+ page.goto('http://localhost:3000', timeout=60000) # 60 seconds
43
+ ```
44
+
45
+ **3. Network connectivity issue**
46
+ ```bash
47
+ # Test connection
48
+ curl http://localhost:3000
49
+
50
+ # Try different host format
51
+ page.goto('http://127.0.0.1:3000') # Instead of localhost
52
+ ```
53
+
54
+ **4. Port incorrect**
55
+ ```bash
56
+ # List all listening ports
57
+ lsof -i -sTCP:LISTEN
58
+
59
+ # Use correct port
60
+ page.goto('http://localhost:CORRECT_PORT')
61
+ ```
62
+
63
+ ### Symptom: wait_for_selector() Timeout
64
+
65
+ **Error message:**
66
+ ```
67
+ TimeoutError: waiting for selector "button.submit" failed: timeout 30000ms exceeded
68
+ ```
69
+
70
+ **Possible causes and solutions:**
71
+
72
+ **1. Page not fully loaded**
73
+ ```python
74
+ # ❌ BAD: Missing wait
75
+ page.goto('http://localhost:3000')
76
+ page.click('button.submit') # Fails
77
+
78
+ # ✅ GOOD: Wait for networkidle
79
+ page.goto('http://localhost:3000')
80
+ page.wait_for_load_state('networkidle')
81
+ page.click('button.submit') # Works
82
+ ```
83
+
84
+ **2. Selector doesn't match**
85
+ ```python
86
+ # Take screenshot to see actual page
87
+ page.screenshot(path='/tmp/debug.png', full_page=True)
88
+
89
+ # Inspect DOM
90
+ content = page.content()
91
+ print('button' in content.lower()) # Does 'button' exist?
92
+
93
+ # Try different selector
94
+ page.wait_for_selector('text=Submit') # Text selector
95
+ page.wait_for_selector('role=button') # Role selector
96
+ ```
97
+
98
+ **3. Element conditionally rendered**
99
+ ```python
100
+ # Check if element appears after action
101
+ page.click('text=Show Form')
102
+ page.wait_for_selector('button.submit') # Now appears
103
+
104
+ # Or check application state
105
+ page.wait_for_function('() => window.formReady === true')
106
+ page.wait_for_selector('button.submit')
107
+ ```
108
+
109
+ **4. Element in iframe**
110
+ ```python
111
+ # Regular selector won't work for iframe content
112
+ # ❌ page.wait_for_selector('.iframe-button')
113
+
114
+ # ✅ Access iframe first
115
+ frame = page.frame_locator('iframe#myframe')
116
+ frame.locator('.iframe-button').wait_for()
117
+ ```
118
+
119
+ ### Symptom: wait_for_load_state('networkidle') Never Completes
120
+
121
+ **Error message:**
122
+ ```
123
+ TimeoutError: page.wait_for_load_state: Timeout 30000ms exceeded
124
+ ```
125
+
126
+ **Possible causes and solutions:**
127
+
128
+ **1. Polling API or WebSocket**
129
+ ```python
130
+ # Page constantly makes requests, never idle
131
+ # ❌ page.wait_for_load_state('networkidle')
132
+
133
+ # ✅ Use 'load' instead
134
+ page.wait_for_load_state('load')
135
+
136
+ # Or wait for specific element
137
+ page.wait_for_selector('.content')
138
+ ```
139
+
140
+ **2. Long-running request**
141
+ ```python
142
+ # Some API call takes very long
143
+ # ✅ Wait for specific element instead
144
+ page.wait_for_selector('.data-loaded')
145
+
146
+ # Or increase timeout
147
+ page.wait_for_load_state('networkidle', timeout=60000)
148
+ ```
149
+
150
+ **3. Failed request keeps retrying**
151
+ ```python
152
+ # Check console for errors
153
+ page.on("console", lambda msg: print(f"[{msg.type}] {msg.text}"))
154
+
155
+ # Check network errors
156
+ def handle_response(response):
157
+ if response.status >= 400:
158
+ print(f"Failed: {response.url} - {response.status}")
159
+ page.on("response", handle_response)
160
+ ```
161
+
162
+ ## Selector Issues
163
+
164
+ ### Symptom: Element Not Found
165
+
166
+ **Error message:**
167
+ ```
168
+ Error: Element not found
169
+ ```
170
+
171
+ **Diagnosis and solutions:**
172
+
173
+ **1. Verify element exists in DOM**
174
+ ```python
175
+ # Get full HTML
176
+ content = page.content()
177
+
178
+ # Search for expected text/class/id
179
+ print('submit' in content.lower())
180
+ print('class="submit"' in content)
181
+ print('id="submit-button"' in content)
182
+
183
+ # Save HTML for inspection
184
+ with open('/tmp/page.html', 'w') as f:
185
+ f.write(content)
186
+ ```
187
+
188
+ **2. Try different selector strategies**
189
+ ```python
190
+ # Text selector (most readable)
191
+ page.click('text=Submit')
192
+
193
+ # Role selector (semantic)
194
+ page.click('role=button[name="Submit"]')
195
+
196
+ # CSS selector
197
+ page.click('button.submit')
198
+ page.click('#submit-button')
199
+
200
+ # Data attribute (most stable)
201
+ page.click('[data-testid="submit"]')
202
+
203
+ # XPath (last resort)
204
+ page.click('xpath=//button[contains(text(), "Submit")]')
205
+ ```
206
+
207
+ **3. Count matching elements**
208
+ ```python
209
+ # How many elements match?
210
+ elements = page.locator('button').all()
211
+ print(f"Found {len(elements)} buttons:")
212
+ for i, btn in enumerate(elements):
213
+ text = btn.inner_text() if btn.is_visible() else "[hidden]"
214
+ print(f" [{i}] {text}")
215
+
216
+ # If multiple matches, make selector more specific
217
+ page.click('form.login >> button.submit')
218
+ ```
219
+
220
+ ### Symptom: Element Not Visible
221
+
222
+ **Error message:**
223
+ ```
224
+ Error: Element is not visible
225
+ ```
226
+
227
+ **Diagnosis and solutions:**
228
+
229
+ **1. Check if element exists but hidden**
230
+ ```python
231
+ # Check visibility
232
+ element = page.locator('button.submit')
233
+ print(f"Exists: {element.count() > 0}")
234
+ print(f"Visible: {element.is_visible()}")
235
+
236
+ # Check CSS
237
+ print(f"Display: {element.evaluate('el => getComputedStyle(el).display')}")
238
+ print(f"Visibility: {element.evaluate('el => getComputedStyle(el).visibility')}")
239
+ ```
240
+
241
+ **2. Scroll element into view**
242
+ ```python
243
+ # Element might be below fold
244
+ page.locator('button.submit').scroll_into_view_if_needed()
245
+ page.click('button.submit')
246
+ ```
247
+
248
+ **3. Wait for element to become visible**
249
+ ```python
250
+ # Element may be hidden initially
251
+ page.wait_for_selector('button.submit', state='visible')
252
+ page.click('button.submit')
253
+ ```
254
+
255
+ **4. Check for overlapping elements**
256
+ ```python
257
+ # Take screenshot to see layout
258
+ page.screenshot(path='/tmp/layout.png')
259
+
260
+ # Check if modal/overlay is blocking
261
+ page.wait_for_selector('.modal', state='hidden')
262
+ page.click('button.submit')
263
+
264
+ # Or force click (bypass visibility check)
265
+ page.click('button.submit', force=True)
266
+ ```
267
+
268
+ ### Symptom: Stale Element
269
+
270
+ **Error message:**
271
+ ```
272
+ Error: Element is not attached to the DOM
273
+ ```
274
+
275
+ **Solution:**
276
+ ```python
277
+ # Don't store element references across page changes
278
+ # ❌ BAD
279
+ button = page.locator('button.submit')
280
+ page.goto('http://localhost:3000/other')
281
+ button.click() # Stale element
282
+
283
+ # ✅ GOOD
284
+ page.goto('http://localhost:3000/other')
285
+ page.locator('button.submit').click() # Query again
286
+ ```
287
+
288
+ ## Server Issues
289
+
290
+ ### Symptom: Port Already in Use
291
+
292
+ **Error message:**
293
+ ```
294
+ Error: listen EADDRINUSE: address already in use :::3000
295
+ ```
296
+
297
+ **Diagnosis and solutions:**
298
+
299
+ **1. Find process using port**
300
+ ```bash
301
+ # macOS/Linux
302
+ lsof -i :3000
303
+
304
+ # Get PID
305
+ lsof -t -i :3000
306
+ ```
307
+
308
+ **2. Kill process**
309
+ ```bash
310
+ # Graceful kill
311
+ lsof -t -i :3000 | xargs kill
312
+
313
+ # Force kill if needed
314
+ lsof -t -i :3000 | xargs kill -9
315
+ ```
316
+
317
+ **3. Use different port**
318
+ ```bash
319
+ # Node.js
320
+ PORT=3001 npm start
321
+
322
+ # Python
323
+ python manage.py runserver 3001
324
+
325
+ # Update test
326
+ page.goto('http://localhost:3001')
327
+ ```
328
+
329
+ ### Symptom: Server Crashes During Test
330
+
331
+ **Error message:**
332
+ ```
333
+ Error: Connection refused / ECONNREFUSED
334
+ ```
335
+
336
+ **Diagnosis and solutions:**
337
+
338
+ **1. Check if process still running**
339
+ ```bash
340
+ # Check by port
341
+ lsof -i :3000
342
+
343
+ # Check by process name
344
+ ps aux | grep node
345
+ ps aux | grep python
346
+ ```
347
+
348
+ **2. Check server logs**
349
+ ```bash
350
+ # If started with with_server.py, check stderr
351
+ python scripts/with_server.py --server "npm start" --port 3000 -- python test.py 2>&1 | tee full.log
352
+
353
+ # Check application log file
354
+ tail -f server.log
355
+ tail -f /tmp/server.log
356
+ ```
357
+
358
+ **3. Common crash causes**
359
+ ```python
360
+ # Memory leak
361
+ # Solution: Restart server between test suites
362
+
363
+ # Unhandled exception
364
+ # Solution: Add error handling in server code
365
+
366
+ # Database connection lost
367
+ # Solution: Implement connection pooling and retry logic
368
+
369
+ # Port conflict
370
+ # Solution: Use unique port for each test run
371
+ ```
372
+
373
+ ### Symptom: Server Won't Start
374
+
375
+ **Error message:**
376
+ ```
377
+ RuntimeError: Server failed to start on port 3000 within 30s
378
+ ```
379
+
380
+ **Diagnosis and solutions:**
381
+
382
+ **1. Check startup logs**
383
+ ```bash
384
+ # Start server manually to see errors
385
+ npm start
386
+ python manage.py runserver
387
+
388
+ # Look for:
389
+ # - Missing dependencies
390
+ # - Configuration errors
391
+ # - Permission issues
392
+ ```
393
+
394
+ **2. Increase timeout**
395
+ ```bash
396
+ # Server might be slow to start
397
+ python scripts/with_server.py --server "npm start" --port 3000 --timeout 60 -- python test.py
398
+ ```
399
+
400
+ **3. Check dependencies**
401
+ ```bash
402
+ # Node.js
403
+ npm install
404
+
405
+ # Python
406
+ pip install -r requirements.txt
407
+
408
+ # Check for peer dependency warnings
409
+ npm ls
410
+ ```
411
+
412
+ ## Network Issues
413
+
414
+ ### Symptom: CORS Error
415
+
416
+ **Error in console:**
417
+ ```
418
+ Access to fetch at 'http://localhost:4000/api' from origin 'http://localhost:3000'
419
+ has been blocked by CORS policy
420
+ ```
421
+
422
+ **Solutions:**
423
+
424
+ **1. Configure server CORS (development)**
425
+ ```javascript
426
+ // Express.js
427
+ const cors = require('cors');
428
+ app.use(cors());
429
+
430
+ // Or specific origin
431
+ app.use(cors({
432
+ origin: 'http://localhost:3000'
433
+ }));
434
+ ```
435
+
436
+ **2. Use proxy in development**
437
+ ```javascript
438
+ // package.json (Create React App)
439
+ {
440
+ "proxy": "http://localhost:4000"
441
+ }
442
+
443
+ // Now fetch('/api/data') goes to http://localhost:4000/api/data
444
+ ```
445
+
446
+ **3. Start servers on same origin (testing)**
447
+ ```bash
448
+ # Use reverse proxy or configure servers to run on same port with different paths
449
+ ```
450
+
451
+ ### Symptom: Request Timeout
452
+
453
+ **Error message:**
454
+ ```
455
+ TimeoutError: waiting for response to **/api/data
456
+ ```
457
+
458
+ **Diagnosis and solutions:**
459
+
460
+ **1. Check API server is running**
461
+ ```bash
462
+ # If using multiple servers
463
+ python scripts/with_server.py \
464
+ --server "cd backend && npm start" --port 4000 \
465
+ --server "cd frontend && npm start" --port 3000 \
466
+ -- python test.py
467
+ ```
468
+
469
+ **2. Check response time**
470
+ ```bash
471
+ curl -w "Time: %{time_total}s\n" http://localhost:4000/api/data
472
+ ```
473
+
474
+ **3. Increase timeout**
475
+ ```python
476
+ # Wait for slow API
477
+ with page.expect_response('**/api/data', timeout=60000) as response_info:
478
+ page.click('button.load')
479
+ ```
480
+
481
+ **4. Mock slow API**
482
+ ```python
483
+ # Mock API for faster tests
484
+ def handle_route(route):
485
+ route.fulfill(
486
+ status=200,
487
+ body='{"data": "mocked"}',
488
+ headers={'Content-Type': 'application/json'}
489
+ )
490
+
491
+ page.route('**/api/data', handle_route)
492
+ ```
493
+
494
+ ### Symptom: SSL/TLS Error
495
+
496
+ **Error message:**
497
+ ```
498
+ Error: certificate not trusted
499
+ ```
500
+
501
+ **Solutions:**
502
+
503
+ **1. Use HTTP for local development**
504
+ ```python
505
+ page.goto('http://localhost:3000') # Not https://
506
+ ```
507
+
508
+ **2. Ignore HTTPS errors (testing only)**
509
+ ```python
510
+ browser = p.chromium.launch(headless=True)
511
+ context = browser.new_context(ignore_https_errors=True)
512
+ page = context.new_page()
513
+ ```
514
+
515
+ ## Environment Issues
516
+
517
+ ### Symptom: Missing Environment Variables
518
+
519
+ **Error in server logs:**
520
+ ```
521
+ Error: DATABASE_URL is not defined
522
+ ```
523
+
524
+ **Solutions:**
525
+
526
+ **1. Create .env file**
527
+ ```bash
528
+ # .env
529
+ PORT=3000
530
+ NODE_ENV=development
531
+ DATABASE_URL=postgresql://localhost/mydb
532
+ API_KEY=test123
533
+ ```
534
+
535
+ **2. Load environment variables**
536
+ ```bash
537
+ # Node.js with dotenv
538
+ npm install dotenv
539
+
540
+ # In server code
541
+ require('dotenv').config();
542
+
543
+ # Python with python-dotenv
544
+ pip install python-dotenv
545
+
546
+ # In server code
547
+ from dotenv import load_dotenv
548
+ load_dotenv()
549
+ ```
550
+
551
+ **3. Set environment variables before starting**
552
+ ```bash
553
+ # Linux/macOS
554
+ export PORT=3000
555
+ npm start
556
+
557
+ # Windows
558
+ set PORT=3000
559
+ npm start
560
+
561
+ # Or inline
562
+ PORT=3000 npm start
563
+ ```
564
+
565
+ ### Symptom: Wrong Node/Python Version
566
+
567
+ **Error message:**
568
+ ```
569
+ SyntaxError: Unexpected token '??' (nullish coalescing)
570
+ ```
571
+
572
+ **Solutions:**
573
+
574
+ **1. Check version**
575
+ ```bash
576
+ node --version
577
+ python --version
578
+ ```
579
+
580
+ **2. Use correct version**
581
+ ```bash
582
+ # Node.js with nvm
583
+ nvm install 18
584
+ nvm use 18
585
+
586
+ # Python with pyenv
587
+ pyenv install 3.11
588
+ pyenv local 3.11
589
+ ```
590
+
591
+ **3. Check project requirements**
592
+ ```json
593
+ // package.json
594
+ {
595
+ "engines": {
596
+ "node": ">=18.0.0"
597
+ }
598
+ }
599
+ ```
600
+
601
+ ## Playwright-Specific Issues
602
+
603
+ ### Symptom: Browser Download Failed
604
+
605
+ **Error message:**
606
+ ```
607
+ Error: Executable doesn't exist at /path/to/browsers/chromium-xxx
608
+ ```
609
+
610
+ **Solution:**
611
+ ```bash
612
+ # Install browsers
613
+ playwright install chromium
614
+
615
+ # Or all browsers
616
+ playwright install
617
+
618
+ # With specific version
619
+ pip install playwright==1.40.0
620
+ playwright install chromium
621
+ ```
622
+
623
+ ### Symptom: Headless vs Headed Differences
624
+
625
+ **Issue:** Test passes in headless but fails in headed (or vice versa)
626
+
627
+ **Solutions:**
628
+
629
+ **1. Viewport size differences**
630
+ ```python
631
+ # Set consistent viewport
632
+ page.set_viewport_size({'width': 1920, 'height': 1080})
633
+ ```
634
+
635
+ **2. Timing differences**
636
+ ```python
637
+ # Headed mode is often slower
638
+ # Always use wait_for_load_state
639
+ page.wait_for_load_state('networkidle')
640
+ ```
641
+
642
+ **3. Debug with headed mode**
643
+ ```python
644
+ # Run in headed to see what's happening
645
+ browser = p.chromium.launch(headless=False, slow_mo=1000)
646
+ ```
647
+
648
+ ### Symptom: Element Screenshot is Blank
649
+
650
+ **Issue:** `element.screenshot()` produces blank image
651
+
652
+ **Solutions:**
653
+
654
+ **1. Wait for element to be visible**
655
+ ```python
656
+ element = page.locator('.chart')
657
+ element.wait_for()
658
+ page.wait_for_timeout(500) # Wait for rendering
659
+ element.screenshot(path='/tmp/chart.png')
660
+ ```
661
+
662
+ **2. Check element has size**
663
+ ```python
664
+ box = element.bounding_box()
665
+ print(f"Size: {box['width']}x{box['height']}")
666
+ ```
667
+
668
+ **3. Capture full page instead**
669
+ ```python
670
+ page.screenshot(path='/tmp/full.png', full_page=True)
671
+ ```
672
+
673
+ ## Performance Issues
674
+
675
+ ### Symptom: Tests Run Very Slowly
676
+
677
+ **Diagnosis and solutions:**
678
+
679
+ **1. Remove unnecessary waits**
680
+ ```python
681
+ # ❌ BAD: Fixed delays
682
+ page.click('button')
683
+ page.wait_for_timeout(5000) # Slow!
684
+
685
+ # ✅ GOOD: Wait for specific condition
686
+ page.click('button')
687
+ page.wait_for_selector('.result') # Fast
688
+ ```
689
+
690
+ **2. Use networkidle only when needed**
691
+ ```python
692
+ # For static pages or SSR
693
+ page.wait_for_load_state('load') # Faster than networkidle
694
+
695
+ # For dynamic pages with APIs
696
+ page.wait_for_load_state('networkidle') # Necessary
697
+ ```
698
+
699
+ **3. Block unnecessary resources**
700
+ ```python
701
+ # Block images, fonts, stylesheets for faster tests
702
+ page.route('**/*.{png,jpg,jpeg,gif,svg,woff,woff2,ttf,css}', lambda route: route.abort())
703
+ ```
704
+
705
+ **4. Reuse browser context**
706
+ ```python
707
+ # ❌ Slow: New browser per test
708
+ def test_1():
709
+ with sync_playwright() as p:
710
+ browser = p.chromium.launch()
711
+ # ...
712
+
713
+ # ✅ Fast: Reuse browser
714
+ @pytest.fixture(scope="session")
715
+ def browser():
716
+ with sync_playwright() as p:
717
+ browser = p.chromium.launch()
718
+ yield browser
719
+ ```
720
+
721
+ ### Symptom: High Memory Usage
722
+
723
+ **Solutions:**
724
+
725
+ **1. Close pages after use**
726
+ ```python
727
+ page = browser.new_page()
728
+ # ... test ...
729
+ page.close()
730
+ ```
731
+
732
+ **2. Clear context between tests**
733
+ ```python
734
+ @pytest.fixture
735
+ def context(browser):
736
+ context = browser.new_context()
737
+ yield context
738
+ context.close()
739
+ ```
740
+
741
+ **3. Limit parallel tests**
742
+ ```bash
743
+ # Don't run too many in parallel
744
+ pytest -n 4 # Limit to 4 workers
745
+ ```
746
+
747
+ ## Debugging Workflow
748
+
749
+ ### Step 1: Reproduce the Issue
750
+
751
+ ```python
752
+ # Create minimal reproduction script
753
+ from playwright.sync_api import sync_playwright
754
+
755
+ with sync_playwright() as p:
756
+ browser = p.chromium.launch(headless=True)
757
+ page = browser.new_page()
758
+
759
+ # Minimal steps to reproduce
760
+ page.goto('http://localhost:3000')
761
+ page.wait_for_load_state('networkidle')
762
+ page.click('button.submit') # Fails here
763
+
764
+ browser.close()
765
+ ```
766
+
767
+ ### Step 2: Gather Evidence
768
+
769
+ ```python
770
+ # Add reconnaissance
771
+ page.goto('http://localhost:3000')
772
+ page.wait_for_load_state('networkidle')
773
+
774
+ # Screenshot
775
+ page.screenshot(path='/tmp/before-click.png', full_page=True)
776
+
777
+ # Console logs
778
+ console_logs = []
779
+ page.on("console", lambda msg: console_logs.append(f"[{msg.type}] {msg.text}"))
780
+
781
+ # DOM content
782
+ with open('/tmp/dom.html', 'w') as f:
783
+ f.write(page.content())
784
+
785
+ # Try action
786
+ try:
787
+ page.click('button.submit')
788
+ except Exception as e:
789
+ print(f"Error: {e}")
790
+ page.screenshot(path='/tmp/error.png', full_page=True)
791
+
792
+ # Save console logs
793
+ with open('/tmp/console.log', 'w') as f:
794
+ f.write('\n'.join(console_logs))
795
+ ```
796
+
797
+ ### Step 3: Analyze Evidence
798
+
799
+ ```bash
800
+ # View screenshots
801
+ open /tmp/before-click.png
802
+ open /tmp/error.png
803
+
804
+ # Search DOM
805
+ grep -i "submit" /tmp/dom.html
806
+ grep -i "button" /tmp/dom.html
807
+
808
+ # Check console
809
+ cat /tmp/console.log | grep -i error
810
+ ```
811
+
812
+ ### Step 4: Form Hypothesis
813
+
814
+ Based on evidence:
815
+ - Screenshot shows page loaded correctly? → Selector issue
816
+ - Screenshot shows blank page? → Loading issue
817
+ - Screenshot shows error message? → Server issue
818
+ - Console shows errors? → JavaScript issue
819
+ - Element exists in DOM but not visible? → CSS issue
820
+
821
+ ### Step 5: Test Hypothesis
822
+
823
+ ```python
824
+ # Hypothesis: Selector is wrong
825
+ # Test: Try different selectors
826
+ page.click('text=Submit') # Try text
827
+ page.click('role=button') # Try role
828
+ page.click('#submit') # Try ID
829
+
830
+ # Hypothesis: Need to wait longer
831
+ # Test: Add explicit wait
832
+ page.wait_for_selector('button.submit', state='visible')
833
+ page.click('button.submit')
834
+
835
+ # Hypothesis: Element obscured
836
+ # Test: Force click
837
+ page.click('button.submit', force=True)
838
+ ```
839
+
840
+ ### Step 6: Verify Fix
841
+
842
+ ```python
843
+ # Once fixed, verify with full test
844
+ page.goto('http://localhost:3000')
845
+ page.wait_for_load_state('networkidle')
846
+ page.wait_for_selector('button.submit', state='visible')
847
+ page.click('button.submit')
848
+ page.wait_for_selector('.success-message')
849
+ print("✅ Test passed")
850
+ ```
851
+
852
+ ### Step 7: Prevent Regression
853
+
854
+ ```python
855
+ # Add to test suite with proper waits and assertions
856
+ def test_submit_button():
857
+ page.goto('http://localhost:3000')
858
+ page.wait_for_load_state('networkidle')
859
+
860
+ # Verify button exists and is clickable
861
+ submit_btn = page.locator('button.submit')
862
+ expect(submit_btn).to_be_visible()
863
+ expect(submit_btn).to_be_enabled()
864
+
865
+ # Click and verify result
866
+ submit_btn.click()
867
+ expect(page.locator('.success-message')).to_be_visible()
868
+ ```