claude-mpm 4.25.10__py3-none-any.whl → 5.1.8__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.
Files changed (507) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/PM_INSTRUCTIONS.md +1055 -2230
  4. claude_mpm/agents/PM_INSTRUCTIONS_TEACH.md +1322 -0
  5. claude_mpm/agents/WORKFLOW.md +4 -4
  6. claude_mpm/agents/__init__.py +6 -0
  7. claude_mpm/agents/agent_loader.py +1 -4
  8. claude_mpm/agents/base_agent_loader.py +10 -35
  9. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +576 -66
  10. claude_mpm/agents/templates/context-management-examples.md +544 -0
  11. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  12. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  13. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  14. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  15. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  16. claude_mpm/cli/__init__.py +28 -3
  17. claude_mpm/cli/commands/__init__.py +2 -0
  18. claude_mpm/cli/commands/agent_source.py +774 -0
  19. claude_mpm/cli/commands/agent_state_manager.py +188 -30
  20. claude_mpm/cli/commands/agents.py +959 -36
  21. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  22. claude_mpm/cli/commands/agents_discover.py +338 -0
  23. claude_mpm/cli/commands/auto_configure.py +537 -239
  24. claude_mpm/cli/commands/config.py +7 -4
  25. claude_mpm/cli/commands/configure.py +924 -45
  26. claude_mpm/cli/commands/configure_navigation.py +63 -46
  27. claude_mpm/cli/commands/doctor.py +10 -2
  28. claude_mpm/cli/commands/local_deploy.py +1 -4
  29. claude_mpm/cli/commands/postmortem.py +401 -0
  30. claude_mpm/cli/commands/run.py +1 -39
  31. claude_mpm/cli/commands/skill_source.py +694 -0
  32. claude_mpm/cli/commands/skills.py +322 -19
  33. claude_mpm/cli/executor.py +22 -3
  34. claude_mpm/cli/interactive/agent_wizard.py +1028 -43
  35. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  36. claude_mpm/cli/parsers/agents_parser.py +256 -4
  37. claude_mpm/cli/parsers/auto_configure_parser.py +13 -0
  38. claude_mpm/cli/parsers/base_parser.py +25 -0
  39. claude_mpm/cli/parsers/config_parser.py +96 -43
  40. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  41. claude_mpm/cli/parsers/skills_parser.py +7 -0
  42. claude_mpm/cli/parsers/source_parser.py +138 -0
  43. claude_mpm/cli/startup.py +456 -103
  44. claude_mpm/cli/startup_display.py +4 -4
  45. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  46. claude_mpm/commands/mpm-agents-detect.md +9 -0
  47. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  48. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  49. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  50. claude_mpm/commands/mpm-doctor.md +9 -0
  51. claude_mpm/commands/mpm-help.md +14 -2
  52. claude_mpm/commands/mpm-init.md +9 -0
  53. claude_mpm/commands/mpm-monitor.md +9 -0
  54. claude_mpm/commands/mpm-postmortem.md +123 -0
  55. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  56. claude_mpm/commands/mpm-status.md +9 -0
  57. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  58. claude_mpm/commands/mpm-ticket-view.md +552 -0
  59. claude_mpm/commands/mpm-version.md +9 -0
  60. claude_mpm/commands/mpm.md +10 -0
  61. claude_mpm/config/agent_presets.py +488 -0
  62. claude_mpm/config/agent_sources.py +325 -0
  63. claude_mpm/config/skill_presets.py +392 -0
  64. claude_mpm/config/skill_sources.py +590 -0
  65. claude_mpm/constants.py +1 -0
  66. claude_mpm/core/claude_runner.py +5 -34
  67. claude_mpm/core/config.py +16 -0
  68. claude_mpm/core/framework/__init__.py +3 -16
  69. claude_mpm/core/framework/loaders/file_loader.py +54 -101
  70. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  71. claude_mpm/core/interactive_session.py +83 -7
  72. claude_mpm/core/oneshot_session.py +71 -8
  73. claude_mpm/core/protocols/__init__.py +23 -0
  74. claude_mpm/core/protocols/runner_protocol.py +103 -0
  75. claude_mpm/core/protocols/session_protocol.py +131 -0
  76. claude_mpm/core/shared/singleton_manager.py +11 -4
  77. claude_mpm/core/system_context.py +38 -0
  78. claude_mpm/core/unified_config.py +22 -0
  79. claude_mpm/experimental/cli_enhancements.py +1 -5
  80. claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-313.pyc +0 -0
  81. claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-313.pyc +0 -0
  82. claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-313.pyc +0 -0
  83. claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-313.pyc +0 -0
  84. claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-313.pyc +0 -0
  85. claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-313.pyc +0 -0
  86. claude_mpm/hooks/claude_hooks/memory_integration.py +12 -1
  87. claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-313.pyc +0 -0
  88. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-313.pyc +0 -0
  89. claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-313.pyc +0 -0
  90. claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-313.pyc +0 -0
  91. claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-313.pyc +0 -0
  92. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  93. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  94. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  95. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  96. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  97. claude_mpm/models/git_repository.py +198 -0
  98. claude_mpm/services/agents/agent_builder.py +45 -9
  99. claude_mpm/services/agents/agent_preset_service.py +238 -0
  100. claude_mpm/services/agents/agent_selection_service.py +484 -0
  101. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  102. claude_mpm/services/agents/cache_git_manager.py +621 -0
  103. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  104. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  105. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  106. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  107. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  108. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  109. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  110. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  111. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  112. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  113. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  114. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  115. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  116. claude_mpm/services/agents/git_source_manager.py +629 -0
  117. claude_mpm/services/agents/loading/framework_agent_loader.py +1 -4
  118. claude_mpm/services/agents/local_template_manager.py +47 -9
  119. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  120. claude_mpm/services/agents/sources/__init__.py +13 -0
  121. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  122. claude_mpm/services/agents/sources/git_source_sync_service.py +1087 -0
  123. claude_mpm/services/agents/startup_sync.py +239 -0
  124. claude_mpm/services/agents/toolchain_detector.py +474 -0
  125. claude_mpm/services/analysis/__init__.py +25 -0
  126. claude_mpm/services/analysis/postmortem_reporter.py +474 -0
  127. claude_mpm/services/analysis/postmortem_service.py +765 -0
  128. claude_mpm/services/command_deployment_service.py +200 -6
  129. claude_mpm/services/core/base.py +7 -2
  130. claude_mpm/services/core/interfaces/__init__.py +1 -3
  131. claude_mpm/services/core/interfaces/health.py +1 -4
  132. claude_mpm/services/core/models/__init__.py +2 -11
  133. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  134. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  135. claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
  136. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  137. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  138. claude_mpm/services/diagnostics/doctor_reporter.py +34 -6
  139. claude_mpm/services/git/__init__.py +21 -0
  140. claude_mpm/services/git/git_operations_service.py +494 -0
  141. claude_mpm/services/github/__init__.py +21 -0
  142. claude_mpm/services/github/github_cli_service.py +397 -0
  143. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  144. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  145. claude_mpm/services/instructions/__init__.py +9 -0
  146. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  147. claude_mpm/services/local_ops/__init__.py +3 -13
  148. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  149. claude_mpm/services/local_ops/health_manager.py +1 -4
  150. claude_mpm/services/mcp_config_manager.py +75 -145
  151. claude_mpm/services/mcp_gateway/core/process_pool.py +22 -16
  152. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  153. claude_mpm/services/mcp_service_verifier.py +6 -3
  154. claude_mpm/services/monitor/daemon.py +28 -8
  155. claude_mpm/services/monitor/daemon_manager.py +96 -19
  156. claude_mpm/services/pr/__init__.py +14 -0
  157. claude_mpm/services/pr/pr_template_service.py +329 -0
  158. claude_mpm/services/project/project_organizer.py +4 -0
  159. claude_mpm/services/runner_configuration_service.py +16 -3
  160. claude_mpm/services/session_management_service.py +16 -4
  161. claude_mpm/services/skills/__init__.py +18 -0
  162. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  163. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  164. claude_mpm/services/socketio/server/core.py +1 -4
  165. claude_mpm/services/socketio/server/main.py +1 -3
  166. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  167. claude_mpm/services/unified/unified_deployment.py +1 -5
  168. claude_mpm/services/visualization/__init__.py +1 -5
  169. claude_mpm/templates/questions/__init__.py +2 -7
  170. claude_mpm/templates/questions/pr_strategy.py +1 -4
  171. claude_mpm/templates/questions/project_init.py +1 -4
  172. claude_mpm/templates/questions/ticket_mgmt.py +1 -4
  173. claude_mpm/utils/agent_dependency_loader.py +77 -10
  174. claude_mpm/utils/agent_filters.py +288 -0
  175. claude_mpm/utils/gitignore.py +3 -0
  176. claude_mpm/utils/migration.py +372 -0
  177. claude_mpm/utils/progress.py +387 -0
  178. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/METADATA +356 -112
  179. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/RECORD +188 -439
  180. claude_mpm/agents/templates/agent-manager.json +0 -273
  181. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  182. claude_mpm/agents/templates/api_qa.json +0 -183
  183. claude_mpm/agents/templates/clerk-ops.json +0 -235
  184. claude_mpm/agents/templates/code_analyzer.json +0 -101
  185. claude_mpm/agents/templates/content-agent.json +0 -358
  186. claude_mpm/agents/templates/dart_engineer.json +0 -307
  187. claude_mpm/agents/templates/data_engineer.json +0 -225
  188. claude_mpm/agents/templates/documentation.json +0 -238
  189. claude_mpm/agents/templates/engineer.json +0 -210
  190. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  191. claude_mpm/agents/templates/golang_engineer.json +0 -270
  192. claude_mpm/agents/templates/imagemagick.json +0 -264
  193. claude_mpm/agents/templates/java_engineer.json +0 -346
  194. claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
  195. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  196. claude_mpm/agents/templates/memory_manager.json +0 -158
  197. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  198. claude_mpm/agents/templates/ops.json +0 -185
  199. claude_mpm/agents/templates/php-engineer.json +0 -287
  200. claude_mpm/agents/templates/product_owner.json +0 -338
  201. claude_mpm/agents/templates/project_organizer.json +0 -144
  202. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  203. claude_mpm/agents/templates/python_engineer.json +0 -387
  204. claude_mpm/agents/templates/qa.json +0 -243
  205. claude_mpm/agents/templates/react_engineer.json +0 -239
  206. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  207. claude_mpm/agents/templates/research.json +0 -258
  208. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  209. claude_mpm/agents/templates/rust_engineer.json +0 -275
  210. claude_mpm/agents/templates/security.json +0 -202
  211. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  212. claude_mpm/agents/templates/tauri_engineer.json +0 -274
  213. claude_mpm/agents/templates/ticketing.json +0 -181
  214. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  215. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  216. claude_mpm/agents/templates/version_control.json +0 -159
  217. claude_mpm/agents/templates/web_qa.json +0 -400
  218. claude_mpm/agents/templates/web_ui.json +0 -189
  219. claude_mpm/cli/README.md +0 -253
  220. claude_mpm/cli/commands/mcp_install_commands.py.backup +0 -284
  221. claude_mpm/cli/commands/mpm_init/README.md +0 -365
  222. claude_mpm/cli_module/refactoring_guide.md +0 -253
  223. claude_mpm/commands/mpm-tickets.md +0 -151
  224. claude_mpm/config/agent_capabilities.yaml +0 -658
  225. claude_mpm/config/async_logging_config.yaml +0 -145
  226. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +0 -34
  227. claude_mpm/d2/.gitignore +0 -22
  228. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +0 -273
  229. claude_mpm/d2/FLASK_INTEGRATION.md +0 -156
  230. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +0 -452
  231. claude_mpm/d2/QUICKSTART.md +0 -186
  232. claude_mpm/d2/README.md +0 -232
  233. claude_mpm/d2/STORE_FIX_SUMMARY.md +0 -167
  234. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +0 -180
  235. claude_mpm/d2/TESTING.md +0 -288
  236. claude_mpm/d2/index.html +0 -118
  237. claude_mpm/d2/package.json +0 -19
  238. claude_mpm/d2/src/App.svelte +0 -110
  239. claude_mpm/d2/src/components/Header.svelte +0 -153
  240. claude_mpm/d2/src/components/MainContent.svelte +0 -74
  241. claude_mpm/d2/src/components/Sidebar.svelte +0 -85
  242. claude_mpm/d2/src/components/tabs/EventsTab.svelte +0 -326
  243. claude_mpm/d2/src/lib/socketio.js +0 -144
  244. claude_mpm/d2/src/main.js +0 -7
  245. claude_mpm/d2/src/stores/events.js +0 -114
  246. claude_mpm/d2/src/stores/socket.js +0 -108
  247. claude_mpm/d2/src/stores/theme.js +0 -65
  248. claude_mpm/d2/svelte.config.js +0 -12
  249. claude_mpm/d2/vite.config.js +0 -15
  250. claude_mpm/dashboard/.claude-mpm/memories/README.md +0 -36
  251. claude_mpm/dashboard/BUILD_NUMBER +0 -1
  252. claude_mpm/dashboard/README.md +0 -121
  253. claude_mpm/dashboard/VERSION +0 -1
  254. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  255. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +0 -273
  256. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +0 -75
  257. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  258. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +0 -141
  259. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  260. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +0 -36
  261. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  262. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +0 -89
  263. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +0 -215
  264. claude_mpm/dashboard/react/entries/events.tsx +0 -165
  265. claude_mpm/dashboard/react/hooks/useEvents.ts +0 -191
  266. claude_mpm/dashboard/react/hooks/useSocket.ts +0 -225
  267. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  268. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +0 -170
  269. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  270. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  271. claude_mpm/dashboard/static/built/components/activity-tree.js.map +0 -1
  272. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  273. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  274. claude_mpm/dashboard/static/built/components/agent-inference.js.map +0 -1
  275. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  276. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  277. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  278. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  279. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  280. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  281. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  282. claude_mpm/dashboard/static/built/components/code-tree.js.map +0 -1
  283. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  284. claude_mpm/dashboard/static/built/components/code-viewer.js.map +0 -1
  285. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  286. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  287. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  288. claude_mpm/dashboard/static/built/components/event-processor.js.map +0 -1
  289. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  290. claude_mpm/dashboard/static/built/components/event-viewer.js.map +0 -1
  291. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  292. claude_mpm/dashboard/static/built/components/export-manager.js.map +0 -1
  293. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  294. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  295. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  296. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +0 -1
  297. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  298. claude_mpm/dashboard/static/built/components/file-viewer.js.map +0 -1
  299. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  300. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +0 -1
  301. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  302. claude_mpm/dashboard/static/built/components/hud-manager.js.map +0 -1
  303. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  304. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +0 -1
  305. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  306. claude_mpm/dashboard/static/built/components/module-viewer.js.map +0 -1
  307. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  308. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  309. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  310. claude_mpm/dashboard/static/built/components/session-manager.js.map +0 -1
  311. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  312. claude_mpm/dashboard/static/built/components/socket-manager.js.map +0 -1
  313. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  314. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +0 -1
  315. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  316. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +0 -1
  317. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  318. claude_mpm/dashboard/static/built/components/working-directory.js.map +0 -1
  319. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  320. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  321. claude_mpm/dashboard/static/built/dashboard.js.map +0 -1
  322. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  323. claude_mpm/dashboard/static/built/react/events.js +0 -30
  324. claude_mpm/dashboard/static/built/react/events.js.map +0 -1
  325. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  326. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  327. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  328. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  329. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  330. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  331. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  332. claude_mpm/dashboard/static/built/socket-client.js.map +0 -1
  333. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  334. claude_mpm/dashboard/static/events.html +0 -607
  335. claude_mpm/dashboard/static/index.html +0 -635
  336. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +0 -170
  337. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  338. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  339. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  340. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  341. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  342. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  343. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  344. claude_mpm/dashboard/static/legacy/files.html +0 -747
  345. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  346. claude_mpm/dashboard/static/monitors.html +0 -431
  347. claude_mpm/dashboard/static/navigation-test-results.md +0 -118
  348. claude_mpm/dashboard/static/production/events.html +0 -659
  349. claude_mpm/dashboard/static/production/main.html +0 -698
  350. claude_mpm/dashboard/static/production/monitors.html +0 -483
  351. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  352. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  353. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  354. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  355. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +0 -36
  356. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +0 -39
  357. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +0 -38
  358. claude_mpm/hooks/README.md +0 -143
  359. claude_mpm/hooks/templates/README.md +0 -180
  360. claude_mpm/hooks/templates/settings.json.example +0 -147
  361. claude_mpm/schemas/agent_schema.json +0 -596
  362. claude_mpm/schemas/frontmatter_schema.json +0 -165
  363. claude_mpm/services/event_bus/README.md +0 -244
  364. claude_mpm/services/events/README.md +0 -303
  365. claude_mpm/services/framework_claude_md_generator/README.md +0 -119
  366. claude_mpm/services/mcp_gateway/README.md +0 -185
  367. claude_mpm/services/socketio/handlers/connection.py.backup +0 -217
  368. claude_mpm/services/socketio/handlers/hook.py.backup +0 -154
  369. claude_mpm/services/static/.gitkeep +0 -2
  370. claude_mpm/services/version_control/VERSION +0 -1
  371. claude_mpm/skills/bundled/.gitkeep +0 -2
  372. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  373. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  374. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  375. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  376. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  377. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  378. claude_mpm/skills/bundled/collaboration/git-worktrees.md +0 -317
  379. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  380. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  381. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  382. claude_mpm/skills/bundled/collaboration/stacked-prs.md +0 -251
  383. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  384. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  385. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  386. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  387. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +0 -63
  388. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  389. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  390. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  391. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  392. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  393. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  394. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  395. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  396. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  397. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  398. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  399. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  400. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  401. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  402. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  403. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  404. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  405. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  406. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  407. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +0 -611
  408. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +0 -596
  409. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +0 -260
  410. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +0 -315
  411. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +0 -436
  412. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +0 -433
  413. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +0 -452
  414. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +0 -404
  415. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +0 -420
  416. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +0 -202
  417. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  418. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +0 -54
  419. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +0 -322
  420. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  421. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +0 -202
  422. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  423. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  424. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  425. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  426. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  427. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +0 -202
  428. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  429. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  430. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  431. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  432. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  433. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  434. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  435. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +0 -22
  436. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +0 -2
  437. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +0 -202
  438. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  439. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  440. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  441. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  442. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  443. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  444. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  445. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  446. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  447. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  448. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  449. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  450. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  451. claude_mpm/skills/bundled/react/flexlayout-react.md +0 -742
  452. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  453. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  454. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  455. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  456. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  457. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  458. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  459. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +0 -495
  460. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +0 -599
  461. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +0 -535
  462. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +0 -613
  463. claude_mpm/skills/bundled/tauri/tauri-event-system.md +0 -648
  464. claude_mpm/skills/bundled/tauri/tauri-file-system.md +0 -673
  465. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +0 -767
  466. claude_mpm/skills/bundled/tauri/tauri-performance.md +0 -669
  467. claude_mpm/skills/bundled/tauri/tauri-state-management.md +0 -573
  468. claude_mpm/skills/bundled/tauri/tauri-testing.md +0 -384
  469. claude_mpm/skills/bundled/tauri/tauri-window-management.md +0 -628
  470. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  471. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +0 -158
  472. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  473. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  474. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  475. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  476. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  477. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  478. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  479. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +0 -458
  480. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +0 -411
  481. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +0 -317
  482. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +0 -270
  483. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +0 -436
  484. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  485. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  486. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  487. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  488. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  489. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +0 -202
  490. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  491. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  492. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  493. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  494. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  495. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  496. claude_mpm/templates/questions/EXAMPLES.md +0 -501
  497. claude_mpm/tools/README_SOCKETIO_DEBUG.md +0 -224
  498. claude_mpm/tools/code_tree_analyzer/README.md +0 -64
  499. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  500. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  501. /claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +0 -0
  502. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  503. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  504. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/WHEEL +0 -0
  505. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/entry_points.txt +0 -0
  506. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/licenses/LICENSE +0 -0
  507. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/top_level.txt +0 -0
