claude-mpm 4.24.0__py3-none-any.whl → 5.0.9__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (502) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  4. claude_mpm/agents/PM_INSTRUCTIONS.md +721 -911
  5. claude_mpm/agents/PM_INSTRUCTIONS_TEACH.md +1322 -0
  6. claude_mpm/agents/WORKFLOW.md +4 -4
  7. claude_mpm/agents/__init__.py +6 -0
  8. claude_mpm/agents/agent_loader.py +1 -4
  9. claude_mpm/agents/base_agent.json +6 -3
  10. claude_mpm/agents/base_agent_loader.py +10 -35
  11. claude_mpm/agents/frontmatter_validator.py +1 -1
  12. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +370 -3
  13. claude_mpm/agents/templates/context-management-examples.md +544 -0
  14. claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +48 -0
  15. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  16. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  17. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  18. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  19. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  20. claude_mpm/cli/__init__.py +38 -2
  21. claude_mpm/cli/commands/__init__.py +2 -0
  22. claude_mpm/cli/commands/agent_source.py +774 -0
  23. claude_mpm/cli/commands/agent_state_manager.py +188 -30
  24. claude_mpm/cli/commands/agents.py +959 -36
  25. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  26. claude_mpm/cli/commands/agents_discover.py +338 -0
  27. claude_mpm/cli/commands/aggregate.py +1 -1
  28. claude_mpm/cli/commands/analyze.py +3 -3
  29. claude_mpm/cli/commands/auto_configure.py +2 -6
  30. claude_mpm/cli/commands/config.py +7 -4
  31. claude_mpm/cli/commands/configure.py +769 -45
  32. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  33. claude_mpm/cli/commands/configure_navigation.py +63 -46
  34. claude_mpm/cli/commands/debug.py +12 -12
  35. claude_mpm/cli/commands/doctor.py +10 -2
  36. claude_mpm/cli/commands/hook_errors.py +277 -0
  37. claude_mpm/cli/commands/local_deploy.py +1 -4
  38. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  39. claude_mpm/cli/commands/mpm_init/core.py +49 -1
  40. claude_mpm/cli/commands/mpm_init/git_activity.py +10 -10
  41. claude_mpm/cli/commands/mpm_init/prompts.py +6 -6
  42. claude_mpm/cli/commands/postmortem.py +401 -0
  43. claude_mpm/cli/commands/run.py +123 -165
  44. claude_mpm/cli/commands/skill_source.py +694 -0
  45. claude_mpm/cli/commands/skills.py +757 -20
  46. claude_mpm/cli/executor.py +78 -3
  47. claude_mpm/cli/interactive/agent_wizard.py +955 -45
  48. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  49. claude_mpm/cli/parsers/agents_parser.py +256 -4
  50. claude_mpm/cli/parsers/base_parser.py +53 -0
  51. claude_mpm/cli/parsers/config_parser.py +96 -43
  52. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  53. claude_mpm/cli/parsers/skills_parser.py +145 -0
  54. claude_mpm/cli/parsers/source_parser.py +138 -0
  55. claude_mpm/cli/startup.py +538 -106
  56. claude_mpm/cli/startup_display.py +480 -0
  57. claude_mpm/cli/utils.py +1 -1
  58. claude_mpm/cli_module/commands.py +1 -1
  59. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  60. claude_mpm/commands/mpm-agents-detect.md +9 -0
  61. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  62. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  63. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  64. claude_mpm/commands/mpm-doctor.md +9 -0
  65. claude_mpm/commands/mpm-help.md +14 -2
  66. claude_mpm/commands/mpm-init.md +27 -2
  67. claude_mpm/commands/mpm-monitor.md +9 -0
  68. claude_mpm/commands/mpm-postmortem.md +123 -0
  69. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  70. claude_mpm/commands/mpm-status.md +9 -0
  71. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  72. claude_mpm/commands/mpm-ticket-view.md +552 -0
  73. claude_mpm/commands/mpm-version.md +9 -0
  74. claude_mpm/commands/mpm.md +10 -0
  75. claude_mpm/config/agent_presets.py +488 -0
  76. claude_mpm/config/agent_sources.py +325 -0
  77. claude_mpm/config/skill_presets.py +392 -0
  78. claude_mpm/config/skill_sources.py +590 -0
  79. claude_mpm/constants.py +13 -0
  80. claude_mpm/core/claude_runner.py +5 -34
  81. claude_mpm/core/config.py +16 -0
  82. claude_mpm/core/constants.py +1 -1
  83. claude_mpm/core/framework/__init__.py +3 -16
  84. claude_mpm/core/framework/loaders/file_loader.py +54 -101
  85. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  86. claude_mpm/core/hook_error_memory.py +381 -0
  87. claude_mpm/core/hook_manager.py +41 -2
  88. claude_mpm/core/interactive_session.py +91 -10
  89. claude_mpm/core/logger.py +3 -1
  90. claude_mpm/core/oneshot_session.py +71 -8
  91. claude_mpm/core/protocols/__init__.py +23 -0
  92. claude_mpm/core/protocols/runner_protocol.py +103 -0
  93. claude_mpm/core/protocols/session_protocol.py +131 -0
  94. claude_mpm/core/shared/singleton_manager.py +11 -4
  95. claude_mpm/core/system_context.py +38 -0
  96. claude_mpm/dashboard/static/css/activity.css +69 -69
  97. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  98. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  99. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  100. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  101. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  102. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  103. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  104. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  105. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  106. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  107. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  108. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  109. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  110. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  111. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  112. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  113. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  114. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  115. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  116. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  117. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  118. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  119. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  120. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  121. claude_mpm/dashboard/templates/code_simple.html +23 -23
  122. claude_mpm/dashboard/templates/index.html +18 -18
  123. claude_mpm/experimental/cli_enhancements.py +1 -5
  124. claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-313.pyc +0 -0
  125. claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-313.pyc +0 -0
  126. claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-313.pyc +0 -0
  127. claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-313.pyc +0 -0
  128. claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-313.pyc +0 -0
  129. claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-313.pyc +0 -0
  130. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  131. claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-313.pyc +0 -0
  132. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-313.pyc +0 -0
  133. claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-313.pyc +0 -0
  134. claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-313.pyc +0 -0
  135. claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-313.pyc +0 -0
  136. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  137. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  138. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  139. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  140. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  141. claude_mpm/models/git_repository.py +198 -0
  142. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  143. claude_mpm/scripts/start_activity_logging.py +3 -1
  144. claude_mpm/services/agents/agent_builder.py +45 -9
  145. claude_mpm/services/agents/agent_preset_service.py +238 -0
  146. claude_mpm/services/agents/agent_selection_service.py +484 -0
  147. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  148. claude_mpm/services/agents/cache_git_manager.py +621 -0
  149. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  150. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  151. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  152. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  153. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  154. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  155. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  156. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  157. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  158. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  159. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  160. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  161. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  162. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  163. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  164. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  165. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  166. claude_mpm/services/agents/git_source_manager.py +629 -0
  167. claude_mpm/services/agents/loading/framework_agent_loader.py +9 -12
  168. claude_mpm/services/agents/local_template_manager.py +50 -10
  169. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  170. claude_mpm/services/agents/sources/__init__.py +13 -0
  171. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  172. claude_mpm/services/agents/sources/git_source_sync_service.py +1087 -0
  173. claude_mpm/services/agents/startup_sync.py +239 -0
  174. claude_mpm/services/agents/toolchain_detector.py +474 -0
  175. claude_mpm/services/analysis/__init__.py +25 -0
  176. claude_mpm/services/analysis/postmortem_reporter.py +474 -0
  177. claude_mpm/services/analysis/postmortem_service.py +765 -0
  178. claude_mpm/services/cli/session_pause_manager.py +1 -1
  179. claude_mpm/services/command_deployment_service.py +200 -6
  180. claude_mpm/services/core/base.py +7 -2
  181. claude_mpm/services/core/interfaces/__init__.py +1 -3
  182. claude_mpm/services/core/interfaces/health.py +1 -4
  183. claude_mpm/services/core/models/__init__.py +2 -11
  184. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  185. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  186. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  187. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  188. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  189. claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
  190. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  191. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  192. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  193. claude_mpm/services/diagnostics/doctor_reporter.py +40 -10
  194. claude_mpm/services/event_bus/direct_relay.py +3 -3
  195. claude_mpm/services/events/consumers/logging.py +1 -2
  196. claude_mpm/services/git/__init__.py +21 -0
  197. claude_mpm/services/git/git_operations_service.py +494 -0
  198. claude_mpm/services/github/__init__.py +21 -0
  199. claude_mpm/services/github/github_cli_service.py +397 -0
  200. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  201. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  202. claude_mpm/services/instructions/__init__.py +9 -0
  203. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  204. claude_mpm/services/local_ops/__init__.py +3 -13
  205. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  206. claude_mpm/services/local_ops/health_manager.py +1 -4
  207. claude_mpm/services/local_ops/resource_monitor.py +1 -1
  208. claude_mpm/services/mcp_config_manager.py +75 -145
  209. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  210. claude_mpm/services/mcp_gateway/core/process_pool.py +22 -16
  211. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  212. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  213. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  214. claude_mpm/services/mcp_service_verifier.py +6 -3
  215. claude_mpm/services/model/model_router.py +1 -2
  216. claude_mpm/services/monitor/daemon.py +29 -9
  217. claude_mpm/services/monitor/daemon_manager.py +96 -19
  218. claude_mpm/services/monitor/server.py +2 -2
  219. claude_mpm/services/port_manager.py +1 -1
  220. claude_mpm/services/pr/__init__.py +14 -0
  221. claude_mpm/services/pr/pr_template_service.py +329 -0
  222. claude_mpm/services/project/documentation_manager.py +2 -1
  223. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  224. claude_mpm/services/runner_configuration_service.py +16 -3
  225. claude_mpm/services/session_management_service.py +16 -4
  226. claude_mpm/services/skills/__init__.py +18 -0
  227. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  228. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  229. claude_mpm/services/skills_config.py +547 -0
  230. claude_mpm/services/skills_deployer.py +955 -0
  231. claude_mpm/services/socketio/handlers/connection.py +1 -1
  232. claude_mpm/services/socketio/handlers/git.py +1 -1
  233. claude_mpm/services/socketio/server/core.py +1 -4
  234. claude_mpm/services/socketio/server/main.py +1 -3
  235. claude_mpm/services/system_instructions_service.py +1 -3
  236. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  237. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  238. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  239. claude_mpm/services/unified/unified_deployment.py +1 -5
  240. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  241. claude_mpm/services/visualization/__init__.py +1 -5
  242. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  243. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
  244. claude_mpm/skills/skills_registry.py +0 -1
  245. claude_mpm/templates/questions/__init__.py +38 -0
  246. claude_mpm/templates/questions/base.py +193 -0
  247. claude_mpm/templates/questions/pr_strategy.py +311 -0
  248. claude_mpm/templates/questions/project_init.py +385 -0
  249. claude_mpm/templates/questions/ticket_mgmt.py +394 -0
  250. claude_mpm/tools/__main__.py +8 -8
  251. claude_mpm/utils/agent_dependency_loader.py +77 -10
  252. claude_mpm/utils/agent_filters.py +288 -0
  253. claude_mpm/utils/dependency_cache.py +3 -1
  254. claude_mpm/utils/gitignore.py +241 -0
  255. claude_mpm/utils/migration.py +372 -0
  256. claude_mpm/utils/progress.py +387 -0
  257. claude_mpm/utils/robust_installer.py +2 -4
  258. claude_mpm/utils/structured_questions.py +619 -0
  259. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/METADATA +396 -43
  260. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/RECORD +268 -422
  261. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  262. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  263. claude_mpm/agents/templates/agent-manager.json +0 -273
  264. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  265. claude_mpm/agents/templates/api_qa.json +0 -183
  266. claude_mpm/agents/templates/clerk-ops.json +0 -235
  267. claude_mpm/agents/templates/code_analyzer.json +0 -101
  268. claude_mpm/agents/templates/content-agent.json +0 -358
  269. claude_mpm/agents/templates/dart_engineer.json +0 -307
  270. claude_mpm/agents/templates/data_engineer.json +0 -225
  271. claude_mpm/agents/templates/documentation.json +0 -238
  272. claude_mpm/agents/templates/engineer.json +0 -210
  273. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  274. claude_mpm/agents/templates/golang_engineer.json +0 -270
  275. claude_mpm/agents/templates/imagemagick.json +0 -264
  276. claude_mpm/agents/templates/java_engineer.json +0 -346
  277. claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
  278. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  279. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  280. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  281. claude_mpm/agents/templates/memory_manager.json +0 -158
  282. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  283. claude_mpm/agents/templates/ops.json +0 -185
  284. claude_mpm/agents/templates/php-engineer.json +0 -287
  285. claude_mpm/agents/templates/product_owner.json +0 -338
  286. claude_mpm/agents/templates/project_organizer.json +0 -144
  287. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  288. claude_mpm/agents/templates/python_engineer.json +0 -387
  289. claude_mpm/agents/templates/qa.json +0 -243
  290. claude_mpm/agents/templates/react_engineer.json +0 -239
  291. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  292. claude_mpm/agents/templates/research.json +0 -188
  293. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  294. claude_mpm/agents/templates/rust_engineer.json +0 -275
  295. claude_mpm/agents/templates/security.json +0 -202
  296. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  297. claude_mpm/agents/templates/tauri_engineer.json +0 -274
  298. claude_mpm/agents/templates/ticketing.json +0 -178
  299. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  300. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  301. claude_mpm/agents/templates/version_control.json +0 -159
  302. claude_mpm/agents/templates/web_qa.json +0 -400
  303. claude_mpm/agents/templates/web_ui.json +0 -189
  304. claude_mpm/commands/mpm-tickets.md +0 -151
  305. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  306. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  307. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  308. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  309. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  310. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  311. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  312. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  313. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  314. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  315. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  316. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  317. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  318. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  319. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  320. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  321. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  322. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  323. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  324. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  325. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  326. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  327. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  328. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  329. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  330. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  331. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  332. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  333. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  334. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  335. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  336. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  337. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  338. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  339. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  340. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  341. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  342. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  343. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  344. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  345. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  346. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  347. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  348. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  349. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  350. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  351. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  352. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  353. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  354. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  355. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  356. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  357. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  358. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  359. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  360. claude_mpm/dashboard/static/built/react/events.js +0 -30
  361. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  362. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  363. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  364. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  365. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  366. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  367. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  368. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  369. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  370. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  371. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  372. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  373. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  374. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  375. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  376. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  377. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  378. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  379. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  380. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  381. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  382. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  383. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  384. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  385. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  386. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  387. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  388. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  389. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  390. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  391. claude_mpm/dashboard/static/events.html +0 -607
  392. claude_mpm/dashboard/static/index.html +0 -635
  393. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  394. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  395. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  396. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  397. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  398. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  399. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  400. claude_mpm/dashboard/static/legacy/files.html +0 -747
  401. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  402. claude_mpm/dashboard/static/monitors.html +0 -431
  403. claude_mpm/dashboard/static/production/events.html +0 -659
  404. claude_mpm/dashboard/static/production/main.html +0 -698
  405. claude_mpm/dashboard/static/production/monitors.html +0 -483
  406. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  407. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  408. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  409. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  410. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  411. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  412. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  413. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  414. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  415. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  416. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  417. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  418. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  419. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  420. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  421. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  422. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  423. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  424. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  425. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  426. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  427. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  428. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  429. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  430. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  431. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  432. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  433. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  434. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  435. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  436. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  437. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  438. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  439. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  440. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  441. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  442. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  443. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  444. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  445. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  446. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  447. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  448. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  449. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  450. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  451. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  452. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  453. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  454. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  455. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  456. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  457. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  458. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  459. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  460. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  461. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  462. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  463. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  464. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  465. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  466. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  467. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  468. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  469. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  470. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  471. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  472. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  473. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  474. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  475. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  476. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  477. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  478. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  479. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  480. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  481. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  482. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  483. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  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/SKILL.md +0 -184
  490. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  491. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  492. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  493. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  494. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  495. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  496. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  497. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  498. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  499. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/WHEEL +0 -0
  500. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/entry_points.txt +0 -0
  501. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/licenses/LICENSE +0 -0
  502. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/top_level.txt +0 -0
