aidevops 2.52.1

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 (329) hide show
  1. package/.agent/AGENTS.md +614 -0
  2. package/.agent/accounts.md +65 -0
  3. package/.agent/aidevops/add-new-mcp-to-aidevops.md +456 -0
  4. package/.agent/aidevops/api-integrations.md +335 -0
  5. package/.agent/aidevops/architecture.md +510 -0
  6. package/.agent/aidevops/configs.md +274 -0
  7. package/.agent/aidevops/docs.md +244 -0
  8. package/.agent/aidevops/extension.md +311 -0
  9. package/.agent/aidevops/mcp-integrations.md +340 -0
  10. package/.agent/aidevops/mcp-troubleshooting.md +162 -0
  11. package/.agent/aidevops/memory-patterns.md +172 -0
  12. package/.agent/aidevops/providers.md +217 -0
  13. package/.agent/aidevops/recommendations.md +321 -0
  14. package/.agent/aidevops/requirements.md +301 -0
  15. package/.agent/aidevops/resources.md +214 -0
  16. package/.agent/aidevops/security-requirements.md +174 -0
  17. package/.agent/aidevops/security.md +350 -0
  18. package/.agent/aidevops/service-links.md +400 -0
  19. package/.agent/aidevops/services.md +357 -0
  20. package/.agent/aidevops/setup.md +153 -0
  21. package/.agent/aidevops/troubleshooting.md +389 -0
  22. package/.agent/aidevops.md +124 -0
  23. package/.agent/build-plus.md +244 -0
  24. package/.agent/content/guidelines.md +109 -0
  25. package/.agent/content.md +87 -0
  26. package/.agent/health.md +59 -0
  27. package/.agent/legal.md +59 -0
  28. package/.agent/loop-state/full-loop.local.md +16 -0
  29. package/.agent/loop-state/ralph-loop.local.md +10 -0
  30. package/.agent/marketing.md +440 -0
  31. package/.agent/memory/README.md +260 -0
  32. package/.agent/onboarding.md +796 -0
  33. package/.agent/plan-plus.md +245 -0
  34. package/.agent/research.md +100 -0
  35. package/.agent/sales.md +333 -0
  36. package/.agent/scripts/101domains-helper.sh +701 -0
  37. package/.agent/scripts/add-missing-returns.sh +140 -0
  38. package/.agent/scripts/agent-browser-helper.sh +311 -0
  39. package/.agent/scripts/agno-setup.sh +712 -0
  40. package/.agent/scripts/ahrefs-mcp-wrapper.js +168 -0
  41. package/.agent/scripts/aidevops-update-check.sh +71 -0
  42. package/.agent/scripts/ampcode-cli.sh +522 -0
  43. package/.agent/scripts/auto-version-bump.sh +156 -0
  44. package/.agent/scripts/autogen-helper.sh +512 -0
  45. package/.agent/scripts/beads-sync-helper.sh +596 -0
  46. package/.agent/scripts/closte-helper.sh +5 -0
  47. package/.agent/scripts/cloudron-helper.sh +321 -0
  48. package/.agent/scripts/codacy-cli-chunked.sh +581 -0
  49. package/.agent/scripts/codacy-cli.sh +442 -0
  50. package/.agent/scripts/code-audit-helper.sh +5 -0
  51. package/.agent/scripts/coderabbit-cli.sh +417 -0
  52. package/.agent/scripts/coderabbit-pro-analysis.sh +238 -0
  53. package/.agent/scripts/commands/code-simplifier.md +86 -0
  54. package/.agent/scripts/commands/full-loop.md +246 -0
  55. package/.agent/scripts/commands/postflight-loop.md +103 -0
  56. package/.agent/scripts/commands/recall.md +182 -0
  57. package/.agent/scripts/commands/remember.md +132 -0
  58. package/.agent/scripts/commands/save-todo.md +175 -0
  59. package/.agent/scripts/commands/session-review.md +154 -0
  60. package/.agent/scripts/comprehensive-quality-fix.sh +106 -0
  61. package/.agent/scripts/context-builder-helper.sh +522 -0
  62. package/.agent/scripts/coolify-cli-helper.sh +674 -0
  63. package/.agent/scripts/coolify-helper.sh +380 -0
  64. package/.agent/scripts/crawl4ai-examples.sh +401 -0
  65. package/.agent/scripts/crawl4ai-helper.sh +1078 -0
  66. package/.agent/scripts/crewai-helper.sh +681 -0
  67. package/.agent/scripts/dev-browser-helper.sh +513 -0
  68. package/.agent/scripts/dns-helper.sh +396 -0
  69. package/.agent/scripts/domain-research-helper.sh +917 -0
  70. package/.agent/scripts/dspy-helper.sh +285 -0
  71. package/.agent/scripts/dspyground-helper.sh +291 -0
  72. package/.agent/scripts/eeat-score-helper.sh +1242 -0
  73. package/.agent/scripts/efficient-return-fix.sh +92 -0
  74. package/.agent/scripts/extract-opencode-prompts.sh +128 -0
  75. package/.agent/scripts/find-missing-returns.sh +113 -0
  76. package/.agent/scripts/fix-auth-headers.sh +104 -0
  77. package/.agent/scripts/fix-common-strings.sh +254 -0
  78. package/.agent/scripts/fix-content-type.sh +100 -0
  79. package/.agent/scripts/fix-error-messages.sh +130 -0
  80. package/.agent/scripts/fix-misplaced-returns.sh +74 -0
  81. package/.agent/scripts/fix-remaining-literals.sh +152 -0
  82. package/.agent/scripts/fix-return-statements.sh +41 -0
  83. package/.agent/scripts/fix-s131-default-cases.sh +249 -0
  84. package/.agent/scripts/fix-sc2155-simple.sh +102 -0
  85. package/.agent/scripts/fix-shellcheck-critical.sh +187 -0
  86. package/.agent/scripts/fix-string-literals.sh +273 -0
  87. package/.agent/scripts/full-loop-helper.sh +773 -0
  88. package/.agent/scripts/generate-opencode-agents.sh +497 -0
  89. package/.agent/scripts/generate-opencode-commands.sh +1629 -0
  90. package/.agent/scripts/generate-skills.sh +366 -0
  91. package/.agent/scripts/git-platforms-helper.sh +640 -0
  92. package/.agent/scripts/gitea-cli-helper.sh +743 -0
  93. package/.agent/scripts/github-cli-helper.sh +702 -0
  94. package/.agent/scripts/gitlab-cli-helper.sh +682 -0
  95. package/.agent/scripts/gsc-add-user-helper.sh +325 -0
  96. package/.agent/scripts/gsc-sitemap-helper.sh +678 -0
  97. package/.agent/scripts/hetzner-helper.sh +485 -0
  98. package/.agent/scripts/hostinger-helper.sh +229 -0
  99. package/.agent/scripts/keyword-research-helper.sh +1815 -0
  100. package/.agent/scripts/langflow-helper.sh +544 -0
  101. package/.agent/scripts/linkedin-automation.py +241 -0
  102. package/.agent/scripts/linter-manager.sh +599 -0
  103. package/.agent/scripts/linters-local.sh +434 -0
  104. package/.agent/scripts/list-keys-helper.sh +488 -0
  105. package/.agent/scripts/local-browser-automation.py +339 -0
  106. package/.agent/scripts/localhost-helper.sh +744 -0
  107. package/.agent/scripts/loop-common.sh +806 -0
  108. package/.agent/scripts/mainwp-helper.sh +728 -0
  109. package/.agent/scripts/markdown-formatter.sh +338 -0
  110. package/.agent/scripts/markdown-lint-fix.sh +311 -0
  111. package/.agent/scripts/mass-fix-returns.sh +58 -0
  112. package/.agent/scripts/mcp-diagnose.sh +167 -0
  113. package/.agent/scripts/mcp-inspector-helper.sh +449 -0
  114. package/.agent/scripts/memory-helper.sh +650 -0
  115. package/.agent/scripts/monitor-code-review.sh +255 -0
  116. package/.agent/scripts/onboarding-helper.sh +706 -0
  117. package/.agent/scripts/opencode-github-setup-helper.sh +797 -0
  118. package/.agent/scripts/opencode-test-helper.sh +213 -0
  119. package/.agent/scripts/pagespeed-helper.sh +464 -0
  120. package/.agent/scripts/pandoc-helper.sh +362 -0
  121. package/.agent/scripts/postflight-check.sh +555 -0
  122. package/.agent/scripts/pre-commit-hook.sh +259 -0
  123. package/.agent/scripts/pre-edit-check.sh +169 -0
  124. package/.agent/scripts/qlty-cli.sh +356 -0
  125. package/.agent/scripts/quality-cli-manager.sh +525 -0
  126. package/.agent/scripts/quality-feedback-helper.sh +462 -0
  127. package/.agent/scripts/quality-fix.sh +263 -0
  128. package/.agent/scripts/quality-loop-helper.sh +1108 -0
  129. package/.agent/scripts/ralph-loop-helper.sh +836 -0
  130. package/.agent/scripts/ralph-upstream-check.sh +341 -0
  131. package/.agent/scripts/secretlint-helper.sh +847 -0
  132. package/.agent/scripts/servers-helper.sh +241 -0
  133. package/.agent/scripts/ses-helper.sh +619 -0
  134. package/.agent/scripts/session-review-helper.sh +404 -0
  135. package/.agent/scripts/setup-linters-wizard.sh +379 -0
  136. package/.agent/scripts/setup-local-api-keys.sh +330 -0
  137. package/.agent/scripts/setup-mcp-integrations.sh +472 -0
  138. package/.agent/scripts/shared-constants.sh +246 -0
  139. package/.agent/scripts/site-crawler-helper.sh +1487 -0
  140. package/.agent/scripts/snyk-helper.sh +940 -0
  141. package/.agent/scripts/sonarcloud-autofix.sh +193 -0
  142. package/.agent/scripts/sonarcloud-cli.sh +191 -0
  143. package/.agent/scripts/sonarscanner-cli.sh +455 -0
  144. package/.agent/scripts/spaceship-helper.sh +747 -0
  145. package/.agent/scripts/stagehand-helper.sh +321 -0
  146. package/.agent/scripts/stagehand-python-helper.sh +321 -0
  147. package/.agent/scripts/stagehand-python-setup.sh +441 -0
  148. package/.agent/scripts/stagehand-setup.sh +439 -0
  149. package/.agent/scripts/system-cleanup.sh +340 -0
  150. package/.agent/scripts/terminal-title-helper.sh +388 -0
  151. package/.agent/scripts/terminal-title-setup.sh +549 -0
  152. package/.agent/scripts/test-stagehand-both-integration.sh +317 -0
  153. package/.agent/scripts/test-stagehand-integration.sh +309 -0
  154. package/.agent/scripts/test-stagehand-python-integration.sh +341 -0
  155. package/.agent/scripts/todo-ready.sh +263 -0
  156. package/.agent/scripts/tool-version-check.sh +362 -0
  157. package/.agent/scripts/toon-helper.sh +469 -0
  158. package/.agent/scripts/twilio-helper.sh +917 -0
  159. package/.agent/scripts/updown-helper.sh +279 -0
  160. package/.agent/scripts/validate-mcp-integrations.sh +250 -0
  161. package/.agent/scripts/validate-version-consistency.sh +131 -0
  162. package/.agent/scripts/vaultwarden-helper.sh +597 -0
  163. package/.agent/scripts/vercel-cli-helper.sh +816 -0
  164. package/.agent/scripts/verify-mirrors.sh +169 -0
  165. package/.agent/scripts/version-manager.sh +831 -0
  166. package/.agent/scripts/webhosting-helper.sh +471 -0
  167. package/.agent/scripts/webhosting-verify.sh +238 -0
  168. package/.agent/scripts/wordpress-mcp-helper.sh +508 -0
  169. package/.agent/scripts/worktree-helper.sh +595 -0
  170. package/.agent/scripts/worktree-sessions.sh +577 -0
  171. package/.agent/seo/dataforseo.md +215 -0
  172. package/.agent/seo/domain-research.md +532 -0
  173. package/.agent/seo/eeat-score.md +659 -0
  174. package/.agent/seo/google-search-console.md +366 -0
  175. package/.agent/seo/gsc-sitemaps.md +282 -0
  176. package/.agent/seo/keyword-research.md +521 -0
  177. package/.agent/seo/serper.md +278 -0
  178. package/.agent/seo/site-crawler.md +387 -0
  179. package/.agent/seo.md +236 -0
  180. package/.agent/services/accounting/quickfile.md +159 -0
  181. package/.agent/services/communications/telfon.md +470 -0
  182. package/.agent/services/communications/twilio.md +569 -0
  183. package/.agent/services/crm/fluentcrm.md +449 -0
  184. package/.agent/services/email/ses.md +399 -0
  185. package/.agent/services/hosting/101domains.md +378 -0
  186. package/.agent/services/hosting/closte.md +177 -0
  187. package/.agent/services/hosting/cloudflare.md +251 -0
  188. package/.agent/services/hosting/cloudron.md +478 -0
  189. package/.agent/services/hosting/dns-providers.md +335 -0
  190. package/.agent/services/hosting/domain-purchasing.md +344 -0
  191. package/.agent/services/hosting/hetzner.md +327 -0
  192. package/.agent/services/hosting/hostinger.md +287 -0
  193. package/.agent/services/hosting/localhost.md +419 -0
  194. package/.agent/services/hosting/spaceship.md +353 -0
  195. package/.agent/services/hosting/webhosting.md +330 -0
  196. package/.agent/social-media.md +69 -0
  197. package/.agent/templates/plans-template.md +114 -0
  198. package/.agent/templates/prd-template.md +129 -0
  199. package/.agent/templates/tasks-template.md +108 -0
  200. package/.agent/templates/todo-template.md +89 -0
  201. package/.agent/tools/ai-assistants/agno.md +471 -0
  202. package/.agent/tools/ai-assistants/capsolver.md +326 -0
  203. package/.agent/tools/ai-assistants/configuration.md +221 -0
  204. package/.agent/tools/ai-assistants/overview.md +209 -0
  205. package/.agent/tools/ai-assistants/status.md +171 -0
  206. package/.agent/tools/ai-assistants/windsurf.md +193 -0
  207. package/.agent/tools/ai-orchestration/autogen.md +406 -0
  208. package/.agent/tools/ai-orchestration/crewai.md +445 -0
  209. package/.agent/tools/ai-orchestration/langflow.md +405 -0
  210. package/.agent/tools/ai-orchestration/openprose.md +487 -0
  211. package/.agent/tools/ai-orchestration/overview.md +362 -0
  212. package/.agent/tools/ai-orchestration/packaging.md +647 -0
  213. package/.agent/tools/browser/agent-browser.md +464 -0
  214. package/.agent/tools/browser/browser-automation.md +400 -0
  215. package/.agent/tools/browser/chrome-devtools.md +282 -0
  216. package/.agent/tools/browser/crawl4ai-integration.md +422 -0
  217. package/.agent/tools/browser/crawl4ai-resources.md +277 -0
  218. package/.agent/tools/browser/crawl4ai-usage.md +416 -0
  219. package/.agent/tools/browser/crawl4ai.md +585 -0
  220. package/.agent/tools/browser/dev-browser.md +341 -0
  221. package/.agent/tools/browser/pagespeed.md +260 -0
  222. package/.agent/tools/browser/playwright.md +266 -0
  223. package/.agent/tools/browser/playwriter.md +310 -0
  224. package/.agent/tools/browser/stagehand-examples.md +456 -0
  225. package/.agent/tools/browser/stagehand-python.md +483 -0
  226. package/.agent/tools/browser/stagehand.md +421 -0
  227. package/.agent/tools/build-agent/agent-review.md +224 -0
  228. package/.agent/tools/build-agent/build-agent.md +784 -0
  229. package/.agent/tools/build-mcp/aidevops-plugin.md +476 -0
  230. package/.agent/tools/build-mcp/api-wrapper.md +445 -0
  231. package/.agent/tools/build-mcp/build-mcp.md +240 -0
  232. package/.agent/tools/build-mcp/deployment.md +401 -0
  233. package/.agent/tools/build-mcp/server-patterns.md +632 -0
  234. package/.agent/tools/build-mcp/transports.md +366 -0
  235. package/.agent/tools/code-review/auditing.md +383 -0
  236. package/.agent/tools/code-review/automation.md +219 -0
  237. package/.agent/tools/code-review/best-practices.md +203 -0
  238. package/.agent/tools/code-review/codacy.md +151 -0
  239. package/.agent/tools/code-review/code-simplifier.md +174 -0
  240. package/.agent/tools/code-review/code-standards.md +309 -0
  241. package/.agent/tools/code-review/coderabbit.md +101 -0
  242. package/.agent/tools/code-review/management.md +155 -0
  243. package/.agent/tools/code-review/qlty.md +248 -0
  244. package/.agent/tools/code-review/secretlint.md +565 -0
  245. package/.agent/tools/code-review/setup.md +250 -0
  246. package/.agent/tools/code-review/snyk.md +563 -0
  247. package/.agent/tools/code-review/tools.md +230 -0
  248. package/.agent/tools/content/summarize.md +353 -0
  249. package/.agent/tools/context/augment-context-engine.md +468 -0
  250. package/.agent/tools/context/context-builder-agent.md +76 -0
  251. package/.agent/tools/context/context-builder.md +375 -0
  252. package/.agent/tools/context/context7.md +371 -0
  253. package/.agent/tools/context/dspy.md +302 -0
  254. package/.agent/tools/context/dspyground.md +374 -0
  255. package/.agent/tools/context/llm-tldr.md +219 -0
  256. package/.agent/tools/context/osgrep.md +488 -0
  257. package/.agent/tools/context/prompt-optimization.md +338 -0
  258. package/.agent/tools/context/toon.md +292 -0
  259. package/.agent/tools/conversion/pandoc.md +304 -0
  260. package/.agent/tools/credentials/api-key-management.md +154 -0
  261. package/.agent/tools/credentials/api-key-setup.md +224 -0
  262. package/.agent/tools/credentials/environment-variables.md +180 -0
  263. package/.agent/tools/credentials/vaultwarden.md +382 -0
  264. package/.agent/tools/data-extraction/outscraper.md +974 -0
  265. package/.agent/tools/deployment/coolify-cli.md +388 -0
  266. package/.agent/tools/deployment/coolify-setup.md +353 -0
  267. package/.agent/tools/deployment/coolify.md +345 -0
  268. package/.agent/tools/deployment/vercel.md +390 -0
  269. package/.agent/tools/git/authentication.md +132 -0
  270. package/.agent/tools/git/gitea-cli.md +193 -0
  271. package/.agent/tools/git/github-actions.md +207 -0
  272. package/.agent/tools/git/github-cli.md +223 -0
  273. package/.agent/tools/git/gitlab-cli.md +190 -0
  274. package/.agent/tools/git/opencode-github-security.md +350 -0
  275. package/.agent/tools/git/opencode-github.md +328 -0
  276. package/.agent/tools/git/opencode-gitlab.md +252 -0
  277. package/.agent/tools/git/security.md +196 -0
  278. package/.agent/tools/git.md +207 -0
  279. package/.agent/tools/opencode/oh-my-opencode.md +375 -0
  280. package/.agent/tools/opencode/opencode-anthropic-auth.md +446 -0
  281. package/.agent/tools/opencode/opencode.md +651 -0
  282. package/.agent/tools/social-media/bird.md +437 -0
  283. package/.agent/tools/task-management/beads.md +336 -0
  284. package/.agent/tools/terminal/terminal-title.md +251 -0
  285. package/.agent/tools/ui/shadcn.md +196 -0
  286. package/.agent/tools/ui/ui-skills.md +115 -0
  287. package/.agent/tools/wordpress/localwp.md +311 -0
  288. package/.agent/tools/wordpress/mainwp.md +391 -0
  289. package/.agent/tools/wordpress/scf.md +527 -0
  290. package/.agent/tools/wordpress/wp-admin.md +729 -0
  291. package/.agent/tools/wordpress/wp-dev.md +940 -0
  292. package/.agent/tools/wordpress/wp-preferred.md +398 -0
  293. package/.agent/tools/wordpress.md +95 -0
  294. package/.agent/workflows/branch/bugfix.md +63 -0
  295. package/.agent/workflows/branch/chore.md +95 -0
  296. package/.agent/workflows/branch/experiment.md +115 -0
  297. package/.agent/workflows/branch/feature.md +59 -0
  298. package/.agent/workflows/branch/hotfix.md +98 -0
  299. package/.agent/workflows/branch/refactor.md +92 -0
  300. package/.agent/workflows/branch/release.md +96 -0
  301. package/.agent/workflows/branch.md +347 -0
  302. package/.agent/workflows/bug-fixing.md +267 -0
  303. package/.agent/workflows/changelog.md +129 -0
  304. package/.agent/workflows/code-audit-remote.md +279 -0
  305. package/.agent/workflows/conversation-starter.md +69 -0
  306. package/.agent/workflows/error-feedback.md +578 -0
  307. package/.agent/workflows/feature-development.md +355 -0
  308. package/.agent/workflows/git-workflow.md +702 -0
  309. package/.agent/workflows/multi-repo-workspace.md +268 -0
  310. package/.agent/workflows/plans.md +709 -0
  311. package/.agent/workflows/postflight.md +604 -0
  312. package/.agent/workflows/pr.md +571 -0
  313. package/.agent/workflows/preflight.md +278 -0
  314. package/.agent/workflows/ralph-loop.md +773 -0
  315. package/.agent/workflows/release.md +498 -0
  316. package/.agent/workflows/session-manager.md +254 -0
  317. package/.agent/workflows/session-review.md +311 -0
  318. package/.agent/workflows/sql-migrations.md +631 -0
  319. package/.agent/workflows/version-bump.md +283 -0
  320. package/.agent/workflows/wiki-update.md +333 -0
  321. package/.agent/workflows/worktree.md +477 -0
  322. package/LICENSE +21 -0
  323. package/README.md +1446 -0
  324. package/VERSION +1 -0
  325. package/aidevops.sh +1746 -0
  326. package/bin/aidevops +21 -0
  327. package/package.json +75 -0
  328. package/scripts/npm-postinstall.js +60 -0
  329. package/setup.sh +2366 -0