@@ -1,831 +0,0 @@
1
- # Testing and Debugging Reference
2
-
3
- ## Unit Testing
4
-
5
- EspoCRM supports PHPUnit for testing.
6
-
7
- ### Test Setup
8
-
9
- Install PHPUnit in your extension:
10
-
11
- ```bash
12
- composer require --dev phpunit/phpunit
13
- ```
14
-
15
- Create `phpunit.xml`:
16
-
17
- ```xml
18
- <?xml version="1.0" encoding="UTF-8"?>
19
- <phpunit
20
- bootstrap="tests/bootstrap.php"
21
- colors="true"
22
- convertErrorsToExceptions="true"
23
- convertNoticesToExceptions="true"
24
- convertWarningsToExceptions="true"
25
- stopOnFailure="false">
26
- <testsuites>
27
- <testsuite name="Unit Tests">
28
- <directory>tests/unit</directory>
29
- </testsuite>
30
- <testsuite name="Integration Tests">
31
- <directory>tests/integration</directory>
32
- </testsuite>
33
- </testsuites>
34
- </phpunit>
35
- ```
36
-
37
- ### Unit Test Example
38
-
39
- Create `tests/unit/MyServiceTest.php`:
40
-
41
- ```php
42
- <?php
43
- namespace Espo\Modules\MyModule\Tests\Unit;
44
-
45
- use PHPUnit\Framework\TestCase;
46
- use Espo\Modules\MyModule\Services\MyEntity;
47
- use Espo\ORM\EntityManager;
48
- use Espo\Core\Acl;
49
- use Espo\Entities\User;
50
-
51
- class MyServiceTest extends TestCase
52
- {
53
- private MyEntity $service;
54
- private EntityManager $entityManager;
55
- private Acl $acl;
56
- private User $user;
57
-
58
- protected function setUp(): void
59
- {
60
- parent::setUp();
61
-
62
- // Create mocks
63
- $this->entityManager = $this->createMock(EntityManager::class);
64
- $this->acl = $this->createMock(Acl::class);
65
- $this->user = $this->createMock(User::class);
66
-
67
- // Create service with mocked dependencies
68
- $this->service = new MyEntity();
69
-
70
- // Inject dependencies via reflection (if needed)
71
- $reflection = new \ReflectionClass($this->service);
72
- $property = $reflection->getProperty('entityManager');
73
- $property->setAccessible(true);
74
- $property->setValue($this->service, $this->entityManager);
75
- }
76
-
77
- public function testCalculateTotal(): void
78
- {
79
- // Arrange
80
- $entity = $this->createMock(\Espo\ORM\Entity::class);
81
-
82
- $entity->method('get')
83
- ->willReturnMap([
84
- ['quantity', null, 5],
85
- ['unitPrice', null, 10.50]
86
- ]);
87
-
88
- // Act
89
- $total = $this->service->calculateTotal($entity);
90
-
91
- // Assert
92
- $this->assertEquals(52.50, $total);
93
- }
94
-
95
- public function testValidateThrowsExceptionForInvalidData(): void
96
- {
97
- // Arrange
98
- $entity = $this->createMock(\Espo\ORM\Entity::class);
99
- $entity->method('get')
100
- ->willReturn(-100);
101
-
102
- // Assert
103
- $this->expectException(\Espo\Core\Exceptions\BadRequest::class);
104
- $this->expectExceptionMessage('Amount cannot be negative');
105
-
106
- // Act
107
- $this->service->validate($entity);
108
- }
109
-
110
- public function testCreateEntitySetsDefaults(): void
111
- {
112
- // Arrange
113
- $entity = $this->createMock(\Espo\ORM\Entity::class);
114
-
115
- $this->user->method('getId')
116
- ->willReturn('user-123');
117
-
118
- $entity->expects($this->once())
119
- ->method('set')
120
- ->with('assignedUserId', 'user-123');
121
-
122
- // Act
123
- $this->service->setDefaults($entity);
124
- }
125
- }
126
- ```
127
-
128
- ### Integration Test Example
129
-
130
- Create `tests/integration/HookTest.php`:
131
-
132
- ```php
133
- <?php
134
- namespace Espo\Modules\MyModule\Tests\Integration;
135
-
136
- use PHPUnit\Framework\TestCase;
137
- use Espo\Core\Container;
138
- use Espo\ORM\EntityManager;
139
-
140
- class HookTest extends TestCase
141
- {
142
- private Container $container;
143
- private EntityManager $entityManager;
144
-
145
- protected function setUp(): void
146
- {
147
- parent::setUp();
148
-
149
- // Load EspoCRM container (requires EspoCRM installation)
150
- require_once 'bootstrap.php';
151
-
152
- $this->container = $GLOBALS['container'];
153
- $this->entityManager = $this->container->get('entityManager');
154
- }
155
-
156
- public function testAccountHookUpdatesRelatedContacts(): void
157
- {
158
- // Create test account
159
- $account = $this->entityManager->getNewEntity('Account');
160
- $account->set('name', 'Test Account');
161
- $this->entityManager->saveEntity($account);
162
-
163
- // Create related contact
164
- $contact = $this->entityManager->getNewEntity('Contact');
165
- $contact->set([
166
- 'firstName' => 'John',
167
- 'lastName' => 'Doe',
168
- 'accountId' => $account->getId()
169
- ]);
170
- $this->entityManager->saveEntity($contact);
171
-
172
- // Update account status
173
- $account->set('status', 'Inactive');
174
- $this->entityManager->saveEntity($account);
175
-
176
- // Refresh contact
177
- $contact = $this->entityManager->getEntityById('Contact', $contact->getId());
178
-
179
- // Assert hook updated contact
180
- $this->assertEquals('Inactive', $contact->get('accountStatus'));
181
-
182
- // Cleanup
183
- $this->entityManager->removeEntity($contact);
184
- $this->entityManager->removeEntity($account);
185
- }
186
- }
187
- ```
188
-
189
- ### Running Tests
190
-
191
- ```bash
192
- # Run all tests
193
- vendor/bin/phpunit
194
-
195
- # Run specific test file
196
- vendor/bin/phpunit tests/unit/MyServiceTest.php
197
-
198
- # Run specific test method
199
- vendor/bin/phpunit --filter testCalculateTotal
200
-
201
- # Run with coverage
202
- vendor/bin/phpunit --coverage-html coverage
203
- ```
204
-
205
- ## Debugging Techniques
206
-
207
- ### Enable Debug Mode
208
-
209
- Edit `data/config.php`:
210
-
211
- ```php
212
- <?php
213
- return [
214
- // ... other config ...
215
- 'logger' => [
216
- 'level' => 'DEBUG', // Change from 'WARNING' to 'DEBUG'
217
- 'maxFileNumber' => 30,
218
- ],
219
- 'isDeveloperMode' => true, // Enable developer mode
220
- ];
221
- ```
222
-
223
- ### Logging
224
-
225
- ```php
226
- <?php
227
- namespace Espo\Modules\MyModule\Services;
228
-
229
- use Espo\Core\Utils\Log;
230
-
231
- class MyService
232
- {
233
- public function __construct(private Log $log) {}
234
-
235
- public function processData(array $data): void
236
- {
237
- // Debug logging
238
- $this->log->debug('Processing data', ['data' => $data]);
239
-
240
- try {
241
- // ... processing ...
242
-
243
- $this->log->info('Data processed successfully', ['count' => count($data)]);
244
- } catch (\Throwable $e) {
245
- $this->log->error('Failed to process data: ' . $e->getMessage(), [
246
- 'exception' => $e,
247
- 'trace' => $e->getTraceAsString()
248
- ]);
249
-
250
- throw $e;
251
- }
252
- }
253
-
254
- public function debugQuery(): void
255
- {
256
- $query = $this->entityManager
257
- ->getQueryBuilder()
258
- ->select()
259
- ->from('Account')
260
- ->where(['type' => 'Customer'])
261
- ->build();
262
-
263
- // Log the SQL query
264
- $sql = $this->entityManager->getQueryComposer()->compose($query);
265
- $this->log->debug('SQL Query', ['sql' => $sql]);
266
- }
267
- }
268
- ```
269
-
270
- ### Check Logs
271
-
272
- ```bash
273
- # Today's log
274
- tail -f data/logs/espo-$(date +%Y-%m-%d).log
275
-
276
- # Search logs
277
- grep "ERROR" data/logs/espo-*.log
278
-
279
- # Filter by component
280
- grep "MyService" data/logs/espo-*.log
281
- ```
282
-
283
- ### XDebug Setup
284
-
285
- Install XDebug PHP extension:
286
-
287
- ```bash
288
- # Ubuntu/Debian
289
- sudo apt-get install php-xdebug
290
-
291
- # macOS (Homebrew)
292
- brew install php-xdebug
293
- ```
294
-
295
- Configure XDebug in `php.ini`:
296
-
297
- ```ini
298
- [xdebug]
299
- zend_extension=xdebug.so
300
- xdebug.mode=debug
301
- xdebug.start_with_request=yes
302
- xdebug.client_host=127.0.0.1
303
- xdebug.client_port=9003
304
- xdebug.idekey=PHPSTORM
305
- ```
306
-
307
- ### Step Debugging with PhpStorm
308
-
309
- 1. Set breakpoints in code
310
- 2. Click "Start Listening for PHP Debug Connections"
311
- 3. Trigger the code path (API call, scheduled job, etc.)
312
- 4. PhpStorm will pause at breakpoints
313
-
314
- ### Debug API Requests
315
-
316
- ```bash
317
- # Using curl with verbose output
318
- curl -v -X GET \
319
- 'http://espocrm.local/api/v1/Account/123' \
320
- -H 'X-Api-Key: your-api-key'
321
-
322
- # Debug POST request
323
- curl -v -X POST \
324
- 'http://espocrm.local/api/v1/Account' \
325
- -H 'Content-Type: application/json' \
326
- -H 'X-Api-Key: your-api-key' \
327
- -d '{
328
- "name": "Test Account",
329
- "type": "Customer"
330
- }'
331
-
332
- # Save response to file for analysis
333
- curl -X GET \
334
- 'http://espocrm.local/api/v1/Account' \
335
- -H 'X-Api-Key: your-api-key' \
336
- -o response.json
337
- ```
338
-
339
- ### Browser DevTools for Frontend Debugging
340
-
341
- ```javascript
342
- // Add console logging in custom views
343
- define('custom:views/my-view', ['view'], function (Dep) {
344
- return Dep.extend({
345
- setup: function () {
346
- Dep.prototype.setup.call(this);
347
-
348
- console.log('View setup', {
349
- model: this.model.attributes,
350
- options: this.options
351
- });
352
- },
353
-
354
- afterRender: function () {
355
- Dep.prototype.afterRender.call(this);
356
-
357
- console.log('View rendered', {
358
- el: this.$el,
359
- modelId: this.model.id
360
- });
361
- }
362
- });
363
- });
364
-
365
- // Debug AJAX requests
366
- this.ajaxPostRequest('Account/action/myAction', data)
367
- .then(response => {
368
- console.log('Response received', response);
369
- })
370
- .catch(xhr => {
371
- console.error('Request failed', {
372
- status: xhr.status,
373
- response: xhr.responseJSON,
374
- error: xhr.responseText
375
- });
376
- });
377
- ```
378
-
379
- ### Database Debugging
380
-
381
- ```bash
382
- # Connect to MySQL
383
- mysql -u espocrm_user -p espocrm_db
384
-
385
- # Enable query logging
386
- SET GLOBAL general_log = 'ON';
387
- SET GLOBAL log_output = 'TABLE';
388
-
389
- # View query log
390
- SELECT * FROM mysql.general_log
391
- WHERE command_type = 'Query'
392
- ORDER BY event_time DESC
393
- LIMIT 100;
394
-
395
- # Disable query logging
396
- SET GLOBAL general_log = 'OFF';
397
- ```
398
-
399
- ### SQL Query Analysis
400
-
401
- ```php
402
- // Log query execution time
403
- $startTime = microtime(true);
404
-
405
- $result = $this->entityManager
406
- ->getRDBRepository('Account')
407
- ->where(['type' => 'Customer'])
408
- ->find();
409
-
410
- $executionTime = microtime(true) - $startTime;
411
-
412
- $this->log->debug('Query execution time', [
413
- 'time' => $executionTime,
414
- 'count' => count($result)
415
- ]);
416
-
417
- // Explain query
418
- $query = $this->entityManager
419
- ->getQueryBuilder()
420
- ->select()
421
- ->from('Account')
422
- ->where(['type' => 'Customer'])
423
- ->build();
424
-
425
- $sql = $this->entityManager->getQueryComposer()->compose($query);
426
-
427
- $pdo = $this->entityManager->getPDO();
428
- $sth = $pdo->prepare('EXPLAIN ' . $sql);
429
- $sth->execute();
430
-
431
- $explain = $sth->fetchAll(\PDO::FETCH_ASSOC);
432
- $this->log->debug('Query explain', ['explain' => $explain]);
433
- ```
434
-
435
- ## Performance Optimization
436
-
437
- ### Use STH Collections for Large Datasets
438
-
439
- ```php
440
- // ❌ WRONG - Loads all records into memory
441
- $contacts = $this->entityManager
442
- ->getRDBRepository('Contact')
443
- ->find();
444
-
445
- foreach ($contacts as $contact) {
446
- // Process
447
- }
448
-
449
- // ✅ CORRECT - Streams records one at a time
450
- $sthCollection = $this->entityManager
451
- ->getRDBRepository('Contact')
452
- ->sth()
453
- ->find();
454
-
455
- foreach ($sthCollection as $contact) {
456
- // Process without loading all into memory
457
- }
458
- ```
459
-
460
- ### Batch Operations
461
-
462
- ```php
463
- // ❌ WRONG - One query per update
464
- $accounts = $this->entityManager
465
- ->getRDBRepository('Account')
466
- ->where(['type' => 'Customer'])
467
- ->find();
468
-
469
- foreach ($accounts as $account) {
470
- $account->set('updated', true);
471
- $this->entityManager->saveEntity($account); // Individual query
472
- }
473
-
474
- // ✅ CORRECT - Batch update with single query
475
- $this->entityManager
476
- ->getQueryBuilder()
477
- ->update()
478
- ->in('Account')
479
- ->set(['updated' => true])
480
- ->where(['type' => 'Customer'])
481
- ->build()
482
- ->execute();
483
- ```
484
-
485
- ### Query Optimization
486
-
487
- ```php
488
- // ❌ WRONG - N+1 queries
489
- $opportunities = $this->entityManager
490
- ->getRDBRepository('Opportunity')
491
- ->find();
492
-
493
- foreach ($opportunities as $opportunity) {
494
- // Each iteration makes a query for account
495
- $account = $this->entityManager
496
- ->getEntityById('Account', $opportunity->get('accountId'));
497
- }
498
-
499
- // ✅ CORRECT - Single query with JOIN
500
- $opportunities = $this->entityManager
501
- ->getRDBRepository('Opportunity')
502
- ->distinct()
503
- ->join('account')
504
- ->select(['*', 'account.name AS accountName'])
505
- ->find();
506
-
507
- foreach ($opportunities as $opportunity) {
508
- // Account name already loaded
509
- $accountName = $opportunity->get('accountName');
510
- }
511
- ```
512
-
513
- ### Caching
514
-
515
- ```php
516
- use Espo\Core\Utils\DataCache;
517
-
518
- class MyService
519
- {
520
- public function __construct(private DataCache $dataCache) {}
521
-
522
- public function getExpensiveData(): array
523
- {
524
- $cacheKey = 'myExpensiveData';
525
-
526
- // Try to get from cache
527
- if ($this->dataCache->has($cacheKey)) {
528
- return $this->dataCache->get($cacheKey);
529
- }
530
-
531
- // Calculate if not cached
532
- $data = $this->performExpensiveCalculation();
533
-
534
- // Store in cache for 1 hour
535
- $this->dataCache->store($cacheKey, $data, 3600);
536
-
537
- return $data;
538
- }
539
-
540
- private function performExpensiveCalculation(): array
541
- {
542
- // Expensive operation
543
- return [];
544
- }
545
- }
546
- ```
547
-
548
- ### Profiling with Xdebug
549
-
550
- ```php
551
- // Enable profiling in php.ini
552
- xdebug.mode=profile
553
- xdebug.output_dir=/tmp/xdebug
554
- xdebug.start_with_request=trigger
555
-
556
- // Trigger with request parameter
557
- // http://espocrm.local/api/v1/Account?XDEBUG_PROFILE=1
558
-
559
- // Analyze with tools like:
560
- // - KCachegrind (Linux)
561
- // - QCachegrind (macOS/Windows)
562
- // - PhpStorm built-in profiler
563
- ```
564
-
565
- ## Common Pitfalls and Solutions
566
-
567
- ### Pitfall 1: Infinite Hook Loops
568
-
569
- **Problem:**
570
- ```php
571
- // Hook triggers itself infinitely
572
- class MyHook implements AfterSave {
573
- public function afterSave(Entity $entity, array $options): void {
574
- $entity->set('updated', true);
575
- $this->entityManager->saveEntity($entity); // Triggers hook again!
576
- }
577
- }
578
- ```
579
-
580
- **Solution:**
581
- ```php
582
- class MyHook implements AfterSave {
583
- public function afterSave(Entity $entity, array $options): void {
584
- // Check if already processing
585
- if (!empty($options['skipHooks'])) {
586
- return;
587
- }
588
-
589
- $entity->set('updated', true);
590
- $this->entityManager->saveEntity($entity, ['skipHooks' => true]);
591
- }
592
- }
593
- ```
594
-
595
- ### Pitfall 2: Missing Cache Rebuild
596
-
597
- **Problem:**
598
- - Metadata changes not reflected
599
- - New classes not found
600
-
601
- **Solution:**
602
- ```bash
603
- # Always rebuild after metadata or class changes
604
- bin/command rebuild
605
- ```
606
-
607
- ### Pitfall 3: Type Mismatches
608
-
609
- **Problem:**
610
- ```php
611
- // Method expects string, gets null
612
- public function process(string $id): void {
613
- // $id is null, causes error
614
- }
615
- ```
616
-
617
- **Solution:**
618
- ```php
619
- // Use nullable types
620
- public function process(?string $id): void {
621
- if (!$id) {
622
- throw new BadRequest('ID is required');
623
- }
624
- // Process
625
- }
626
- ```
627
-
628
- ### Pitfall 4: Container Dependency
629
-
630
- **Problem:**
631
- ```php
632
- // Tight coupling to Container
633
- class MyService {
634
- public function __construct(private Container $container) {}
635
- }
636
- ```
637
-
638
- **Solution:**
639
- ```php
640
- // Inject specific dependencies
641
- class MyService {
642
- public function __construct(
643
- private EntityManager $entityManager,
644
- private Metadata $metadata
645
- ) {}
646
- }
647
- ```
648
-
649
- ### Pitfall 5: Not Using Transactions
650
-
651
- **Problem:**
652
- ```php
653
- // Partial updates on error
654
- $entity1->set('status', 'Processing');
655
- $this->entityManager->saveEntity($entity1);
656
-
657
- // Error occurs here
658
- throw new \Exception('Error');
659
-
660
- // entity2 never updated, data inconsistent
661
- $entity2->set('status', 'Complete');
662
- $this->entityManager->saveEntity($entity2);
663
- ```
664
-
665
- **Solution:**
666
- ```php
667
- use Espo\ORM\TransactionManager;
668
-
669
- // Atomic operation
670
- $this->transactionManager->run(function () {
671
- $entity1->set('status', 'Processing');
672
- $this->entityManager->saveEntity($entity1);
673
-
674
- // If error occurs, both changes rolled back
675
- if ($error) {
676
- throw new \Exception('Error');
677
- }
678
-
679
- $entity2->set('status', 'Complete');
680
- $this->entityManager->saveEntity($entity2);
681
- });
682
- ```
683
-
684
- ### Pitfall 6: Direct PDO Usage
685
-
686
- **Problem:**
687
- ```php
688
- // Bypassing ORM
689
- $pdo = $this->entityManager->getPDO();
690
- $pdo->query("INSERT INTO account (name) VALUES ('Test')");
691
- ```
692
-
693
- **Solution:**
694
- ```php
695
- // Use ORM
696
- $account = $this->entityManager->getNewEntity('Account');
697
- $account->set('name', 'Test');
698
- $this->entityManager->saveEntity($account);
699
- ```
700
-
701
- ### Pitfall 7: Memory Exhaustion
702
-
703
- **Problem:**
704
- ```php
705
- // Loading 100k records into memory
706
- $contacts = $this->entityManager
707
- ->getRDBRepository('Contact')
708
- ->find(); // Memory exhausted!
709
- ```
710
-
711
- **Solution:**
712
- ```php
713
- // Use STH collection
714
- $sthCollection = $this->entityManager
715
- ->getRDBRepository('Contact')
716
- ->sth()
717
- ->find();
718
-
719
- foreach ($sthCollection as $contact) {
720
- // Process one at a time
721
- }
722
- ```
723
-
724
- ## Error Handling Best Practices
725
-
726
- ### Use Specific Exceptions
727
-
728
- ```php
729
- use Espo\Core\Exceptions\{
730
- BadRequest,
731
- Forbidden,
732
- NotFound,
733
- Conflict,
734
- Error
735
- };
736
-
737
- class MyService {
738
- public function process(string $id): Entity {
739
- // Validate input
740
- if (!$id) {
741
- throw new BadRequest('ID is required');
742
- }
743
-
744
- // Check existence
745
- $entity = $this->entityManager->getEntityById('Account', $id);
746
- if (!$entity) {
747
- throw new NotFound('Account not found');
748
- }
749
-
750
- // Check permissions
751
- if (!$this->acl->check($entity, 'edit')) {
752
- throw new Forbidden('No edit access');
753
- }
754
-
755
- // Check business rules
756
- if ($entity->get('locked')) {
757
- throw new Conflict('Account is locked');
758
- }
759
-
760
- // Process...
761
- return $entity;
762
- }
763
- }
764
- ```
765
-
766
- ### Try-Catch Patterns
767
-
768
- ```php
769
- // Catch and log
770
- try {
771
- $this->performRiskyOperation();
772
- } catch (\Throwable $e) {
773
- $this->log->error('Operation failed: ' . $e->getMessage(), [
774
- 'exception' => $e
775
- ]);
776
- throw $e; // Re-throw
777
- }
778
-
779
- // Catch and convert
780
- try {
781
- $result = $this->externalApi->call();
782
- } catch (\GuzzleHttp\Exception\RequestException $e) {
783
- throw new Error('External API failed: ' . $e->getMessage());
784
- }
785
-
786
- // Catch specific, let others propagate
787
- try {
788
- $this->operation();
789
- } catch (NotFound $e) {
790
- // Handle not found specifically
791
- return $this->createDefault();
792
- }
793
- // Other exceptions propagate up
794
- ```
795
-
796
- ## Debugging Checklist
797
-
798
- When something doesn't work:
799
-
800
- 1. **Check Logs**
801
- - `data/logs/espo-YYYY-MM-DD.log`
802
- - PHP error logs
803
-
804
- 2. **Verify Cache Rebuild**
805
- - `bin/command rebuild`
806
-
807
- 3. **Check Permissions**
808
- - File permissions (files should be writable)
809
- - ACL permissions (user has access)
810
-
811
- 4. **Validate Metadata**
812
- - JSON syntax correct
813
- - Required fields present
814
-
815
- 5. **Check Database**
816
- - Table exists
817
- - Columns exist
818
- - Indexes present
819
-
820
- 6. **Test API Directly**
821
- - Use curl or Postman
822
- - Check request/response
823
-
824
- 7. **Enable Debug Mode**
825
- - `'logger' => ['level' => 'DEBUG']`
826
- - `'isDeveloperMode' => true`
827
-
828
- 8. **Use XDebug**
829
- - Set breakpoints
830
- - Step through code
831
- - Inspect variables