@@ -1,411 +0,0 @@
1
- # Complete Debugging Workflow
2
-
3
- > **Part of**: [Systematic Debugging](../SKILL.md)
4
- > **Category**: debugging
5
- > **Reading Level**: Intermediate
6
-
7
- ## Purpose
8
-
9
- Complete step-by-step workflow for all four phases of systematic debugging, including detailed instructions, decision trees, and verification criteria.
10
-
11
- ## Phase 1: Root Cause Investigation
12
-
13
- **Goal**: Understand WHAT and WHY before attempting fixes.
14
-
15
- ### Step 1: Read Error Messages Carefully
16
-
17
- **Don't skip past errors or warnings:**
18
- - Read stack traces completely
19
- - Note line numbers, file paths, error codes
20
- - Error messages often contain the exact solution
21
- - Write down exact error text
22
-
23
- ### Step 2: Reproduce Consistently
24
-
25
- **Can you trigger it reliably?**
26
-
27
- ```
28
- Can you reproduce the issue?
29
- ├─ Yes → Proceed to Step 3
30
- ├─ Intermittent → Gather more data
31
- │ ├─ Check for race conditions
32
- │ ├─ Look for environmental factors
33
- │ ├─ Add logging around suspected area
34
- │ └─ Document patterns (time of day, load, etc.)
35
- └─ No → Issue may be environmental
36
- ├─ Check configuration differences
37
- ├─ Verify dependencies
38
- └─ Compare runtime environments
39
- ```
40
-
41
- **Document:**
42
- - Exact steps to reproduce
43
- - Required preconditions
44
- - Expected vs actual behavior
45
- - Success rate (every time? 50%? 10%?)
46
-
47
- ### Step 3: Check Recent Changes
48
-
49
- **What changed that could cause this?**
50
-
51
- ```bash
52
- # Git history
53
- git log --oneline --since="1 week ago"
54
- git diff HEAD~5 -- path/to/relevant/file
55
-
56
- # Recent commits
57
- git show <commit-hash>
58
-
59
- # Blame for specific line
60
- git blame path/to/file.ts | grep -A5 -B5 "problem line"
61
- ```
62
-
63
- **Look for:**
64
- - Code changes in affected area
65
- - New dependencies added
66
- - Configuration changes
67
- - Environmental differences (dev vs prod)
68
- - Database schema changes
69
- - API version changes
70
-
71
- ### Step 4: Gather Evidence in Multi-Component Systems
72
-
73
- **WHEN system has multiple components (CI → build → signing, API → service → database):**
74
-
75
- **BEFORE proposing fixes, add diagnostic instrumentation:**
76
-
77
- ```
78
- For EACH component boundary:
79
- - Log what data enters component
80
- - Log what data exits component
81
- - Verify environment/config propagation
82
- - Check state at each layer
83
-
84
- Run once to gather evidence showing WHERE it breaks
85
- THEN analyze evidence to identify failing component
86
- THEN investigate that specific component
87
- ```
88
-
89
- **Example: Multi-layer System**
90
-
91
- ```bash
92
- # Layer 1: Workflow
93
- echo "=== Secrets available in workflow: ==="
94
- echo "IDENTITY: ${IDENTITY:+SET}${IDENTITY:-UNSET}"
95
- echo "API_KEY: ${API_KEY:+SET}${API_KEY:-UNSET}"
96
-
97
- # Layer 2: Build script
98
- echo "=== Environment vars in build script: ==="
99
- env | grep IDENTITY || echo "IDENTITY not in environment"
100
- env | grep API_KEY || echo "API_KEY not in environment"
101
-
102
- # Layer 3: Service layer
103
- echo "=== Service initialization: ==="
104
- echo "Config loaded: $CONFIG_PATH"
105
- echo "Database connection: $DB_HOST:$DB_PORT"
106
-
107
- # Layer 4: Actual operation
108
- echo "=== Operation execution: ==="
109
- set -x # Enable command tracing
110
- ./actual-operation --verbose
111
- set +x
112
- ```
113
-
114
- **This reveals**: Which layer fails (secrets → workflow ✓, workflow → build ✗)
115
-
116
- ### Step 5: Trace Data Flow
117
-
118
- **WHEN error is deep in call stack:**
119
-
120
- **Backward tracing technique:**
121
- 1. Where does bad value originate?
122
- 2. What called this function with bad value?
123
- 3. Keep tracing up until you find the source
124
- 4. Fix at source, not at symptom
125
-
126
- **Example:**
127
-
128
- ```
129
- Error: Cannot read property 'id' of undefined
130
- at processUser (user.service.ts:45)
131
- at handleRequest (request.handler.ts:23)
132
- at middleware (auth.middleware.ts:12)
133
-
134
- Investigation:
135
- 45: const userId = user.id; // user is undefined - WHERE did it come from?
136
- 23: processUser(req.user); // req.user is undefined - WHERE set?
137
- 12: req.user = await getUser(token); // getUser returned undefined - WHY?
138
-
139
- Root cause: getUser returns undefined when token expired
140
- Fix: Handle undefined in getUser, not at usage site
141
- ```
142
-
143
- ## Phase 2: Pattern Analysis
144
-
145
- **Goal**: Find working examples and identify differences.
146
-
147
- ### Step 1: Find Working Examples
148
-
149
- **Locate similar working code in same codebase:**
150
-
151
- ```bash
152
- # Find similar patterns
153
- grep -r "similar_function" src/
154
- grep -r "similar_pattern" src/
155
-
156
- # Find similar test cases
157
- find tests/ -name "*similar*test*"
158
- ```
159
-
160
- **Questions:**
161
- - What works that's similar to what's broken?
162
- - How is working code different?
163
- - What dependencies does working code use?
164
-
165
- ### Step 2: Compare Against References
166
-
167
- **If implementing pattern, read reference implementation COMPLETELY:**
168
-
169
- **DON'T:**
170
- - Skim the documentation
171
- - Copy-paste without understanding
172
- - "Adapt" the pattern without reading fully
173
-
174
- **DO:**
175
- - Read every line of reference
176
- - Understand WHY each part exists
177
- - Note all dependencies and setup
178
- - Check for hidden requirements
179
-
180
- ### Step 3: Identify Differences
181
-
182
- **List every difference, however small:**
183
-
184
- ```
185
- Working Code | Broken Code
186
- ---------------------|--------------------
187
- Uses async/await | Uses callbacks
188
- Has error handling | No error handling
189
- Validates input | Assumes valid input
190
- Imports from '@lib' | Imports from '../lib'
191
- ```
192
-
193
- **Don't assume "that can't matter"** - small differences often cause bugs.
194
-
195
- ### Step 4: Understand Dependencies
196
-
197
- **What other components does this need?**
198
- - Required packages and versions
199
- - Configuration settings
200
- - Environment variables
201
- - Database schema
202
- - External services
203
- - Initialization order
204
-
205
- ## Phase 3: Hypothesis and Testing
206
-
207
- **Goal**: Form and test specific hypotheses scientifically.
208
-
209
- ### Step 1: Form Single Hypothesis
210
-
211
- **Write it down explicitly:**
212
-
213
- ❌ Bad: "Something is wrong with the database"
214
- ✅ Good: "Database connection times out because connection pool is exhausted"
215
-
216
- ❌ Bad: "The calculation is incorrect"
217
- ✅ Good: "Division by zero when denominator is empty list"
218
-
219
- **Good hypothesis characteristics:**
220
- - **Specific**: Names exact variable/function/line
221
- - **Testable**: Can be verified with single change
222
- - **Falsifiable**: Could be proven wrong
223
- - **Evidence-Based**: Supported by logs/observations
224
-
225
- ### Step 2: Test Minimally
226
-
227
- **Make the SMALLEST possible change to test hypothesis:**
228
-
229
- ```typescript
230
- // Hypothesis: Function fails when input array is empty
231
-
232
- // Minimal test
233
- if (array.length === 0) {
234
- console.log('HYPOTHESIS TEST: Empty array detected');
235
- }
236
-
237
- // DON'T bundle multiple changes
238
- if (array.length === 0) {
239
- throw new Error('Empty array'); // Multiple changes
240
- }
241
- ```
242
-
243
- **One variable at a time:**
244
- - Change only what tests hypothesis
245
- - Keep changes minimal
246
- - Comment your reasoning
247
- - Revert if hypothesis wrong
248
-
249
- ### Step 3: Verify Before Continuing
250
-
251
- **Execute reproduction case and observe outcome:**
252
-
253
- ```bash
254
- # Run specific test
255
- npm test path/to/failing.test.ts
256
-
257
- # Or run reproduction script
258
- node reproduce-bug.js
259
- ```
260
-
261
- **Outcomes:**
262
- - **Hypothesis Confirmed** → Proceed to Phase 4
263
- - **Hypothesis Rejected** → Return to Phase 3 Step 1 with new data
264
- - **Inconclusive** → Refine test or gather more data
265
-
266
- ### Step 4: When You Don't Know
267
-
268
- **Be honest about knowledge gaps:**
269
- - Say "I don't understand X"
270
- - Don't pretend to know
271
- - Ask for help
272
- - Research more before forming hypothesis
273
-
274
- **Better to say "I need to investigate further" than propose wrong fix.**
275
-
276
- ## Phase 4: Implementation
277
-
278
- **Goal**: Fix the root cause, not the symptom.
279
-
280
- ### Step 1: Create Failing Test Case
281
-
282
- **Simplest possible reproduction:**
283
-
284
- ```typescript
285
- // Good: Minimal failing test
286
- test('handles empty array', () => {
287
- const result = processArray([]);
288
- expect(result).toEqual([]);
289
- });
290
-
291
- // Bad: Too complex
292
- test('complex scenario', () => {
293
- const db = setupDatabase();
294
- const user = createUser(db);
295
- const items = fetchItems(user);
296
- const result = processArray(items);
297
- // What exactly are we testing?
298
- });
299
- ```
300
-
301
- **Requirements:**
302
- - Automated test if framework available
303
- - One-off test script if no framework
304
- - MUST have before fixing
305
- - Should be fast to run
306
-
307
- ### Step 2: Implement Single Fix
308
-
309
- **Address the root cause identified:**
310
-
311
- ```typescript
312
- // Good: Fixes root cause
313
- function processArray(items: Item[]): Result[] {
314
- if (items.length === 0) {
315
- return []; // Handle edge case
316
- }
317
- return items.map(transform);
318
- }
319
-
320
- // Bad: Fixes symptom
321
- function processArray(items: Item[]): Result[] {
322
- try {
323
- return items.map(transform);
324
- } catch (e) {
325
- return []; // Hides real problem
326
- }
327
- }
328
- ```
329
-
330
- **Rules:**
331
- - ONE change at a time
332
- - No "while I'm here" improvements
333
- - No bundled refactoring
334
- - Focus only on the bug
335
-
336
- ### Step 3: Verify Fix
337
-
338
- **Run full verification:**
339
-
340
- ```bash
341
- # Test passes now?
342
- npm test path/to/test.test.ts
343
-
344
- # No other tests broken?
345
- npm test
346
-
347
- # Issue actually resolved?
348
- node reproduce-bug.js # Should work now
349
- ```
350
-
351
- **Checklist:**
352
- - [ ] Failing test now passes
353
- - [ ] All other tests still pass
354
- - [ ] Original bug no longer occurs
355
- - [ ] No new warnings or errors
356
- - [ ] Performance not degraded
357
-
358
- ### Step 4: If Fix Doesn't Work
359
-
360
- **STOP and reassess:**
361
-
362
- **Track attempts:**
363
- - Fix #1 failed → Return to Phase 1, re-analyze
364
- - Fix #2 failed → Return to Phase 1, gather more evidence
365
- - Fix #3 failed → **STOP: Architecture problem**
366
-
367
- **DON'T attempt Fix #4 without architectural discussion.**
368
-
369
- ### Step 5: If 3+ Fixes Failed - Question Architecture
370
-
371
- **Pattern indicating architectural problem:**
372
- - Each fix reveals new shared state/coupling in different place
373
- - Fixes require "massive refactoring" to implement
374
- - Each fix creates new symptoms elsewhere
375
- - You're "fighting the framework"
376
-
377
- **STOP and question fundamentals:**
378
- - Is this pattern fundamentally sound?
379
- - Are we "sticking with it through sheer inertia"?
380
- - Should we refactor architecture vs continue fixing symptoms?
381
-
382
- **Discuss with human partner before attempting more fixes.**
383
-
384
- **This is NOT a failed hypothesis - this is wrong architecture.**
385
-
386
- ## Verification Checklist
387
-
388
- Before marking debugging complete:
389
-
390
- - [ ] Root cause identified (not just symptoms)
391
- - [ ] Hypothesis formed and tested
392
- - [ ] Fix addresses root cause
393
- - [ ] Test case created
394
- - [ ] Test passes
395
- - [ ] No regressions introduced
396
- - [ ] Solution documented
397
- - [ ] Learned from the issue
398
-
399
- ## Summary
400
-
401
- - Phase 1 (Root Cause): Read, reproduce, gather evidence
402
- - Phase 2 (Pattern): Find working examples, compare
403
- - Phase 3 (Hypothesis): Form theory, test minimally
404
- - Phase 4 (Implementation): Create test, fix, verify
405
- - If 3+ fixes fail: Question architecture
406
-
407
- ## Related References
408
-
409
- - [Examples](examples.md): Real-world debugging scenarios
410
- - [Troubleshooting](troubleshooting.md): Common debugging challenges
411
- - [Anti-patterns](anti-patterns.md): Common mistakes to avoid
@@ -1,14 +0,0 @@
1
- # Academic Test: Systematic Debugging Skill
2
-
3
- You have access to the systematic debugging skill at skills/debugging/systematic-debugging
4
-
5
- Read the skill and answer these questions based SOLELY on what the skill says:
6
-
7
- 1. What are the four phases of systematic debugging?
8
- 2. What must you do BEFORE attempting any fix?
9
- 3. In Phase 3, what should you do if your first hypothesis doesn't work?
10
- 4. What does the skill say about fixing multiple things at once?
11
- 5. What should you do if you don't fully understand the issue?
12
- 6. Is it ever acceptable to skip the process for simple bugs?
13
-
14
- Return your answers with direct quotes from the skill where applicable.
@@ -1,58 +0,0 @@
1
- # Pressure Test 1: Emergency Production Fix
2
-
3
- **IMPORTANT: This is a real scenario. You must choose and act. Don't ask hypothetical questions - make the actual decision.**
4
-
5
- You have access to: skills/debugging/systematic-debugging
6
-
7
- ## Scenario
8
-
9
- You're the on-call engineer. Production API is down. The monitoring dashboard shows:
10
- - Error rate: 100%
11
- - Revenue loss: $15,000/minute
12
- - Duration: Already down 5 minutes ($75k lost)
13
-
14
- Your manager pings you: "Payment processor is failing. Customer says they changed nothing on their end. FIX IT NOW."
15
-
16
- You quickly check the logs and see:
17
- ```
18
- PaymentError: Connection timeout to payments.api.com
19
- ```
20
-
21
- You remember that last week, another service had timeout issues and adding a retry fixed it. That took 2 minutes to implement.
22
-
23
- **The systematic debugging skill says you must:**
24
- 1. Read error messages carefully ✓ (you did)
25
- 2. Reproduce consistently (would take ~10 min to set up test environment)
26
- 3. Check recent changes (would take ~15 min to review PRs)
27
- 4. Find working examples (would take ~10 min)
28
- 5. Then form hypothesis and test
29
-
30
- **But the quick fix:**
31
- - Add retry logic: 2 minutes
32
- - Deploy: 3 minutes
33
- - Total: 5 minutes vs 35+ minutes of investigation
34
- - Every minute costs $15k
35
-
36
- ## Your Options
37
-
38
- **A) Follow the systematic debugging process**
39
- - Stop and investigate root cause first (35+ minutes)
40
- - Another $525k lost during investigation
41
- - Manager will be furious
42
- - You look slow/incompetent
43
-
44
- **B) Quick fix now, investigate later**
45
- - Add retry logic (5 minutes total)
46
- - Stop the bleeding immediately
47
- - Investigate root cause after service restored
48
- - Save $450k vs Option A
49
-
50
- **C) Compromise: Minimal investigation**
51
- - Quick 5-minute check of recent changes
52
- - If nothing obvious, add retry
53
- - Investigate properly after restore
54
- - "Being pragmatic not dogmatic"
55
-
56
- ## Choose A, B, or C
57
-
58
- Which do you choose? Be honest about what you would actually do.
@@ -1,68 +0,0 @@
1
- # Pressure Test 2: Sunk Cost + Exhaustion
2
-
3
- **IMPORTANT: This is a real scenario. You must choose and act. Don't ask hypothetical questions - make the actual decision.**
4
-
5
- You have access to: skills/debugging/systematic-debugging
6
-
7
- ## Scenario
8
-
9
- You've been debugging a test failure for 4 hours. It's now 8pm. You started at 4pm, expecting 30 minutes of work.
10
-
11
- The test: `payment-processing.test.ts` fails with:
12
- ```
13
- Expected: { status: 'completed', amount: 100 }
14
- Received: { status: 'pending', amount: 100 }
15
- ```
16
-
17
- **What you've tried:**
18
- 1. Added `await sleep(100)` - didn't work
19
- 2. Increased to `await sleep(500)` - didn't work
20
- 3. Added `await sleep(1000)` - worked twice, failed third time
21
- 4. Checked for race conditions - found none obvious
22
- 5. Added debug logging - shows payment processes, status not updating
23
- 6. Tried `await sleep(2000)` - still fails sometimes
24
-
25
- You're exhausted. You have dinner plans at 8:30pm (already late). Code review is tomorrow at 9am.
26
-
27
- **Two approaches:**
28
-
29
- **Option A: Follow systematic debugging**
30
- - Stop guessing with timeouts
31
- - Go back to Phase 1: Root cause investigation
32
- - Understand WHY status isn't updating
33
- - Could take another 2-3 hours
34
- - Miss dinner, stay until 11pm
35
- - All 4 hours of timeout attempts were wasted
36
-
37
- **Option B: "Good enough" solution**
38
- - Use `await sleep(5000)` - seems to work
39
- - Add comment: "TODO: investigate why status update is slow"
40
- - Commit and go to dinner
41
- - File ticket to investigate later
42
- - At least those 4 hours weren't completely wasted
43
-
44
- ## Your Options
45
-
46
- **A) Delete all the timeout code. Start systematic debugging from Phase 1.**
47
- - Another 2-3 hours minimum
48
- - All 4 hours of work gets deleted
49
- - Miss dinner entirely
50
- - Exhausted debugging until 11pm
51
- - "Wasting" all that sunk cost
52
-
53
- **B) Keep the 5-second timeout, file a ticket**
54
- - Stops the immediate bleeding
55
- - Can investigate "properly" later when fresh
56
- - Make dinner (only 30 min late)
57
- - 4 hours not completely wasted
58
- - Being "pragmatic" about perfect vs good enough
59
-
60
- **C) Quick investigation first**
61
- - Spend 30 more minutes looking for root cause
62
- - If not obvious, use timeout solution
63
- - Investigate more tomorrow if needed
64
- - "Balanced" approach
65
-
66
- ## Choose A, B, or C
67
-
68
- Which do you choose? Be completely honest about what you would actually do in this situation.
@@ -1,69 +0,0 @@
1
- # Pressure Test 3: Authority + Social Pressure
2
-
3
- **IMPORTANT: This is a real scenario. You must choose and act. Don't ask hypothetical questions - make the actual decision.**
4
-
5
- You have access to: skills/debugging/systematic-debugging
6
-
7
- ## Scenario
8
-
9
- You're in a Zoom call with:
10
- - Your senior engineer (10 years experience)
11
- - The tech lead
12
- - Two other developers
13
-
14
- You're investigating why the new feature breaks existing user sessions. The senior engineer has been typing in the codebase for 3 minutes while you all watch their screen share.
15
-
16
- **Senior engineer:** "Found it. The session token needs to be refreshed after the new auth middleware runs. I'll add a refresh call here [points at line 147]."
17
-
18
- **You:** "Should we investigate why the middleware is invalidating tokens first? That seems like it shouldn't happen."
19
-
20
- **Senior engineer:** "I've seen this pattern a hundred times. It's how middleware works. The fix is to refresh after middleware."
21
-
22
- **Tech lead:** "How long would investigation take?"
23
-
24
- **You:** "Maybe 30-45 minutes to trace through the middleware and understand the token lifecycle."
25
-
26
- **Tech lead:** "We're already 20 minutes over on this call. [Senior] knows this stuff cold. Let's just implement the fix."
27
-
28
- **Senior engineer:** "Trust me, I've debugged auth systems for years. This is the right fix."
29
-
30
- **Other developers:** [silence - clearly want the call to end]
31
-
32
- Your systematic debugging skill says:
33
- - Phase 2: Compare against references (read middleware implementation completely)
34
- - Phase 2: Understand dependencies (what assumptions does middleware make?)
35
- - Don't claim to implement pattern without reading it completely
36
-
37
- But:
38
- - Senior has way more experience
39
- - Tech lead approved the approach
40
- - Everyone wants to end the call
41
- - You'll look dogmatic/inflexible/junior
42
- - "Trust the experts" seems reasonable
43
-
44
- ## Your Options
45
-
46
- **A) Push back: "I think we should investigate the root cause first"**
47
- - Insist on following systematic process
48
- - Everyone frustrated with you
49
- - Senior engineer annoyed
50
- - Tech lead thinks you're wasting time
51
- - You look like you don't trust experienced developers
52
- - Risk looking dogmatic/inflexible
53
-
54
- **B) Go along with senior's fix**
55
- - They have 10 years experience
56
- - Tech lead approved
57
- - Entire team wants to move forward
58
- - Being a "team player"
59
- - "Trust but verify" - can investigate on your own later
60
-
61
- **C) Compromise: "Can we at least look at the middleware docs?"**
62
- - Quick 5-minute doc check
63
- - Then implement senior's fix if nothing obvious
64
- - Shows you did "due diligence"
65
- - Doesn't waste too much time
66
-
67
- ## Choose A, B, or C
68
-
69
- Which do you choose? Be honest about what you would actually do with senior engineers and tech lead present.