@@ -0,0 +1,266 @@
1
+ ---
2
+ description: Cross-browser testing automation with Playwright MCP
3
+ mode: subagent
4
+ tools:
5
+ read: true
6
+ write: false
7
+ edit: false
8
+ bash: true
9
+ glob: true
10
+ grep: true
11
+ webfetch: true
12
+ task: true
13
+ ---
14
+
15
+ # Playwright MCP Usage Examples
16
+
17
+ <!-- AI-CONTEXT-START -->
18
+
19
+ ## Quick Reference
20
+
21
+ - Playwright examples for cross-browser testing automation
22
+ - Browsers: chromium, firefox, webkit
23
+ - Test types:
24
+ - Cross-browser: `runTest()`, `testBrowserFeatures()`
25
+ - User flows: `automateFlow()`, `testFormValidation()`
26
+ - Mobile: `testOnDevice()`, `testOrientations()`
27
+ - Performance: `measurePerformance()`, `testWithNetwork()`
28
+ - Visual: `visualRegressionSuite()`, `screenshotComponents()`
29
+ - Security: `testXSS()`, `testAuthentication()`
30
+ - API: `testAPIIntegration()`, `testRealTimeFeatures()`
31
+ - Device emulation: iPhone, Samsung, iPad
32
+ - Network throttling: Fast 3G, Slow 3G, Offline
33
+ - Integration: Works with Chrome DevTools MCP
34
+ <!-- AI-CONTEXT-END -->
35
+
36
+ ## Cross-Browser Testing
37
+
38
+ ### **Multi-Browser Test Suite**
39
+
40
+ ```javascript
41
+ // Test across different browsers
42
+ const browsers = ['chromium', 'firefox', 'webkit'];
43
+
44
+ for (const browserName of browsers) {
45
+ await playwright.runTest({
46
+ browser: browserName,
47
+ url: "https://your-website.com",
48
+ test: "login-flow"
49
+ });
50
+ }
51
+ ```
52
+
53
+ ### **Browser-Specific Feature Testing**
54
+
55
+ ```javascript
56
+ // Test browser-specific features
57
+ await playwright.testBrowserFeatures({
58
+ url: "https://your-website.com",
59
+ features: ["webgl", "webrtc", "geolocation", "notifications"],
60
+ browsers: ["chromium", "firefox", "webkit"]
61
+ });
62
+ ```
63
+
64
+ ## 🔄 **Automated User Flows**
65
+
66
+ ### **E-commerce Checkout Flow**
67
+
68
+ ```javascript
69
+ // Automate complete checkout process
70
+ await playwright.automateFlow({
71
+ url: "https://your-ecommerce.com",
72
+ steps: [
73
+ { action: "click", selector: ".product-card:first-child" },
74
+ { action: "click", selector: ".add-to-cart" },
75
+ { action: "click", selector: ".cart-icon" },
76
+ { action: "fill", selector: "#email", value: "test@example.com" },
77
+ { action: "fill", selector: "#password", value: "testpass123" },
78
+ { action: "click", selector: ".checkout-button" }
79
+ ]
80
+ });
81
+ ```
82
+
83
+ ### **Form Validation Testing**
84
+
85
+ ```javascript
86
+ // Test form validation scenarios
87
+ await playwright.testFormValidation({
88
+ url: "https://your-website.com/contact",
89
+ form: "#contact-form",
90
+ scenarios: [
91
+ { field: "email", value: "invalid-email", expectError: true },
92
+ { field: "phone", value: "123", expectError: true },
93
+ { field: "message", value: "", expectError: true }
94
+ ]
95
+ });
96
+ ```
97
+
98
+ ## 📱 **Mobile & Responsive Testing**
99
+
100
+ ### **Device-Specific Testing**
101
+
102
+ ```javascript
103
+ // Test on various mobile devices
104
+ const devices = [
105
+ 'iPhone 12',
106
+ 'iPhone 12 Pro Max',
107
+ 'Samsung Galaxy S21',
108
+ 'iPad Pro'
109
+ ];
110
+
111
+ for (const device of devices) {
112
+ await playwright.testOnDevice({
113
+ device: device,
114
+ url: "https://your-website.com",
115
+ tests: ["navigation", "forms", "media-queries"]
116
+ });
117
+ }
118
+ ```
119
+
120
+ ### **Orientation Testing**
121
+
122
+ ```javascript
123
+ // Test portrait and landscape orientations
124
+ await playwright.testOrientations({
125
+ url: "https://your-website.com",
126
+ device: "iPhone 12",
127
+ orientations: ["portrait", "landscape"],
128
+ captureScreenshots: true
129
+ });
130
+ ```
131
+
132
+ ## 🎯 **Performance Testing**
133
+
134
+ ### **Load Time Analysis**
135
+
136
+ ```javascript
137
+ // Measure page load performance
138
+ await playwright.measurePerformance({
139
+ url: "https://your-website.com",
140
+ metrics: [
141
+ "domContentLoaded",
142
+ "load",
143
+ "firstContentfulPaint",
144
+ "largestContentfulPaint"
145
+ ],
146
+ iterations: 5
147
+ });
148
+ ```
149
+
150
+ ### **Network Throttling Tests**
151
+
152
+ ```javascript
153
+ // Test under different network conditions
154
+ const networkConditions = [
155
+ { name: "Fast 3G", downloadThroughput: 1.5 * 1024 * 1024 / 8 },
156
+ { name: "Slow 3G", downloadThroughput: 500 * 1024 / 8 },
157
+ { name: "Offline", offline: true }
158
+ ];
159
+
160
+ for (const condition of networkConditions) {
161
+ await playwright.testWithNetwork({
162
+ url: "https://your-website.com",
163
+ networkCondition: condition,
164
+ timeout: 30000
165
+ });
166
+ }
167
+ ```
168
+
169
+ ## 🔍 **Visual Testing & Screenshots**
170
+
171
+ ### **Visual Regression Suite**
172
+
173
+ ```javascript
174
+ // Comprehensive visual regression testing
175
+ await playwright.visualRegressionSuite({
176
+ baseUrl: "https://your-website.com",
177
+ pages: ["/", "/about", "/products", "/contact"],
178
+ viewports: [
179
+ { width: 1920, height: 1080 },
180
+ { width: 1366, height: 768 },
181
+ { width: 375, height: 667 }
182
+ ],
183
+ threshold: 0.2
184
+ });
185
+ ```
186
+
187
+ ### **Component Screenshot Testing**
188
+
189
+ ```javascript
190
+ // Test individual components
191
+ await playwright.screenshotComponents({
192
+ url: "https://your-website.com",
193
+ components: [
194
+ { selector: ".header", name: "header" },
195
+ { selector: ".navigation", name: "nav" },
196
+ { selector: ".hero-section", name: "hero" },
197
+ { selector: ".footer", name: "footer" }
198
+ ]
199
+ });
200
+ ```
201
+
202
+ ## 🛡️ **Security Testing**
203
+
204
+ ### **XSS Vulnerability Testing**
205
+
206
+ ```javascript
207
+ // Test for XSS vulnerabilities
208
+ await playwright.testXSS({
209
+ url: "https://your-website.com",
210
+ forms: ["#search-form", "#contact-form", "#login-form"],
211
+ payloads: [
212
+ "<script>alert('XSS')</script>",
213
+ "javascript:alert('XSS')",
214
+ "<img src=x onerror=alert('XSS')>"
215
+ ]
216
+ });
217
+ ```
218
+
219
+ ### **Authentication Testing**
220
+
221
+ ```javascript
222
+ // Test authentication flows
223
+ await playwright.testAuthentication({
224
+ loginUrl: "https://your-website.com/login",
225
+ credentials: {
226
+ valid: { username: "testuser", password: "testpass" },
227
+ invalid: { username: "invalid", password: "wrong" }
228
+ },
229
+ protectedUrls: ["/dashboard", "/profile", "/settings"]
230
+ });
231
+ ```
232
+
233
+ ## 📊 **API Testing Integration**
234
+
235
+ ### **API Response Validation**
236
+
237
+ ```javascript
238
+ // Test API endpoints through UI interactions
239
+ await playwright.testAPIIntegration({
240
+ url: "https://your-website.com",
241
+ interactions: [
242
+ {
243
+ action: "click",
244
+ selector: ".load-more",
245
+ expectAPI: {
246
+ url: "/api/posts",
247
+ method: "GET",
248
+ status: 200
249
+ }
250
+ }
251
+ ]
252
+ });
253
+ ```
254
+
255
+ ### **Real-time Data Testing**
256
+
257
+ ```javascript
258
+ // Test real-time features
259
+ await playwright.testRealTimeFeatures({
260
+ url: "https://your-chat-app.com",
261
+ scenarios: [
262
+ { action: "sendMessage", text: "Hello World" },
263
+ { action: "expectMessage", text: "Hello World", timeout: 5000 }
264
+ ]
265
+ });
266
+ ```
@@ -0,0 +1,310 @@
1
+ ---
2
+ description: Playwriter MCP - browser automation via Chrome extension with full Playwright API
3
+ mode: subagent
4
+ tools:
5
+ read: true
6
+ write: false
7
+ edit: false
8
+ bash: true
9
+ glob: true
10
+ grep: true
11
+ webfetch: true
12
+ task: true
13
+ ---
14
+
15
+ # Playwriter - Browser Extension MCP
16
+
17
+ <!-- AI-CONTEXT-START -->
18
+
19
+ ## Quick Reference
20
+
21
+ - **Purpose**: Browser automation via Chrome extension with full Playwright API
22
+ - **Install Extension**: [Chrome Web Store](https://chromewebstore.google.com/detail/playwriter-mcp/jfeammnjpkecdekppnclgkkffahnhfhe)
23
+ - **MCP**: `npx playwriter@latest`
24
+ - **Single Tool**: `execute` - runs Playwright code snippets
25
+
26
+ **Key Advantages**:
27
+ - **1 tool vs 17+** - Less context bloat than BrowserMCP/Antigravity
28
+ - **Full Playwright API** - LLMs already know it from training
29
+ - **Your existing browser** - Reuse extensions, sessions, cookies
30
+ - **Bypass detection** - Disconnect extension to bypass automation detection
31
+ - **Collaborate with AI** - Work alongside it in the same browser
32
+
33
+ **Icon States**:
34
+ - Gray: Not connected
35
+ - Green: Connected and ready
36
+ - Orange (...): Connecting
37
+ - Red (!): Error
38
+
39
+ <!-- AI-CONTEXT-END -->
40
+
41
+ ## Installation
42
+
43
+ ### 1. Install Chrome Extension
44
+
45
+ Install from [Chrome Web Store](https://chromewebstore.google.com/detail/playwriter-mcp/jfeammnjpkecdekppnclgkkffahnhfhe) and pin to toolbar.
46
+
47
+ ### 2. Connect to Tabs
48
+
49
+ Click the Playwriter extension icon on any tab you want to control. Icon turns green when connected.
50
+
51
+ ### 3. Configure MCP
52
+
53
+ Add to your MCP client configuration:
54
+
55
+ **OpenCode** (`~/.config/opencode/opencode.json`):
56
+
57
+ ```json
58
+ {
59
+ "mcp": {
60
+ "playwriter": {
61
+ "type": "local",
62
+ "command": ["npx", "playwriter@latest"],
63
+ "enabled": true
64
+ }
65
+ }
66
+ }
67
+ ```text
68
+
69
+ **Claude Desktop** (`claude_desktop_config.json`):
70
+
71
+ ```json
72
+ {
73
+ "mcpServers": {
74
+ "playwriter": {
75
+ "command": "npx",
76
+ "args": ["playwriter@latest"]
77
+ }
78
+ }
79
+ }
80
+ ```text
81
+
82
+ ## Usage
83
+
84
+ ### The `execute` Tool
85
+
86
+ Playwriter exposes a single `execute` tool that runs Playwright code:
87
+
88
+ ```javascript
89
+ // Navigate
90
+ await page.goto('https://example.com')
91
+
92
+ // Click
93
+ await page.click('button.submit')
94
+
95
+ // Fill form
96
+ await page.fill('input[name="email"]', 'user@example.com')
97
+
98
+ // Screenshot
99
+ await page.screenshot({ path: 'screenshot.png' })
100
+
101
+ // Extract text
102
+ const title = await page.textContent('h1')
103
+
104
+ // Wait for element
105
+ await page.waitForSelector('.loaded')
106
+ ```text
107
+
108
+ ### Multi-Tab Control
109
+
110
+ ```javascript
111
+ // Get all connected tabs
112
+ const pages = context.pages()
113
+
114
+ // Switch between tabs
115
+ const page1 = pages[0]
116
+ const page2 = pages[1]
117
+
118
+ // Create new tab
119
+ const newPage = await context.newPage()
120
+ await newPage.goto('https://example.com')
121
+ ```text
122
+
123
+ ### Programmatic Usage
124
+
125
+ Use with playwright-core directly:
126
+
127
+ ```javascript
128
+ import { chromium } from 'playwright-core'
129
+ import { startPlayWriterCDPRelayServer, getCdpUrl } from 'playwriter'
130
+
131
+ const server = await startPlayWriterCDPRelayServer()
132
+ const browser = await chromium.connectOverCDP(getCdpUrl())
133
+
134
+ const context = browser.contexts()[0]
135
+ const page = context.pages()[0]
136
+
137
+ await page.goto('https://example.com')
138
+ await page.screenshot({ path: 'screenshot.png' })
139
+
140
+ await browser.close()
141
+ server.close()
142
+ ```text
143
+
144
+ ## Comparison with Other Tools
145
+
146
+ | Feature | Playwriter | BrowserMCP | Playwright MCP | Stagehand |
147
+ |---------|------------|------------|----------------|-----------|
148
+ | Tools | 1 (`execute`) | 17+ | 10+ | 4 primitives |
149
+ | Context bloat | Minimal | High | Medium | Low |
150
+ | API | Full Playwright | Limited | Full Playwright | Natural language |
151
+ | Browser | Your existing | New instance | New instance | New instance |
152
+ | Extensions | ✅ Reuse yours | ❌ | ❌ | ❌ |
153
+ | Sessions | ✅ Existing | ❌ | ❌ | ❌ |
154
+ | Detection bypass | ✅ Disconnect | ❌ | ❌ | ❌ |
155
+ | Collaboration | ✅ Same browser | ❌ | ❌ | ❌ |
156
+
157
+ ### When to Use Playwriter
158
+
159
+ - **Debugging existing sessions** - Start on a page with your logged-in state
160
+ - **Bypassing automation detection** - Disconnect extension temporarily
161
+ - **Using your extensions** - Ad blockers, password managers work
162
+ - **Collaborating with AI** - Help it past captchas in real-time
163
+ - **Resource efficiency** - No separate Chrome instance
164
+
165
+ ### When to Use Other Tools
166
+
167
+ - **Stagehand** - Natural language automation, self-healing selectors
168
+ - **Playwright MCP** - Isolated automation, no extension needed
169
+ - **Crawl4AI** - Web scraping and content extraction
170
+
171
+ ## Architecture
172
+
173
+ ```text
174
+ +---------------------+ +-------------------+ +-----------------+
175
+ | BROWSER | | LOCALHOST | | MCP CLIENT |
176
+ | | | | | |
177
+ | +---------------+ | | WebSocket Server | | +-----------+ |
178
+ | | Extension |<---------> :19988 | | | AI Agent | |
179
+ | | (bg script) | | WS | | | | (Claude) | |
180
+ | +-------+-------+ | | /extension | | +-----------+ |
181
+ | | | | ^ | | | |
182
+ | | chrome | | | | | v |
183
+ | | .debug | | v | | +-----------+ |
184
+ | v | | /cdp/:id <--------------> | execute | |
185
+ | +---------------+ | | | WS | | tool | |
186
+ | | Tab 1 (green) | | | Routes: | | +-----------+ |
187
+ | +---------------+ | | - CDP commands | | | |
188
+ | +---------------+ | | - CDP events | | v |
189
+ | | Tab 2 (green) | | | - attach/detach | | +-----------+ |
190
+ | +---------------+ | | Target events | | | Playwright| |
191
+ | +---------------+ | +-------------------+ | | API | |
192
+ | | Tab 3 (gray) | | | +-----------+ |
193
+ | +---------------+ | Tab 3 not controlled +-----------------+
194
+ +---------------------+
195
+ ```text
196
+
197
+ ## Security
198
+
199
+ ### How It Works
200
+
201
+ 1. **Local WebSocket Server** - Runs on `localhost:19988`
202
+ 2. **Localhost-Only** - No CORS headers, only local processes can connect
203
+ 3. **User-Controlled** - Only tabs where you clicked the extension icon
204
+ 4. **Explicit Consent** - Chrome shows automation banner on controlled tabs
205
+
206
+ ### What Can Be Controlled
207
+
208
+ - ✅ Tabs you explicitly connected (clicked extension icon)
209
+ - ✅ New tabs created by automation
210
+ - ❌ Other browser tabs
211
+ - ❌ Tabs you haven't connected
212
+
213
+ ### What Cannot Happen
214
+
215
+ - ❌ Remote access (localhost-only)
216
+ - ❌ Passive monitoring of unconnected tabs
217
+ - ❌ Automatic spreading to new manual tabs
218
+
219
+ ## Common Patterns
220
+
221
+ ### Login Flow
222
+
223
+ ```javascript
224
+ // Navigate to login
225
+ await page.goto('https://app.example.com/login')
226
+
227
+ // Fill credentials
228
+ await page.fill('input[name="email"]', 'user@example.com')
229
+ await page.fill('input[name="password"]', 'password')
230
+
231
+ // Click login
232
+ await page.click('button[type="submit"]')
233
+
234
+ // Wait for redirect
235
+ await page.waitForURL('**/dashboard')
236
+ ```text
237
+
238
+ ### Form Submission
239
+
240
+ ```javascript
241
+ // Fill form fields
242
+ await page.fill('#name', 'John Doe')
243
+ await page.fill('#email', 'john@example.com')
244
+ await page.selectOption('#country', 'US')
245
+ await page.check('#terms')
246
+
247
+ // Submit
248
+ await page.click('button[type="submit"]')
249
+
250
+ // Wait for success
251
+ await page.waitForSelector('.success-message')
252
+ ```text
253
+
254
+ ### Data Extraction
255
+
256
+ ```javascript
257
+ // Get all product prices
258
+ const prices = await page.$$eval('.product-price',
259
+ elements => elements.map(el => el.textContent)
260
+ )
261
+
262
+ // Get table data
263
+ const rows = await page.$$eval('table tr', rows =>
264
+ rows.map(row => {
265
+ const cells = row.querySelectorAll('td')
266
+ return Array.from(cells).map(cell => cell.textContent)
267
+ })
268
+ )
269
+ ```text
270
+
271
+ ### Screenshot and PDF
272
+
273
+ ```javascript
274
+ // Full page screenshot
275
+ await page.screenshot({ path: 'full.png', fullPage: true })
276
+
277
+ // Element screenshot
278
+ await page.locator('.chart').screenshot({ path: 'chart.png' })
279
+
280
+ // PDF export
281
+ await page.pdf({ path: 'page.pdf', format: 'A4' })
282
+ ```text
283
+
284
+ ## Troubleshooting
285
+
286
+ ### Extension Not Connecting
287
+
288
+ 1. Check extension is installed and pinned
289
+ 2. Click extension icon on the tab (should turn green)
290
+ 3. Check for error badge (red !)
291
+ 4. Reload the tab and try again
292
+
293
+ ### MCP Not Finding Tabs
294
+
295
+ 1. Ensure extension is connected (green icon)
296
+ 2. Restart MCP client
297
+ 3. Check WebSocket server is running on port 19988
298
+
299
+ ### Automation Detection
300
+
301
+ 1. Disconnect extension (click icon to turn gray)
302
+ 2. Complete manual action (login, captcha)
303
+ 3. Reconnect extension (click icon to turn green)
304
+ 4. Continue automation
305
+
306
+ ## Resources
307
+
308
+ - **GitHub**: https://github.com/remorses/playwriter
309
+ - **Chrome Extension**: https://chromewebstore.google.com/detail/playwriter-mcp/jfeammnjpkecdekppnclgkkffahnhfhe
310
+ - **Playwright Docs**: https://playwright.dev/docs/api/class-page