@trieungoctam/vibekit 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (352) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +85 -0
  3. package/agents/debugger.md +158 -0
  4. package/agents/docs-manager.md +220 -0
  5. package/agents/planner.md +129 -0
  6. package/agents/researcher.md +58 -0
  7. package/agents/reviewer.md +152 -0
  8. package/agents/tester.md +126 -0
  9. package/bin/vibekit.js +18 -0
  10. package/hooks/lib/ck-config-utils.cjs +831 -0
  11. package/hooks/lib/colors.cjs +95 -0
  12. package/hooks/lib/config-counter.cjs +103 -0
  13. package/hooks/lib/context-builder.cjs +616 -0
  14. package/hooks/lib/git-info-cache.cjs +143 -0
  15. package/hooks/lib/hook-logger.cjs +92 -0
  16. package/hooks/lib/privacy-checker.cjs +297 -0
  17. package/hooks/lib/project-detector.cjs +474 -0
  18. package/hooks/lib/scout-checker.cjs +263 -0
  19. package/hooks/lib/transcript-parser.cjs +181 -0
  20. package/hooks/post-edit-simplify-reminder.cjs +156 -0
  21. package/hooks/privacy-block.cjs +166 -0
  22. package/hooks/scout-block.cjs +147 -0
  23. package/hooks/session-init.cjs +360 -0
  24. package/package.json +41 -0
  25. package/rules/development-rules.md +52 -0
  26. package/rules/documentation-management.md +121 -0
  27. package/rules/orchestration-protocol.md +43 -0
  28. package/rules/primary-workflow.md +57 -0
  29. package/rules/team-coordination-rules.md +90 -0
  30. package/skills/ai/agent-browser/SKILL.md +294 -0
  31. package/skills/ai/agent-browser/references/.gitkeep +0 -0
  32. package/skills/ai/agent-browser/references/agent-browser-vs-chrome-devtools.md +112 -0
  33. package/skills/ai/agent-browser/references/browserbase-cloud-setup.md +161 -0
  34. package/skills/ai/ai-artist/SKILL.md +122 -0
  35. package/skills/ai/ai-artist/data/awesome-prompts.csv +3592 -0
  36. package/skills/ai/ai-artist/data/lighting.csv +19 -0
  37. package/skills/ai/ai-artist/data/nano-banana-templates.csv +17 -0
  38. package/skills/ai/ai-artist/data/platforms.csv +11 -0
  39. package/skills/ai/ai-artist/data/styles.csv +26 -0
  40. package/skills/ai/ai-artist/data/techniques.csv +19 -0
  41. package/skills/ai/ai-artist/data/use-cases.csv +16 -0
  42. package/skills/ai/ai-artist/references/advanced-techniques.md +184 -0
  43. package/skills/ai/ai-artist/references/awesome-nano-banana-pro-prompts.md +8575 -0
  44. package/skills/ai/ai-artist/references/domain-code.md +66 -0
  45. package/skills/ai/ai-artist/references/domain-data.md +72 -0
  46. package/skills/ai/ai-artist/references/domain-marketing.md +66 -0
  47. package/skills/ai/ai-artist/references/domain-patterns.md +33 -0
  48. package/skills/ai/ai-artist/references/domain-writing.md +68 -0
  49. package/skills/ai/ai-artist/references/image-prompting.md +141 -0
  50. package/skills/ai/ai-artist/references/llm-prompting.md +165 -0
  51. package/skills/ai/ai-artist/references/nano-banana.md +136 -0
  52. package/skills/ai/ai-artist/references/reasoning-techniques.md +201 -0
  53. package/skills/ai/ai-artist/references/validation-workflow.md +117 -0
  54. package/skills/ai/ai-artist/scripts/core.py +197 -0
  55. package/skills/ai/ai-artist/scripts/extract_prompts.py +102 -0
  56. package/skills/ai/ai-artist/scripts/generate.py +370 -0
  57. package/skills/ai/ai-artist/scripts/search.py +147 -0
  58. package/skills/ai/ai-multimodal/.env.example +204 -0
  59. package/skills/ai/ai-multimodal/SKILL.md +110 -0
  60. package/skills/ai/ai-multimodal/references/audio-processing.md +387 -0
  61. package/skills/ai/ai-multimodal/references/image-generation.md +939 -0
  62. package/skills/ai/ai-multimodal/references/music-generation.md +311 -0
  63. package/skills/ai/ai-multimodal/references/video-analysis.md +515 -0
  64. package/skills/ai/ai-multimodal/references/video-generation.md +457 -0
  65. package/skills/ai/ai-multimodal/references/vision-understanding.md +492 -0
  66. package/skills/ai/ai-multimodal/scripts/.coverage +0 -0
  67. package/skills/ai/ai-multimodal/scripts/check_setup.py +315 -0
  68. package/skills/ai/ai-multimodal/scripts/document_converter.py +395 -0
  69. package/skills/ai/ai-multimodal/scripts/gemini_batch_process.py +1185 -0
  70. package/skills/ai/ai-multimodal/scripts/media_optimizer.py +506 -0
  71. package/skills/ai/ai-multimodal/scripts/requirements.txt +26 -0
  72. package/skills/ai/ai-multimodal/scripts/tests/.coverage +0 -0
  73. package/skills/ai/ai-multimodal/scripts/tests/requirements.txt +20 -0
  74. package/skills/ai/ai-multimodal/scripts/tests/test_document_converter.py +74 -0
  75. package/skills/ai/ai-multimodal/scripts/tests/test_gemini_batch_process.py +362 -0
  76. package/skills/ai/ai-multimodal/scripts/tests/test_media_optimizer.py +373 -0
  77. package/skills/ai/mcp-management/README.md +219 -0
  78. package/skills/ai/mcp-management/SKILL.md +210 -0
  79. package/skills/ai/mcp-management/assets/tools.json +3146 -0
  80. package/skills/ai/mcp-management/references/configuration.md +114 -0
  81. package/skills/ai/mcp-management/references/gemini-cli-integration.md +221 -0
  82. package/skills/ai/mcp-management/references/mcp-protocol.md +116 -0
  83. package/skills/ai/mcp-management/scripts/.env.example +10 -0
  84. package/skills/ai/mcp-management/scripts/cli.ts +195 -0
  85. package/skills/ai/mcp-management/scripts/dist/analyze-tools.js +70 -0
  86. package/skills/ai/mcp-management/scripts/dist/cli.js +160 -0
  87. package/skills/ai/mcp-management/scripts/dist/mcp-client.js +183 -0
  88. package/skills/ai/mcp-management/scripts/mcp-client.ts +230 -0
  89. package/skills/ai/mcp-management/scripts/package.json +20 -0
  90. package/skills/ai/mcp-management/scripts/tsconfig.json +15 -0
  91. package/skills/core/brainstorm/SKILL.md +164 -0
  92. package/skills/core/brainstorm/scripts/frame-template.html +214 -0
  93. package/skills/core/brainstorm/scripts/helper.js +88 -0
  94. package/skills/core/brainstorm/scripts/server.cjs +338 -0
  95. package/skills/core/brainstorm/scripts/start-server.sh +153 -0
  96. package/skills/core/brainstorm/scripts/stop-server.sh +55 -0
  97. package/skills/core/brainstorm/spec-document-reviewer-prompt.md +49 -0
  98. package/skills/core/brainstorm/visual-companion.md +286 -0
  99. package/skills/core/code-review/SKILL.md +147 -0
  100. package/skills/core/code-review/references/code-review-reception.md +113 -0
  101. package/skills/core/code-review/references/codebase-scan-workflow.md +29 -0
  102. package/skills/core/code-review/references/edge-case-scouting.md +119 -0
  103. package/skills/core/code-review/references/parallel-review-workflow.md +69 -0
  104. package/skills/core/code-review/references/requesting-code-review.md +116 -0
  105. package/skills/core/code-review/references/task-management-reviews.md +140 -0
  106. package/skills/core/code-review/references/verification-before-completion.md +139 -0
  107. package/skills/core/cook/README.md +86 -0
  108. package/skills/core/cook/SKILL.md +113 -0
  109. package/skills/core/cook/references/intent-detection.md +101 -0
  110. package/skills/core/cook/references/review-cycle.md +75 -0
  111. package/skills/core/cook/references/subagent-patterns.md +75 -0
  112. package/skills/core/cook/references/workflow-steps.md +172 -0
  113. package/skills/core/debug/SKILL.md +121 -0
  114. package/skills/core/debug/references/defense-in-depth.md +124 -0
  115. package/skills/core/debug/references/frontend-verification.md +103 -0
  116. package/skills/core/debug/references/investigation-methodology.md +101 -0
  117. package/skills/core/debug/references/log-and-ci-analysis.md +97 -0
  118. package/skills/core/debug/references/performance-diagnostics.md +113 -0
  119. package/skills/core/debug/references/reporting-standards.md +122 -0
  120. package/skills/core/debug/references/root-cause-tracing.md +122 -0
  121. package/skills/core/debug/references/systematic-debugging.md +102 -0
  122. package/skills/core/debug/references/task-management-debugging.md +155 -0
  123. package/skills/core/debug/references/verification.md +123 -0
  124. package/skills/core/debug/scripts/find-polluter.sh +63 -0
  125. package/skills/core/debug/scripts/find-polluter.test.md +102 -0
  126. package/skills/core/execute/SKILL.md +70 -0
  127. package/skills/core/fix/SKILL.md +111 -0
  128. package/skills/core/fix/references/complexity-assessment.md +72 -0
  129. package/skills/core/fix/references/mode-selection.md +46 -0
  130. package/skills/core/fix/references/parallel-exploration.md +100 -0
  131. package/skills/core/fix/references/review-cycle.md +77 -0
  132. package/skills/core/fix/references/skill-activation-matrix.md +78 -0
  133. package/skills/core/fix/references/task-orchestration.md +103 -0
  134. package/skills/core/fix/references/workflow-ci.md +28 -0
  135. package/skills/core/fix/references/workflow-deep.md +122 -0
  136. package/skills/core/fix/references/workflow-logs.md +72 -0
  137. package/skills/core/fix/references/workflow-quick.md +59 -0
  138. package/skills/core/fix/references/workflow-standard.md +111 -0
  139. package/skills/core/fix/references/workflow-test.md +75 -0
  140. package/skills/core/fix/references/workflow-types.md +33 -0
  141. package/skills/core/fix/references/workflow-ui.md +75 -0
  142. package/skills/core/plan/SKILL.md +145 -0
  143. package/skills/core/plan/plan-document-reviewer-prompt.md +49 -0
  144. package/skills/core/subagent-dev/SKILL.md +277 -0
  145. package/skills/core/subagent-dev/code-quality-reviewer-prompt.md +26 -0
  146. package/skills/core/subagent-dev/implementer-prompt.md +113 -0
  147. package/skills/core/subagent-dev/spec-reviewer-prompt.md +61 -0
  148. package/skills/core/tdd/SKILL.md +371 -0
  149. package/skills/core/tdd/testing-anti-patterns.md +299 -0
  150. package/skills/core/test/SKILL.md +109 -0
  151. package/skills/core/test/references/report-format.md +58 -0
  152. package/skills/core/test/references/test-execution-workflow.md +103 -0
  153. package/skills/core/test/references/ui-testing-workflow.md +65 -0
  154. package/skills/core/verify/SKILL.md +139 -0
  155. package/skills/dev/backend-dev/SKILL.md +96 -0
  156. package/skills/dev/backend-dev/references/backend-api-design.md +495 -0
  157. package/skills/dev/backend-dev/references/backend-architecture.md +454 -0
  158. package/skills/dev/backend-dev/references/backend-authentication.md +338 -0
  159. package/skills/dev/backend-dev/references/backend-code-quality.md +659 -0
  160. package/skills/dev/backend-dev/references/backend-debugging.md +904 -0
  161. package/skills/dev/backend-dev/references/backend-devops.md +494 -0
  162. package/skills/dev/backend-dev/references/backend-mindset.md +387 -0
  163. package/skills/dev/backend-dev/references/backend-performance.md +397 -0
  164. package/skills/dev/backend-dev/references/backend-security.md +290 -0
  165. package/skills/dev/backend-dev/references/backend-technologies.md +256 -0
  166. package/skills/dev/backend-dev/references/backend-testing.md +429 -0
  167. package/skills/dev/context-engineering/SKILL.md +108 -0
  168. package/skills/dev/context-engineering/references/context-compression.md +84 -0
  169. package/skills/dev/context-engineering/references/context-degradation.md +93 -0
  170. package/skills/dev/context-engineering/references/context-fundamentals.md +75 -0
  171. package/skills/dev/context-engineering/references/context-optimization.md +82 -0
  172. package/skills/dev/context-engineering/references/evaluation.md +89 -0
  173. package/skills/dev/context-engineering/references/memory-systems.md +88 -0
  174. package/skills/dev/context-engineering/references/multi-agent-patterns.md +90 -0
  175. package/skills/dev/context-engineering/references/project-development.md +97 -0
  176. package/skills/dev/context-engineering/references/runtime-awareness.md +202 -0
  177. package/skills/dev/context-engineering/references/tool-design.md +86 -0
  178. package/skills/dev/context-engineering/scripts/compression_evaluator.py +349 -0
  179. package/skills/dev/context-engineering/scripts/context_analyzer.py +317 -0
  180. package/skills/dev/context-engineering/scripts/tests/test_edge_cases.py +246 -0
  181. package/skills/dev/databases/SKILL.md +84 -0
  182. package/skills/dev/databases/analytics.md +198 -0
  183. package/skills/dev/databases/db-design.md +188 -0
  184. package/skills/dev/databases/incremental-etl.md +213 -0
  185. package/skills/dev/databases/references/mongodb-aggregation.md +447 -0
  186. package/skills/dev/databases/references/mongodb-atlas.md +465 -0
  187. package/skills/dev/databases/references/mongodb-crud.md +408 -0
  188. package/skills/dev/databases/references/mongodb-indexing.md +442 -0
  189. package/skills/dev/databases/references/postgresql-administration.md +594 -0
  190. package/skills/dev/databases/references/postgresql-performance.md +527 -0
  191. package/skills/dev/databases/references/postgresql-psql-cli.md +467 -0
  192. package/skills/dev/databases/references/postgresql-queries.md +475 -0
  193. package/skills/dev/databases/scripts/.coverage +0 -0
  194. package/skills/dev/databases/scripts/db_backup.py +502 -0
  195. package/skills/dev/databases/scripts/db_migrate.py +426 -0
  196. package/skills/dev/databases/scripts/db_performance_check.py +457 -0
  197. package/skills/dev/databases/scripts/requirements.txt +20 -0
  198. package/skills/dev/databases/scripts/tests/coverage-db.json +1 -0
  199. package/skills/dev/databases/scripts/tests/requirements.txt +4 -0
  200. package/skills/dev/databases/scripts/tests/test_db_backup.py +340 -0
  201. package/skills/dev/databases/scripts/tests/test_db_migrate.py +277 -0
  202. package/skills/dev/databases/scripts/tests/test_db_performance_check.py +370 -0
  203. package/skills/dev/databases/stacks/bigquery.md +231 -0
  204. package/skills/dev/databases/stacks/d1_cloudflare.md +137 -0
  205. package/skills/dev/databases/stacks/mysql.md +216 -0
  206. package/skills/dev/databases/stacks/postgres.md +235 -0
  207. package/skills/dev/databases/stacks/sqlite.md +244 -0
  208. package/skills/dev/databases/transactional.md +176 -0
  209. package/skills/dev/devops/.env.example +76 -0
  210. package/skills/dev/devops/SKILL.md +97 -0
  211. package/skills/dev/devops/references/browser-rendering.md +305 -0
  212. package/skills/dev/devops/references/cloudflare-d1-kv.md +123 -0
  213. package/skills/dev/devops/references/cloudflare-platform.md +271 -0
  214. package/skills/dev/devops/references/cloudflare-r2-storage.md +280 -0
  215. package/skills/dev/devops/references/cloudflare-workers-advanced.md +312 -0
  216. package/skills/dev/devops/references/cloudflare-workers-apis.md +309 -0
  217. package/skills/dev/devops/references/cloudflare-workers-basics.md +418 -0
  218. package/skills/dev/devops/references/docker-basics.md +297 -0
  219. package/skills/dev/devops/references/docker-compose.md +292 -0
  220. package/skills/dev/devops/references/gcloud-platform.md +297 -0
  221. package/skills/dev/devops/references/gcloud-services.md +304 -0
  222. package/skills/dev/devops/references/kubernetes-basics.md +99 -0
  223. package/skills/dev/devops/references/kubernetes-helm-advanced.md +75 -0
  224. package/skills/dev/devops/references/kubernetes-helm.md +81 -0
  225. package/skills/dev/devops/references/kubernetes-kubectl.md +74 -0
  226. package/skills/dev/devops/references/kubernetes-security-advanced.md +98 -0
  227. package/skills/dev/devops/references/kubernetes-security.md +95 -0
  228. package/skills/dev/devops/references/kubernetes-troubleshooting-advanced.md +74 -0
  229. package/skills/dev/devops/references/kubernetes-troubleshooting.md +49 -0
  230. package/skills/dev/devops/references/kubernetes-workflows-advanced.md +75 -0
  231. package/skills/dev/devops/references/kubernetes-workflows.md +78 -0
  232. package/skills/dev/devops/scripts/cloudflare_deploy.py +269 -0
  233. package/skills/dev/devops/scripts/docker_optimize.py +332 -0
  234. package/skills/dev/devops/scripts/requirements.txt +20 -0
  235. package/skills/dev/devops/scripts/tests/requirements.txt +3 -0
  236. package/skills/dev/devops/scripts/tests/test_cloudflare_deploy.py +285 -0
  237. package/skills/dev/devops/scripts/tests/test_docker_optimize.py +436 -0
  238. package/skills/dev/frontend-design/SKILL.md +78 -0
  239. package/skills/dev/frontend-design/references/ai-multimodal-overview.md +165 -0
  240. package/skills/dev/frontend-design/references/analysis-best-practices.md +80 -0
  241. package/skills/dev/frontend-design/references/analysis-prompts.md +141 -0
  242. package/skills/dev/frontend-design/references/analysis-techniques.md +118 -0
  243. package/skills/dev/frontend-design/references/animejs.md +396 -0
  244. package/skills/dev/frontend-design/references/asset-generation.md +337 -0
  245. package/skills/dev/frontend-design/references/design-extraction-overview.md +71 -0
  246. package/skills/dev/frontend-design/references/extraction-best-practices.md +141 -0
  247. package/skills/dev/frontend-design/references/extraction-output-templates.md +162 -0
  248. package/skills/dev/frontend-design/references/extraction-prompts.md +127 -0
  249. package/skills/dev/frontend-design/references/technical-accessibility.md +119 -0
  250. package/skills/dev/frontend-design/references/technical-best-practices.md +97 -0
  251. package/skills/dev/frontend-design/references/technical-optimization.md +44 -0
  252. package/skills/dev/frontend-design/references/technical-overview.md +90 -0
  253. package/skills/dev/frontend-design/references/technical-workflows.md +150 -0
  254. package/skills/dev/frontend-design/references/visual-analysis-overview.md +95 -0
  255. package/skills/dev/frontend-design/references/workflow-3d.md +102 -0
  256. package/skills/dev/frontend-design/references/workflow-describe.md +87 -0
  257. package/skills/dev/frontend-design/references/workflow-immersive.md +87 -0
  258. package/skills/dev/frontend-design/references/workflow-quick.md +57 -0
  259. package/skills/dev/frontend-design/references/workflow-screenshot.md +63 -0
  260. package/skills/dev/frontend-design/references/workflow-video.md +74 -0
  261. package/skills/dev/frontend-dev/SKILL.md +400 -0
  262. package/skills/dev/frontend-dev/resources/common-patterns.md +331 -0
  263. package/skills/dev/frontend-dev/resources/complete-examples.md +872 -0
  264. package/skills/dev/frontend-dev/resources/component-patterns.md +502 -0
  265. package/skills/dev/frontend-dev/resources/data-fetching.md +767 -0
  266. package/skills/dev/frontend-dev/resources/file-organization.md +502 -0
  267. package/skills/dev/frontend-dev/resources/loading-and-error-states.md +501 -0
  268. package/skills/dev/frontend-dev/resources/performance.md +406 -0
  269. package/skills/dev/frontend-dev/resources/routing-guide.md +364 -0
  270. package/skills/dev/frontend-dev/resources/styling-guide.md +428 -0
  271. package/skills/dev/frontend-dev/resources/typescript-standards.md +418 -0
  272. package/skills/dev/git/SKILL.md +114 -0
  273. package/skills/dev/git/references/branch-management.md +88 -0
  274. package/skills/dev/git/references/commit-standards.md +46 -0
  275. package/skills/dev/git/references/gh-cli-guide.md +109 -0
  276. package/skills/dev/git/references/safety-protocols.md +69 -0
  277. package/skills/dev/git/references/workflow-commit.md +58 -0
  278. package/skills/dev/git/references/workflow-merge.md +48 -0
  279. package/skills/dev/git/references/workflow-pr.md +58 -0
  280. package/skills/dev/git/references/workflow-push.md +52 -0
  281. package/skills/dev/git-worktree/SKILL.md +218 -0
  282. package/skills/utils/ask/SKILL.md +58 -0
  283. package/skills/utils/bootstrap/SKILL.md +101 -0
  284. package/skills/utils/bootstrap/references/shared-phases.md +59 -0
  285. package/skills/utils/bootstrap/references/workflow-auto.md +52 -0
  286. package/skills/utils/bootstrap/references/workflow-fast.md +50 -0
  287. package/skills/utils/bootstrap/references/workflow-full.md +60 -0
  288. package/skills/utils/bootstrap/references/workflow-parallel.md +59 -0
  289. package/skills/utils/ck-help/SKILL.md +102 -0
  290. package/skills/utils/ck-help/scripts/ck-help.py +1321 -0
  291. package/skills/utils/ck-help/scripts/commands_data.yaml +3 -0
  292. package/skills/utils/ck-help/scripts/skills_data.yaml +593 -0
  293. package/skills/utils/copywriting/SKILL.md +94 -0
  294. package/skills/utils/copywriting/references/copy-formulas.md +150 -0
  295. package/skills/utils/copywriting/references/cta-patterns.md +168 -0
  296. package/skills/utils/copywriting/references/email-copy.md +193 -0
  297. package/skills/utils/copywriting/references/headline-templates.md +140 -0
  298. package/skills/utils/copywriting/references/landing-page-copy.md +175 -0
  299. package/skills/utils/copywriting/references/power-words.md +189 -0
  300. package/skills/utils/copywriting/references/social-media-copy.md +222 -0
  301. package/skills/utils/copywriting/references/workflow-cro.md +83 -0
  302. package/skills/utils/copywriting/references/workflow-enhance.md +32 -0
  303. package/skills/utils/copywriting/references/workflow-fast.md +29 -0
  304. package/skills/utils/copywriting/references/workflow-good.md +39 -0
  305. package/skills/utils/copywriting/references/writing-styles.md +247 -0
  306. package/skills/utils/copywriting/scripts/extract-writing-styles.py +308 -0
  307. package/skills/utils/copywriting/templates/copy-brief.md +49 -0
  308. package/skills/utils/docs/SKILL.md +55 -0
  309. package/skills/utils/docs/references/init-workflow.md +32 -0
  310. package/skills/utils/docs/references/summarize-workflow.md +18 -0
  311. package/skills/utils/docs/references/update-workflow.md +59 -0
  312. package/skills/utils/journal/SKILL.md +11 -0
  313. package/skills/utils/kanban/SKILL.md +99 -0
  314. package/skills/utils/preview/SKILL.md +75 -0
  315. package/skills/utils/preview/references/generation-modes.md +95 -0
  316. package/skills/utils/preview/references/view-mode.md +42 -0
  317. package/skills/utils/repomix/SKILL.md +248 -0
  318. package/skills/utils/repomix/references/configuration.md +211 -0
  319. package/skills/utils/repomix/references/usage-patterns.md +232 -0
  320. package/skills/utils/repomix/scripts/.coverage +0 -0
  321. package/skills/utils/repomix/scripts/README.md +179 -0
  322. package/skills/utils/repomix/scripts/repomix_batch.py +455 -0
  323. package/skills/utils/repomix/scripts/repos.example.json +15 -0
  324. package/skills/utils/repomix/scripts/requirements.txt +15 -0
  325. package/skills/utils/repomix/scripts/tests/test_repomix_batch.py +531 -0
  326. package/skills/utils/research/SKILL.md +171 -0
  327. package/skills/utils/scout/SKILL.md +89 -0
  328. package/skills/utils/scout/references/external-scouting.md +140 -0
  329. package/skills/utils/scout/references/internal-scouting.md +119 -0
  330. package/skills/utils/scout/references/task-management-scouting.md +125 -0
  331. package/skills/utils/sequential-thinking/.env.example +8 -0
  332. package/skills/utils/sequential-thinking/README.md +183 -0
  333. package/skills/utils/sequential-thinking/SKILL.md +95 -0
  334. package/skills/utils/sequential-thinking/package.json +31 -0
  335. package/skills/utils/sequential-thinking/references/advanced-strategies.md +79 -0
  336. package/skills/utils/sequential-thinking/references/advanced-techniques.md +76 -0
  337. package/skills/utils/sequential-thinking/references/core-patterns.md +95 -0
  338. package/skills/utils/sequential-thinking/references/examples-api.md +88 -0
  339. package/skills/utils/sequential-thinking/references/examples-architecture.md +94 -0
  340. package/skills/utils/sequential-thinking/references/examples-debug.md +90 -0
  341. package/skills/utils/sequential-thinking/scripts/format-thought.js +159 -0
  342. package/skills/utils/sequential-thinking/scripts/process-thought.js +236 -0
  343. package/skills/utils/sequential-thinking/tests/format-thought.test.js +133 -0
  344. package/skills/utils/sequential-thinking/tests/process-thought.test.js +215 -0
  345. package/skills/utils/write-skill/SKILL.md +655 -0
  346. package/skills/utils/write-skill/anthropic-best-practices.md +1150 -0
  347. package/skills/utils/write-skill/examples/CLAUDE_MD_TESTING.md +189 -0
  348. package/skills/utils/write-skill/graphviz-conventions.dot +172 -0
  349. package/skills/utils/write-skill/persuasion-principles.md +187 -0
  350. package/skills/utils/write-skill/render-graphs.js +168 -0
  351. package/skills/utils/write-skill/testing-skills-with-subagents.md +384 -0
  352. package/src/commands/init.js +238 -0
@@ -0,0 +1,457 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Database performance analysis tool for MongoDB and PostgreSQL.
4
+ Analyzes slow queries, recommends indexes, and generates reports.
5
+ """
6
+
7
+ import argparse
8
+ import json
9
+ import sys
10
+ from dataclasses import dataclass, asdict
11
+ from datetime import datetime
12
+ from pathlib import Path
13
+ from typing import Dict, List, Optional
14
+
15
+ # Windows UTF-8 compatibility (works for both local and global installs)
16
+ CLAUDE_ROOT = Path(__file__).parent.parent.parent.parent
17
+ sys.path.insert(0, str(CLAUDE_ROOT / 'scripts'))
18
+ try:
19
+ from win_compat import ensure_utf8_stdout
20
+ ensure_utf8_stdout()
21
+ except ImportError:
22
+ if sys.platform == 'win32':
23
+ import io
24
+ if hasattr(sys.stdout, 'buffer'):
25
+ sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')
26
+
27
+ try:
28
+ from pymongo import MongoClient
29
+ MONGO_AVAILABLE = True
30
+ except ImportError:
31
+ MONGO_AVAILABLE = False
32
+
33
+ try:
34
+ import psycopg2
35
+ from psycopg2.extras import RealDictCursor
36
+ POSTGRES_AVAILABLE = True
37
+ except ImportError:
38
+ POSTGRES_AVAILABLE = False
39
+
40
+
41
+ @dataclass
42
+ class SlowQuery:
43
+ """Represents a slow query."""
44
+
45
+ query: str
46
+ execution_time_ms: float
47
+ count: int
48
+ collection_or_table: Optional[str] = None
49
+ index_used: Optional[str] = None
50
+
51
+
52
+ @dataclass
53
+ class IndexRecommendation:
54
+ """Index recommendation."""
55
+
56
+ collection_or_table: str
57
+ fields: List[str]
58
+ reason: str
59
+ estimated_benefit: str
60
+
61
+
62
+ @dataclass
63
+ class PerformanceReport:
64
+ """Performance analysis report."""
65
+
66
+ database_type: str
67
+ database_name: str
68
+ timestamp: datetime
69
+ slow_queries: List[SlowQuery]
70
+ index_recommendations: List[IndexRecommendation]
71
+ database_metrics: Dict[str, any]
72
+
73
+
74
+ class PerformanceAnalyzer:
75
+ """Analyzes database performance."""
76
+
77
+ def __init__(self, db_type: str, connection_string: str, threshold_ms: int = 100):
78
+ """
79
+ Initialize performance analyzer.
80
+
81
+ Args:
82
+ db_type: Database type ('mongodb' or 'postgres')
83
+ connection_string: Database connection string
84
+ threshold_ms: Slow query threshold in milliseconds
85
+ """
86
+ self.db_type = db_type.lower()
87
+ self.connection_string = connection_string
88
+ self.threshold_ms = threshold_ms
89
+
90
+ self.client = None
91
+ self.db = None
92
+ self.conn = None
93
+
94
+ def connect(self) -> bool:
95
+ """Connect to database."""
96
+ try:
97
+ if self.db_type == "mongodb":
98
+ if not MONGO_AVAILABLE:
99
+ print("Error: pymongo not installed")
100
+ return False
101
+ self.client = MongoClient(self.connection_string)
102
+ self.db = self.client.get_default_database()
103
+ self.client.server_info()
104
+ return True
105
+
106
+ elif self.db_type == "postgres":
107
+ if not POSTGRES_AVAILABLE:
108
+ print("Error: psycopg2 not installed")
109
+ return False
110
+ self.conn = psycopg2.connect(self.connection_string)
111
+ return True
112
+
113
+ else:
114
+ print(f"Error: Unsupported database type: {self.db_type}")
115
+ return False
116
+
117
+ except Exception as e:
118
+ print(f"Connection error: {e}")
119
+ return False
120
+
121
+ def disconnect(self):
122
+ """Disconnect from database."""
123
+ try:
124
+ if self.client:
125
+ self.client.close()
126
+ if self.conn:
127
+ self.conn.close()
128
+ except Exception as e:
129
+ print(f"Disconnect error: {e}")
130
+
131
+ def analyze(self) -> Optional[PerformanceReport]:
132
+ """
133
+ Analyze database performance.
134
+
135
+ Returns:
136
+ PerformanceReport if successful, None otherwise
137
+ """
138
+ try:
139
+ if self.db_type == "mongodb":
140
+ return self._analyze_mongodb()
141
+ elif self.db_type == "postgres":
142
+ return self._analyze_postgres()
143
+ else:
144
+ return None
145
+
146
+ except Exception as e:
147
+ print(f"Analysis error: {e}")
148
+ return None
149
+
150
+ def _analyze_mongodb(self) -> PerformanceReport:
151
+ """Analyze MongoDB performance."""
152
+ slow_queries = []
153
+ index_recommendations = []
154
+
155
+ # Enable profiling if not enabled
156
+ profiling_level = self.db.command("profile", -1)
157
+ if profiling_level.get("was", 0) == 0:
158
+ self.db.command("profile", 1, slowms=self.threshold_ms)
159
+
160
+ # Get slow queries from system.profile
161
+ for doc in self.db.system.profile.find(
162
+ {"millis": {"$gte": self.threshold_ms}},
163
+ limit=50
164
+ ).sort("millis", -1):
165
+
166
+ query_str = json.dumps(doc.get("command", {}), default=str)
167
+
168
+ slow_queries.append(SlowQuery(
169
+ query=query_str,
170
+ execution_time_ms=doc.get("millis", 0),
171
+ count=1,
172
+ collection_or_table=doc.get("ns", "").split(".")[-1] if "ns" in doc else None,
173
+ index_used=doc.get("planSummary")
174
+ ))
175
+
176
+ # Analyze collections for index recommendations
177
+ for coll_name in self.db.list_collection_names():
178
+ if coll_name.startswith("system."):
179
+ continue
180
+
181
+ coll = self.db[coll_name]
182
+
183
+ # Check for collections scans
184
+ stats = coll.aggregate([
185
+ {"$collStats": {"storageStats": {}}}
186
+ ]).next()
187
+
188
+ # Check if collection has indexes
189
+ indexes = list(coll.list_indexes())
190
+
191
+ if len(indexes) <= 1: # Only _id index
192
+ # Recommend indexes based on common patterns
193
+ # Sample documents to find frequently queried fields
194
+ sample = list(coll.find().limit(100))
195
+
196
+ if sample:
197
+ # Find fields that appear in most documents
198
+ field_freq = {}
199
+ for doc in sample:
200
+ for field in doc.keys():
201
+ if field != "_id":
202
+ field_freq[field] = field_freq.get(field, 0) + 1
203
+
204
+ # Recommend index on most common field
205
+ if field_freq:
206
+ top_field = max(field_freq.items(), key=lambda x: x[1])[0]
207
+ index_recommendations.append(IndexRecommendation(
208
+ collection_or_table=coll_name,
209
+ fields=[top_field],
210
+ reason="Frequently queried field without index",
211
+ estimated_benefit="High"
212
+ ))
213
+
214
+ # Get database metrics
215
+ server_status = self.client.admin.command("serverStatus")
216
+ db_stats = self.db.command("dbStats")
217
+
218
+ metrics = {
219
+ "connections": server_status.get("connections", {}).get("current", 0),
220
+ "operations_per_sec": server_status.get("opcounters", {}).get("query", 0),
221
+ "database_size_mb": db_stats.get("dataSize", 0) / (1024 * 1024),
222
+ "index_size_mb": db_stats.get("indexSize", 0) / (1024 * 1024),
223
+ "collections": db_stats.get("collections", 0)
224
+ }
225
+
226
+ return PerformanceReport(
227
+ database_type="mongodb",
228
+ database_name=self.db.name,
229
+ timestamp=datetime.now(),
230
+ slow_queries=slow_queries[:10], # Top 10
231
+ index_recommendations=index_recommendations,
232
+ database_metrics=metrics
233
+ )
234
+
235
+ def _analyze_postgres(self) -> PerformanceReport:
236
+ """Analyze PostgreSQL performance."""
237
+ slow_queries = []
238
+ index_recommendations = []
239
+
240
+ with self.conn.cursor(cursor_factory=RealDictCursor) as cur:
241
+ # Check if pg_stat_statements extension is available
242
+ cur.execute("""
243
+ SELECT EXISTS (
244
+ SELECT 1 FROM pg_extension WHERE extname = 'pg_stat_statements'
245
+ ) AS has_extension
246
+ """)
247
+ has_pg_stat_statements = cur.fetchone()["has_extension"]
248
+
249
+ if has_pg_stat_statements:
250
+ # Get slow queries from pg_stat_statements
251
+ cur.execute("""
252
+ SELECT
253
+ query,
254
+ mean_exec_time,
255
+ calls,
256
+ total_exec_time
257
+ FROM pg_stat_statements
258
+ WHERE mean_exec_time >= %s
259
+ ORDER BY mean_exec_time DESC
260
+ LIMIT 10
261
+ """, (self.threshold_ms,))
262
+
263
+ for row in cur.fetchall():
264
+ slow_queries.append(SlowQuery(
265
+ query=row["query"],
266
+ execution_time_ms=row["mean_exec_time"],
267
+ count=row["calls"]
268
+ ))
269
+
270
+ # Find tables with sequential scans (potential index candidates)
271
+ cur.execute("""
272
+ SELECT
273
+ schemaname,
274
+ tablename,
275
+ seq_scan,
276
+ seq_tup_read,
277
+ idx_scan
278
+ FROM pg_stat_user_tables
279
+ WHERE seq_scan > 1000
280
+ AND (idx_scan IS NULL OR seq_scan > idx_scan * 2)
281
+ ORDER BY seq_tup_read DESC
282
+ LIMIT 10
283
+ """)
284
+
285
+ for row in cur.fetchall():
286
+ index_recommendations.append(IndexRecommendation(
287
+ collection_or_table=f"{row['schemaname']}.{row['tablename']}",
288
+ fields=["<analyze query patterns>"],
289
+ reason=f"High sequential scans ({row['seq_scan']}) vs index scans ({row['idx_scan'] or 0})",
290
+ estimated_benefit="High" if row["seq_tup_read"] > 100000 else "Medium"
291
+ ))
292
+
293
+ # Find unused indexes
294
+ cur.execute("""
295
+ SELECT
296
+ schemaname,
297
+ tablename,
298
+ indexname,
299
+ idx_scan
300
+ FROM pg_stat_user_indexes
301
+ WHERE idx_scan = 0
302
+ AND indexname NOT LIKE '%_pkey'
303
+ ORDER BY pg_relation_size(indexrelid) DESC
304
+ """)
305
+
306
+ unused_indexes = []
307
+ for row in cur.fetchall():
308
+ unused_indexes.append(
309
+ f"{row['schemaname']}.{row['tablename']}.{row['indexname']}"
310
+ )
311
+
312
+ # Database metrics
313
+ cur.execute("""
314
+ SELECT
315
+ sum(numbackends) AS connections,
316
+ sum(xact_commit) AS commits,
317
+ sum(xact_rollback) AS rollbacks
318
+ FROM pg_stat_database
319
+ WHERE datname = current_database()
320
+ """)
321
+ stats = cur.fetchone()
322
+
323
+ cur.execute("""
324
+ SELECT pg_database_size(current_database()) AS db_size
325
+ """)
326
+ db_size = cur.fetchone()["db_size"]
327
+
328
+ cur.execute("""
329
+ SELECT
330
+ sum(heap_blks_hit) / NULLIF(sum(heap_blks_hit) + sum(heap_blks_read), 0) AS cache_hit_ratio
331
+ FROM pg_statio_user_tables
332
+ """)
333
+ cache_ratio = cur.fetchone()["cache_hit_ratio"] or 0
334
+
335
+ metrics = {
336
+ "connections": stats["connections"],
337
+ "commits": stats["commits"],
338
+ "rollbacks": stats["rollbacks"],
339
+ "database_size_mb": db_size / (1024 * 1024),
340
+ "cache_hit_ratio": float(cache_ratio),
341
+ "unused_indexes": unused_indexes
342
+ }
343
+
344
+ return PerformanceReport(
345
+ database_type="postgres",
346
+ database_name=self.conn.info.dbname,
347
+ timestamp=datetime.now(),
348
+ slow_queries=slow_queries,
349
+ index_recommendations=index_recommendations,
350
+ database_metrics=metrics
351
+ )
352
+
353
+ def print_report(self, report: PerformanceReport):
354
+ """Print performance report."""
355
+ print("=" * 80)
356
+ print(f"Database Performance Report - {report.database_type.upper()}")
357
+ print(f"Database: {report.database_name}")
358
+ print(f"Timestamp: {report.timestamp}")
359
+ print("=" * 80)
360
+
361
+ print("\n## Database Metrics")
362
+ print("-" * 80)
363
+ for key, value in report.database_metrics.items():
364
+ if isinstance(value, float):
365
+ print(f"{key}: {value:.2f}")
366
+ else:
367
+ print(f"{key}: {value}")
368
+
369
+ print("\n## Slow Queries")
370
+ print("-" * 80)
371
+ if report.slow_queries:
372
+ for i, query in enumerate(report.slow_queries, 1):
373
+ print(f"\n{i}. Execution Time: {query.execution_time_ms:.2f}ms | Count: {query.count}")
374
+ if query.collection_or_table:
375
+ print(f" Collection/Table: {query.collection_or_table}")
376
+ if query.index_used:
377
+ print(f" Index Used: {query.index_used}")
378
+ print(f" Query: {query.query[:200]}...")
379
+ else:
380
+ print("No slow queries found")
381
+
382
+ print("\n## Index Recommendations")
383
+ print("-" * 80)
384
+ if report.index_recommendations:
385
+ for i, rec in enumerate(report.index_recommendations, 1):
386
+ print(f"\n{i}. {rec.collection_or_table}")
387
+ print(f" Fields: {', '.join(rec.fields)}")
388
+ print(f" Reason: {rec.reason}")
389
+ print(f" Estimated Benefit: {rec.estimated_benefit}")
390
+
391
+ if report.database_type == "mongodb":
392
+ index_spec = {field: 1 for field in rec.fields}
393
+ print(f" Command: db.{rec.collection_or_table}.createIndex({json.dumps(index_spec)})")
394
+ elif report.database_type == "postgres":
395
+ fields_str = ", ".join(rec.fields)
396
+ print(f" Command: CREATE INDEX idx_{rec.collection_or_table.replace('.', '_')}_{rec.fields[0]} ON {rec.collection_or_table}({fields_str});")
397
+ else:
398
+ print("No index recommendations")
399
+
400
+ print("\n" + "=" * 80)
401
+
402
+ def save_report(self, report: PerformanceReport, filename: str):
403
+ """Save report to JSON file."""
404
+ # Convert dataclasses to dict
405
+ report_dict = {
406
+ "database_type": report.database_type,
407
+ "database_name": report.database_name,
408
+ "timestamp": report.timestamp.isoformat(),
409
+ "slow_queries": [asdict(q) for q in report.slow_queries],
410
+ "index_recommendations": [asdict(r) for r in report.index_recommendations],
411
+ "database_metrics": report.database_metrics
412
+ }
413
+
414
+ with open(filename, "w") as f:
415
+ json.dump(report_dict, f, indent=2, default=str)
416
+
417
+ print(f"\nReport saved to: {filename}")
418
+
419
+
420
+ def main():
421
+ """Main entry point."""
422
+ parser = argparse.ArgumentParser(description="Database performance analysis tool")
423
+ parser.add_argument("--db", required=True, choices=["mongodb", "postgres"],
424
+ help="Database type")
425
+ parser.add_argument("--uri", required=True, help="Database connection string")
426
+ parser.add_argument("--threshold", type=int, default=100,
427
+ help="Slow query threshold in milliseconds (default: 100)")
428
+ parser.add_argument("--output", help="Save report to JSON file")
429
+
430
+ args = parser.parse_args()
431
+
432
+ analyzer = PerformanceAnalyzer(args.db, args.uri, args.threshold)
433
+
434
+ if not analyzer.connect():
435
+ sys.exit(1)
436
+
437
+ try:
438
+ print(f"Analyzing {args.db} performance (threshold: {args.threshold}ms)...")
439
+ report = analyzer.analyze()
440
+
441
+ if report:
442
+ analyzer.print_report(report)
443
+
444
+ if args.output:
445
+ analyzer.save_report(report, args.output)
446
+
447
+ sys.exit(0)
448
+ else:
449
+ print("Analysis failed")
450
+ sys.exit(1)
451
+
452
+ finally:
453
+ analyzer.disconnect()
454
+
455
+
456
+ if __name__ == "__main__":
457
+ main()
@@ -0,0 +1,20 @@
1
+ # Databases Skill Dependencies
2
+ # Python 3.10+ required
3
+
4
+ # No Python package dependencies - uses only standard library
5
+
6
+ # Testing dependencies (dev)
7
+ pytest>=8.0.0
8
+ pytest-cov>=4.1.0
9
+ pytest-mock>=3.12.0
10
+
11
+ # Note: This skill requires database CLI tools:
12
+ #
13
+ # PostgreSQL:
14
+ # - psql CLI (comes with PostgreSQL)
15
+ # - Ubuntu/Debian: sudo apt-get install postgresql-client
16
+ # - macOS: brew install postgresql
17
+ #
18
+ # MongoDB:
19
+ # - mongosh CLI: https://www.mongodb.com/try/download/shell
20
+ # - mongodump/mongorestore: https://www.mongodb.com/try/download/database-tools
@@ -0,0 +1 @@
1
+ {"meta": {"format": 3, "version": "7.11.0", "timestamp": "2025-11-05T00:57:30.958744", "branch_coverage": false, "show_contexts": false}, "files": {"db_backup.py": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 20, 21, 22, 24, 25, 26, 27, 28, 29, 30, 33, 34, 36, 44, 45, 46, 48, 67, 68, 70, 71, 72, 73, 78, 87, 88, 89, 91, 92, 94, 95, 97, 98, 100, 105, 106, 107, 108, 109, 110, 111, 113, 115, 124, 127, 128, 130, 136, 145, 146, 147, 149, 150, 151, 153, 154, 156, 172, 173, 175, 179, 198, 199, 200, 202, 214, 216, 217, 218, 221, 222, 228, 229, 230, 232, 234, 235, 236, 237, 238, 247, 249, 251, 252, 258, 260, 263, 266, 270, 271, 277, 279, 280, 291, 292, 293, 300, 304, 305, 311, 318, 320, 321, 322, 323, 325, 334, 338, 340, 351, 352, 354, 355, 358, 359, 360, 362, 363, 365, 366, 368, 370, 372, 382, 384, 388, 389, 392, 394, 396, 397, 398, 399, 400, 401, 402, 403, 404, 406, 408, 409, 410, 411, 414, 416, 418, 428, 429, 432, 501], "summary": {"covered_lines": 153, "num_statements": 249, "percent_covered": 61.44578313253012, "percent_covered_display": "61", "missing_lines": 96, "excluded_lines": 0}, "missing_lines": [75, 76, 101, 102, 125, 132, 133, 134, 158, 159, 160, 165, 166, 168, 169, 170, 176, 177, 181, 190, 191, 193, 194, 196, 223, 224, 225, 226, 240, 241, 243, 244, 245, 253, 254, 255, 256, 264, 267, 268, 273, 274, 275, 282, 283, 284, 301, 302, 307, 308, 309, 335, 336, 356, 367, 385, 412, 434, 435, 437, 440, 443, 444, 445, 446, 448, 452, 453, 454, 455, 459, 462, 463, 465, 468, 470, 472, 473, 479, 481, 482, 483, 485, 486, 487, 488, 489, 490, 491, 492, 493, 494, 496, 497, 498, 502], "excluded_lines": [], "functions": {"BackupManager.__init__": {"executed_lines": [44, 45, 46], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "BackupManager.create_backup": {"executed_lines": [67, 68, 70, 71, 72, 73], "summary": {"covered_lines": 6, "num_statements": 8, "percent_covered": 75.0, "percent_covered_display": "75", "missing_lines": 2, "excluded_lines": 0}, "missing_lines": [75, 76], "excluded_lines": []}, "BackupManager._backup_mongodb": {"executed_lines": [87, 88, 89, 91, 92, 94, 95, 97, 98, 100, 105, 106, 107, 108, 109, 110, 111, 113, 115, 124, 127, 128, 130], "summary": {"covered_lines": 23, "num_statements": 29, "percent_covered": 79.3103448275862, "percent_covered_display": "79", "missing_lines": 6, "excluded_lines": 0}, "missing_lines": [101, 102, 125, 132, 133, 134], "excluded_lines": []}, "BackupManager._backup_postgres": {"executed_lines": [145, 146, 147, 149, 150, 151, 153, 154, 156, 172, 173, 175, 179, 198, 199, 200], "summary": {"covered_lines": 16, "num_statements": 32, "percent_covered": 50.0, "percent_covered_display": "50", "missing_lines": 16, "excluded_lines": 0}, "missing_lines": [158, 159, 160, 165, 166, 168, 169, 170, 176, 177, 181, 190, 191, 193, 194, 196], "excluded_lines": []}, "BackupManager.restore_backup": {"executed_lines": [214, 216, 217, 218, 221, 222, 228, 229, 230, 232, 234, 235, 236, 237, 238], "summary": {"covered_lines": 15, "num_statements": 24, "percent_covered": 62.5, "percent_covered_display": "62", "missing_lines": 9, "excluded_lines": 0}, "missing_lines": [223, 224, 225, 226, 240, 241, 243, 244, 245], "excluded_lines": []}, "BackupManager._restore_mongodb": {"executed_lines": [249, 251, 252, 258, 260, 263, 266, 270, 271], "summary": {"covered_lines": 9, "num_statements": 19, "percent_covered": 47.36842105263158, "percent_covered_display": "47", "missing_lines": 10, "excluded_lines": 0}, "missing_lines": [253, 254, 255, 256, 264, 267, 268, 273, 274, 275], "excluded_lines": []}, "BackupManager._restore_postgres": {"executed_lines": [279, 280, 291, 292, 293, 300, 304, 305], "summary": {"covered_lines": 8, "num_statements": 16, "percent_covered": 50.0, "percent_covered_display": "50", "missing_lines": 8, "excluded_lines": 0}, "missing_lines": [282, 283, 284, 301, 302, 307, 308, 309], "excluded_lines": []}, "BackupManager.list_backups": {"executed_lines": [318, 320, 321, 322, 323, 325, 334, 338], "summary": {"covered_lines": 8, "num_statements": 10, "percent_covered": 80.0, "percent_covered_display": "80", "missing_lines": 2, "excluded_lines": 0}, "missing_lines": [335, 336], "excluded_lines": []}, "BackupManager.cleanup_old_backups": {"executed_lines": [351, 352, 354, 355, 358, 359, 360, 362, 363, 365, 366, 368, 370], "summary": {"covered_lines": 13, "num_statements": 15, "percent_covered": 86.66666666666667, "percent_covered_display": "87", "missing_lines": 2, "excluded_lines": 0}, "missing_lines": [356, 367], "excluded_lines": []}, "BackupManager._verify_backup": {"executed_lines": [382, 384, 388, 389, 392], "summary": {"covered_lines": 5, "num_statements": 6, "percent_covered": 83.33333333333333, "percent_covered_display": "83", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [385], "excluded_lines": []}, "BackupManager._get_size": {"executed_lines": [396, 397, 398, 399, 400, 401, 402, 403, 404], "summary": {"covered_lines": 9, "num_statements": 9, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "BackupManager._format_size": {"executed_lines": [408, 409, 410, 411], "summary": {"covered_lines": 4, "num_statements": 5, "percent_covered": 80.0, "percent_covered_display": "80", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [412], "excluded_lines": []}, "BackupManager._save_metadata": {"executed_lines": [416, 418, 428, 429], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "main": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 38, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 38, "excluded_lines": 0}, "missing_lines": [434, 435, 437, 440, 443, 444, 445, 446, 448, 452, 453, 454, 455, 459, 462, 463, 465, 468, 470, 472, 473, 479, 481, 482, 483, 485, 486, 487, 488, 489, 490, 491, 492, 493, 494, 496, 497, 498], "excluded_lines": []}, "": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 20, 21, 22, 24, 25, 26, 27, 28, 29, 30, 33, 34, 36, 48, 78, 136, 202, 247, 277, 311, 340, 372, 394, 406, 414, 432, 501], "summary": {"covered_lines": 30, "num_statements": 31, "percent_covered": 96.7741935483871, "percent_covered_display": "97", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [502], "excluded_lines": []}}, "classes": {"BackupInfo": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 0, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "BackupManager": {"executed_lines": [44, 45, 46, 67, 68, 70, 71, 72, 73, 87, 88, 89, 91, 92, 94, 95, 97, 98, 100, 105, 106, 107, 108, 109, 110, 111, 113, 115, 124, 127, 128, 130, 145, 146, 147, 149, 150, 151, 153, 154, 156, 172, 173, 175, 179, 198, 199, 200, 214, 216, 217, 218, 221, 222, 228, 229, 230, 232, 234, 235, 236, 237, 238, 249, 251, 252, 258, 260, 263, 266, 270, 271, 279, 280, 291, 292, 293, 300, 304, 305, 318, 320, 321, 322, 323, 325, 334, 338, 351, 352, 354, 355, 358, 359, 360, 362, 363, 365, 366, 368, 370, 382, 384, 388, 389, 392, 396, 397, 398, 399, 400, 401, 402, 403, 404, 408, 409, 410, 411, 416, 418, 428, 429], "summary": {"covered_lines": 123, "num_statements": 180, "percent_covered": 68.33333333333333, "percent_covered_display": "68", "missing_lines": 57, "excluded_lines": 0}, "missing_lines": [75, 76, 101, 102, 125, 132, 133, 134, 158, 159, 160, 165, 166, 168, 169, 170, 176, 177, 181, 190, 191, 193, 194, 196, 223, 224, 225, 226, 240, 241, 243, 244, 245, 253, 254, 255, 256, 264, 267, 268, 273, 274, 275, 282, 283, 284, 301, 302, 307, 308, 309, 335, 336, 356, 367, 385, 412], "excluded_lines": []}, "": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 20, 21, 22, 24, 25, 26, 27, 28, 29, 30, 33, 34, 36, 48, 78, 136, 202, 247, 277, 311, 340, 372, 394, 406, 414, 432, 501], "summary": {"covered_lines": 30, "num_statements": 69, "percent_covered": 43.47826086956522, "percent_covered_display": "43", "missing_lines": 39, "excluded_lines": 0}, "missing_lines": [434, 435, 437, 440, 443, 444, 445, 446, 448, 452, 453, 454, 455, 459, 462, 463, 465, 468, 470, 472, 473, 479, 481, 482, 483, 485, 486, 487, 488, 489, 490, 491, 492, 493, 494, 496, 497, 498, 502], "excluded_lines": []}}}, "db_migrate.py": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 13, 14, 16, 17, 19, 20, 22, 23, 26, 27, 30, 31, 32, 34, 35, 36, 37, 38, 39, 40, 41, 44, 45, 47, 56, 57, 58, 59, 61, 62, 63, 65, 72, 73, 83, 91, 92, 98, 108, 124, 135, 136, 137, 138, 140, 147, 148, 156, 157, 158, 160, 170, 171, 172, 173, 175, 176, 177, 178, 179, 184, 192, 194, 195, 196, 207, 208, 209, 210, 211, 213, 214, 223, 227, 229, 240, 242, 243, 244, 245, 249, 287, 299, 300, 304, 305, 306, 338, 413], "summary": {"covered_lines": 89, "num_statements": 221, "percent_covered": 40.27149321266968, "percent_covered_display": "40", "missing_lines": 132, "excluded_lines": 0}, "missing_lines": [18, 24, 25, 74, 75, 76, 77, 78, 80, 81, 84, 85, 86, 87, 88, 94, 95, 96, 100, 101, 102, 103, 104, 105, 106, 110, 112, 113, 114, 115, 122, 180, 181, 182, 199, 200, 201, 202, 203, 204, 224, 225, 246, 247, 248, 251, 252, 253, 254, 255, 261, 267, 268, 269, 272, 276, 278, 279, 281, 282, 283, 284, 285, 301, 302, 308, 309, 310, 312, 314, 315, 316, 317, 318, 320, 321, 322, 323, 324, 325, 326, 328, 329, 331, 332, 333, 334, 335, 340, 341, 343, 344, 347, 350, 351, 352, 356, 357, 361, 362, 363, 367, 369, 372, 373, 374, 375, 378, 379, 380, 382, 384, 385, 387, 388, 390, 391, 392, 393, 394, 396, 397, 398, 399, 401, 402, 403, 405, 406, 407, 410, 414], "excluded_lines": [], "functions": {"MigrationManager.__init__": {"executed_lines": [56, 57, 58, 59, 61, 62, 63], "summary": {"covered_lines": 7, "num_statements": 7, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "MigrationManager.connect": {"executed_lines": [72, 73, 83, 91, 92], "summary": {"covered_lines": 5, "num_statements": 20, "percent_covered": 25.0, "percent_covered_display": "25", "missing_lines": 15, "excluded_lines": 0}, "missing_lines": [74, 75, 76, 77, 78, 80, 81, 84, 85, 86, 87, 88, 94, 95, 96], "excluded_lines": []}, "MigrationManager.disconnect": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 7, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 7, "excluded_lines": 0}, "missing_lines": [100, 101, 102, 103, 104, 105, 106], "excluded_lines": []}, "MigrationManager._ensure_migrations_table": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 6, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 6, "excluded_lines": 0}, "missing_lines": [110, 112, 113, 114, 115, 122], "excluded_lines": []}, "MigrationManager.generate_migration": {"executed_lines": [135, 136, 137, 138, 140, 147, 148, 156, 157, 158, 160, 170, 171, 172, 173, 175, 176, 177, 178, 179], "summary": {"covered_lines": 20, "num_statements": 23, "percent_covered": 86.95652173913044, "percent_covered_display": "87", "missing_lines": 3, "excluded_lines": 0}, "missing_lines": [180, 181, 182], "excluded_lines": []}, "MigrationManager.get_pending_migrations": {"executed_lines": [192, 194, 195, 196, 207, 208, 209, 210, 211, 213, 214, 223, 227], "summary": {"covered_lines": 13, "num_statements": 21, "percent_covered": 61.904761904761905, "percent_covered_display": "62", "missing_lines": 8, "excluded_lines": 0}, "missing_lines": [199, 200, 201, 202, 203, 204, 224, 225], "excluded_lines": []}, "MigrationManager.apply_migration": {"executed_lines": [240, 242, 243, 244, 245, 249], "summary": {"covered_lines": 6, "num_statements": 27, "percent_covered": 22.22222222222222, "percent_covered_display": "22", "missing_lines": 21, "excluded_lines": 0}, "missing_lines": [246, 247, 248, 251, 252, 253, 254, 255, 261, 267, 268, 269, 272, 276, 278, 279, 281, 282, 283, 284, 285], "excluded_lines": []}, "MigrationManager.rollback_migration": {"executed_lines": [299, 300, 304, 305, 306], "summary": {"covered_lines": 5, "num_statements": 30, "percent_covered": 16.666666666666668, "percent_covered_display": "17", "missing_lines": 25, "excluded_lines": 0}, "missing_lines": [301, 302, 308, 309, 310, 312, 314, 315, 316, 317, 318, 320, 321, 322, 323, 324, 325, 326, 328, 329, 331, 332, 333, 334, 335], "excluded_lines": []}, "main": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 43, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 43, "excluded_lines": 0}, "missing_lines": [340, 341, 343, 344, 347, 350, 351, 352, 356, 357, 361, 362, 363, 367, 369, 372, 373, 374, 375, 378, 379, 380, 382, 384, 385, 387, 388, 390, 391, 392, 393, 394, 396, 397, 398, 399, 401, 402, 403, 405, 406, 407, 410], "excluded_lines": []}, "": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 13, 14, 16, 17, 19, 20, 22, 23, 26, 27, 30, 31, 32, 34, 35, 36, 37, 38, 39, 40, 41, 44, 45, 47, 65, 98, 108, 124, 184, 229, 287, 338, 413], "summary": {"covered_lines": 33, "num_statements": 37, "percent_covered": 89.1891891891892, "percent_covered_display": "89", "missing_lines": 4, "excluded_lines": 0}, "missing_lines": [18, 24, 25, 414], "excluded_lines": []}}, "classes": {"Migration": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 0, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "MigrationManager": {"executed_lines": [56, 57, 58, 59, 61, 62, 63, 72, 73, 83, 91, 92, 135, 136, 137, 138, 140, 147, 148, 156, 157, 158, 160, 170, 171, 172, 173, 175, 176, 177, 178, 179, 192, 194, 195, 196, 207, 208, 209, 210, 211, 213, 214, 223, 227, 240, 242, 243, 244, 245, 249, 299, 300, 304, 305, 306], "summary": {"covered_lines": 56, "num_statements": 141, "percent_covered": 39.716312056737586, "percent_covered_display": "40", "missing_lines": 85, "excluded_lines": 0}, "missing_lines": [74, 75, 76, 77, 78, 80, 81, 84, 85, 86, 87, 88, 94, 95, 96, 100, 101, 102, 103, 104, 105, 106, 110, 112, 113, 114, 115, 122, 180, 181, 182, 199, 200, 201, 202, 203, 204, 224, 225, 246, 247, 248, 251, 252, 253, 254, 255, 261, 267, 268, 269, 272, 276, 278, 279, 281, 282, 283, 284, 285, 301, 302, 308, 309, 310, 312, 314, 315, 316, 317, 318, 320, 321, 322, 323, 324, 325, 326, 328, 329, 331, 332, 333, 334, 335], "excluded_lines": []}, "": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 13, 14, 16, 17, 19, 20, 22, 23, 26, 27, 30, 31, 32, 34, 35, 36, 37, 38, 39, 40, 41, 44, 45, 47, 65, 98, 108, 124, 184, 229, 287, 338, 413], "summary": {"covered_lines": 33, "num_statements": 80, "percent_covered": 41.25, "percent_covered_display": "41", "missing_lines": 47, "excluded_lines": 0}, "missing_lines": [18, 24, 25, 340, 341, 343, 344, 347, 350, 351, 352, 356, 357, 361, 362, 363, 367, 369, 372, 373, 374, 375, 378, 379, 380, 382, 384, 385, 387, 388, 390, 391, 392, 393, 394, 396, 397, 398, 399, 401, 402, 403, 405, 406, 407, 410, 414], "excluded_lines": []}}}, "db_performance_check.py": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 14, 15, 17, 18, 20, 21, 24, 25, 28, 29, 30, 32, 33, 34, 35, 36, 39, 40, 41, 43, 44, 45, 46, 49, 50, 51, 53, 54, 55, 56, 57, 58, 61, 62, 64, 73, 74, 75, 77, 78, 79, 81, 83, 84, 93, 101, 102, 108, 110, 111, 112, 113, 114, 118, 137, 222, 340, 342, 343, 344, 345, 346, 348, 349, 350, 351, 352, 354, 356, 357, 358, 359, 360, 361, 362, 363, 365, 369, 370, 371, 372, 373, 374, 375, 376, 378, 379, 380, 387, 389, 392, 401, 402, 404, 407, 443], "summary": {"covered_lines": 85, "num_statements": 194, "percent_covered": 43.81443298969072, "percent_covered_display": "44", "missing_lines": 109, "excluded_lines": 0}, "missing_lines": [16, 22, 23, 85, 86, 87, 88, 89, 90, 91, 94, 95, 96, 97, 98, 104, 105, 106, 115, 116, 125, 126, 127, 128, 129, 131, 133, 134, 135, 139, 140, 143, 144, 145, 148, 153, 155, 164, 165, 166, 168, 171, 176, 178, 181, 183, 185, 186, 187, 188, 189, 192, 193, 194, 202, 203, 205, 213, 224, 225, 227, 229, 234, 236, 238, 250, 251, 258, 272, 273, 281, 293, 294, 295, 300, 308, 310, 313, 315, 320, 322, 331, 364, 367, 381, 382, 383, 385, 409, 410, 412, 413, 415, 417, 419, 421, 422, 424, 425, 426, 428, 429, 431, 432, 434, 436, 437, 440, 444], "excluded_lines": [], "functions": {"PerformanceAnalyzer.__init__": {"executed_lines": [73, 74, 75, 77, 78, 79], "summary": {"covered_lines": 6, "num_statements": 6, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "PerformanceAnalyzer.connect": {"executed_lines": [83, 84, 93, 101, 102], "summary": {"covered_lines": 5, "num_statements": 20, "percent_covered": 25.0, "percent_covered_display": "25", "missing_lines": 15, "excluded_lines": 0}, "missing_lines": [85, 86, 87, 88, 89, 90, 91, 94, 95, 96, 97, 98, 104, 105, 106], "excluded_lines": []}, "PerformanceAnalyzer.disconnect": {"executed_lines": [110, 111, 112, 113, 114], "summary": {"covered_lines": 5, "num_statements": 7, "percent_covered": 71.42857142857143, "percent_covered_display": "71", "missing_lines": 2, "excluded_lines": 0}, "missing_lines": [115, 116], "excluded_lines": []}, "PerformanceAnalyzer.analyze": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 9, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 9, "excluded_lines": 0}, "missing_lines": [125, 126, 127, 128, 129, 131, 133, 134, 135], "excluded_lines": []}, "PerformanceAnalyzer._analyze_mongodb": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 29, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 29, "excluded_lines": 0}, "missing_lines": [139, 140, 143, 144, 145, 148, 153, 155, 164, 165, 166, 168, 171, 176, 178, 181, 183, 185, 186, 187, 188, 189, 192, 193, 194, 202, 203, 205, 213], "excluded_lines": []}, "PerformanceAnalyzer._analyze_postgres": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 24, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 24, "excluded_lines": 0}, "missing_lines": [224, 225, 227, 229, 234, 236, 238, 250, 251, 258, 272, 273, 281, 293, 294, 295, 300, 308, 310, 313, 315, 320, 322, 331], "excluded_lines": []}, "PerformanceAnalyzer.print_report": {"executed_lines": [342, 343, 344, 345, 346, 348, 349, 350, 351, 352, 354, 356, 357, 358, 359, 360, 361, 362, 363, 365, 369, 370, 371, 372, 373, 374, 375, 376, 378, 379, 380, 387], "summary": {"covered_lines": 32, "num_statements": 38, "percent_covered": 84.21052631578948, "percent_covered_display": "84", "missing_lines": 6, "excluded_lines": 0}, "missing_lines": [364, 367, 381, 382, 383, 385], "excluded_lines": []}, "PerformanceAnalyzer.save_report": {"executed_lines": [392, 401, 402, 404], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "main": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 20, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 20, "excluded_lines": 0}, "missing_lines": [409, 410, 412, 413, 415, 417, 419, 421, 422, 424, 425, 426, 428, 429, 431, 432, 434, 436, 437, 440], "excluded_lines": []}, "": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 14, 15, 17, 18, 20, 21, 24, 25, 28, 29, 30, 32, 33, 34, 35, 36, 39, 40, 41, 43, 44, 45, 46, 49, 50, 51, 53, 54, 55, 56, 57, 58, 61, 62, 64, 81, 108, 118, 137, 222, 340, 389, 407, 443], "summary": {"covered_lines": 33, "num_statements": 37, "percent_covered": 89.1891891891892, "percent_covered_display": "89", "missing_lines": 4, "excluded_lines": 0}, "missing_lines": [16, 22, 23, 444], "excluded_lines": []}}, "classes": {"SlowQuery": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 0, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "IndexRecommendation": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 0, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "PerformanceReport": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 0, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "PerformanceAnalyzer": {"executed_lines": [73, 74, 75, 77, 78, 79, 83, 84, 93, 101, 102, 110, 111, 112, 113, 114, 342, 343, 344, 345, 346, 348, 349, 350, 351, 352, 354, 356, 357, 358, 359, 360, 361, 362, 363, 365, 369, 370, 371, 372, 373, 374, 375, 376, 378, 379, 380, 387, 392, 401, 402, 404], "summary": {"covered_lines": 52, "num_statements": 137, "percent_covered": 37.956204379562045, "percent_covered_display": "38", "missing_lines": 85, "excluded_lines": 0}, "missing_lines": [85, 86, 87, 88, 89, 90, 91, 94, 95, 96, 97, 98, 104, 105, 106, 115, 116, 125, 126, 127, 128, 129, 131, 133, 134, 135, 139, 140, 143, 144, 145, 148, 153, 155, 164, 165, 166, 168, 171, 176, 178, 181, 183, 185, 186, 187, 188, 189, 192, 193, 194, 202, 203, 205, 213, 224, 225, 227, 229, 234, 236, 238, 250, 251, 258, 272, 273, 281, 293, 294, 295, 300, 308, 310, 313, 315, 320, 322, 331, 364, 367, 381, 382, 383, 385], "excluded_lines": []}, "": {"executed_lines": [2, 7, 8, 9, 10, 11, 12, 14, 15, 17, 18, 20, 21, 24, 25, 28, 29, 30, 32, 33, 34, 35, 36, 39, 40, 41, 43, 44, 45, 46, 49, 50, 51, 53, 54, 55, 56, 57, 58, 61, 62, 64, 81, 108, 118, 137, 222, 340, 389, 407, 443], "summary": {"covered_lines": 33, "num_statements": 57, "percent_covered": 57.89473684210526, "percent_covered_display": "58", "missing_lines": 24, "excluded_lines": 0}, "missing_lines": [16, 22, 23, 409, 410, 412, 413, 415, 417, 419, 421, 422, 424, 425, 426, 428, 429, 431, 432, 434, 436, 437, 440, 444], "excluded_lines": []}}}, "tests/test_db_backup.py": {"executed_lines": [1, 3, 4, 5, 6, 7, 9, 12, 14, 17, 18, 20, 21, 22, 25, 26, 28, 39, 40, 42, 44, 53, 54, 55, 56, 57, 58, 61, 62, 64, 66, 68, 69, 71, 72, 74, 76, 77, 84, 85, 86, 87, 89, 90, 92, 94, 96, 97, 99, 106, 110, 112, 113, 120, 122, 123, 125, 127, 129, 132, 139, 140, 141, 143, 145, 148, 151, 152, 155, 156, 157, 158, 159, 161, 163, 166, 169, 171, 172, 173, 175, 176, 178, 180, 183, 184, 186, 191, 192, 194, 195, 197, 199, 202, 203, 205, 206, 208, 213, 215, 217, 219, 224, 226, 228, 231, 232, 234, 240, 242, 244, 247, 248, 251, 252, 255, 257, 258, 260, 262, 265, 266, 268, 269, 272, 274, 275, 277, 279, 282, 283, 285, 287, 289, 291, 294, 295, 297, 299, 301, 303, 305, 306, 307, 308, 310, 312, 314, 315, 317, 319, 321, 323, 325, 326, 327, 328, 330, 332, 336, 339], "summary": {"covered_lines": 158, "num_statements": 161, "percent_covered": 98.13664596273291, "percent_covered_display": "98", "missing_lines": 3, "excluded_lines": 0}, "missing_lines": [107, 108, 340], "excluded_lines": [], "functions": {"temp_backup_dir": {"executed_lines": [20, 21, 22], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "sample_backup_info": {"executed_lines": [28], "summary": {"covered_lines": 1, "num_statements": 1, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupInfo.test_backup_info_creation": {"executed_lines": [44, 53, 54, 55, 56, 57, 58], "summary": {"covered_lines": 7, "num_statements": 7, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_init": {"executed_lines": [66, 68, 69], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_backup_mongodb": {"executed_lines": [74, 76, 77, 84, 85, 86, 87], "summary": {"covered_lines": 7, "num_statements": 7, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_backup_postgres": {"executed_lines": [92, 94, 96, 97, 99, 106], "summary": {"covered_lines": 6, "num_statements": 8, "percent_covered": 75.0, "percent_covered_display": "75", "missing_lines": 2, "excluded_lines": 0}, "missing_lines": [107, 108], "excluded_lines": []}, "TestBackupManager.test_backup_postgres_no_database": {"executed_lines": [112, 113, 120], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_backup_with_compression": {"executed_lines": [125, 127, 129, 132, 139, 140, 141], "summary": {"covered_lines": 7, "num_statements": 7, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_save_and_load_metadata": {"executed_lines": [145, 148, 151, 152, 155, 156, 157, 158, 159], "summary": {"covered_lines": 9, "num_statements": 9, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_list_backups": {"executed_lines": [163, 166, 169, 171, 172, 173], "summary": {"covered_lines": 6, "num_statements": 6, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_restore_mongodb": {"executed_lines": [178, 180, 183, 184, 186, 191, 192], "summary": {"covered_lines": 7, "num_statements": 7, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_restore_postgres": {"executed_lines": [197, 199, 202, 203, 205, 206, 208, 213], "summary": {"covered_lines": 8, "num_statements": 8, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_restore_nonexistent_backup": {"executed_lines": [217, 219, 224], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_restore_dry_run": {"executed_lines": [228, 231, 232, 234, 240], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_cleanup_old_backups": {"executed_lines": [244, 247, 248, 251, 252, 255, 257, 258], "summary": {"covered_lines": 8, "num_statements": 8, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_cleanup_dry_run": {"executed_lines": [262, 265, 266, 268, 269, 272, 274, 275], "summary": {"covered_lines": 8, "num_statements": 8, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_verify_backup": {"executed_lines": [279, 282, 283, 285, 287], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_verify_empty_backup": {"executed_lines": [291, 294, 295, 297, 299], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_format_size": {"executed_lines": [303, 305, 306, 307, 308], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_get_size_file": {"executed_lines": [312, 314, 315, 317, 319], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager.test_get_size_directory": {"executed_lines": [323, 325, 326, 327, 328, 330, 332], "summary": {"covered_lines": 7, "num_statements": 7, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "": {"executed_lines": [1, 3, 4, 5, 6, 7, 9, 12, 14, 17, 18, 25, 26, 39, 40, 42, 61, 62, 64, 71, 72, 89, 90, 110, 122, 123, 143, 161, 175, 176, 194, 195, 215, 226, 242, 260, 277, 289, 301, 310, 321, 336, 339], "summary": {"covered_lines": 40, "num_statements": 41, "percent_covered": 97.5609756097561, "percent_covered_display": "98", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [340], "excluded_lines": []}}, "classes": {"TestBackupInfo": {"executed_lines": [44, 53, 54, 55, 56, 57, 58], "summary": {"covered_lines": 7, "num_statements": 7, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestBackupManager": {"executed_lines": [66, 68, 69, 74, 76, 77, 84, 85, 86, 87, 92, 94, 96, 97, 99, 106, 112, 113, 120, 125, 127, 129, 132, 139, 140, 141, 145, 148, 151, 152, 155, 156, 157, 158, 159, 163, 166, 169, 171, 172, 173, 178, 180, 183, 184, 186, 191, 192, 197, 199, 202, 203, 205, 206, 208, 213, 217, 219, 224, 228, 231, 232, 234, 240, 244, 247, 248, 251, 252, 255, 257, 258, 262, 265, 266, 268, 269, 272, 274, 275, 279, 282, 283, 285, 287, 291, 294, 295, 297, 299, 303, 305, 306, 307, 308, 312, 314, 315, 317, 319, 323, 325, 326, 327, 328, 330, 332], "summary": {"covered_lines": 107, "num_statements": 109, "percent_covered": 98.1651376146789, "percent_covered_display": "98", "missing_lines": 2, "excluded_lines": 0}, "missing_lines": [107, 108], "excluded_lines": []}, "": {"executed_lines": [1, 3, 4, 5, 6, 7, 9, 12, 14, 17, 18, 20, 21, 22, 25, 26, 28, 39, 40, 42, 61, 62, 64, 71, 72, 89, 90, 110, 122, 123, 143, 161, 175, 176, 194, 195, 215, 226, 242, 260, 277, 289, 301, 310, 321, 336, 339], "summary": {"covered_lines": 44, "num_statements": 45, "percent_covered": 97.77777777777777, "percent_covered_display": "98", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [340], "excluded_lines": []}}}, "tests/test_db_migrate.py": {"executed_lines": [1, 3, 4, 5, 6, 7, 8, 10, 13, 15, 18, 19, 21, 22, 23, 26, 27, 29, 30, 31, 32, 33, 36, 37, 39, 40, 41, 42, 45, 46, 48, 50, 57, 58, 59, 60, 63, 64, 66, 68, 70, 71, 72, 74, 75, 87, 88, 99, 101, 102, 104, 106, 108, 109, 111, 112, 115, 116, 119, 120, 121, 122, 124, 126, 127, 129, 132, 133, 135, 137, 140, 148, 149, 150, 153, 154, 156, 158, 159, 160, 162, 163, 192, 194, 196, 204, 206, 208, 209, 237, 239, 241, 243, 246, 248, 251, 252, 260, 261, 262, 264, 265, 267, 270, 271, 272, 273, 276], "summary": {"covered_lines": 105, "num_statements": 139, "percent_covered": 75.53956834532374, "percent_covered_display": "76", "missing_lines": 34, "excluded_lines": 0}, "missing_lines": [77, 78, 80, 81, 83, 84, 85, 90, 91, 93, 94, 96, 97, 165, 166, 168, 169, 171, 186, 188, 189, 190, 211, 212, 214, 215, 218, 227, 228, 229, 231, 233, 235, 277], "excluded_lines": [], "functions": {"temp_migrations_dir": {"executed_lines": [21, 22, 23], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "mock_mongo_client": {"executed_lines": [29, 30, 31, 32, 33], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "mock_postgres_conn": {"executed_lines": [39, 40, 41, 42], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigration.test_migration_creation": {"executed_lines": [50, 57, 58, 59, 60], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager.test_init": {"executed_lines": [68, 70, 71, 72], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager.test_connect_mongodb": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 7, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 7, "excluded_lines": 0}, "missing_lines": [77, 78, 80, 81, 83, 84, 85], "excluded_lines": []}, "TestMigrationManager.test_connect_postgres": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 6, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 6, "excluded_lines": 0}, "missing_lines": [90, 91, 93, 94, 96, 97], "excluded_lines": []}, "TestMigrationManager.test_connect_unsupported_db": {"executed_lines": [101, 102, 104], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager.test_generate_migration": {"executed_lines": [108, 109, 111, 112, 115, 116, 119, 120, 121, 122], "summary": {"covered_lines": 10, "num_statements": 10, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager.test_generate_migration_dry_run": {"executed_lines": [126, 127, 129, 132, 133], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager.test_get_pending_migrations": {"executed_lines": [137, 140, 148, 149, 150, 153, 154, 156, 158, 159, 160], "summary": {"covered_lines": 11, "num_statements": 11, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager.test_apply_mongodb_migration": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 9, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 9, "excluded_lines": 0}, "missing_lines": [165, 166, 168, 169, 171, 186, 188, 189, 190], "excluded_lines": []}, "TestMigrationManager.test_apply_migration_dry_run": {"executed_lines": [194, 196, 204, 206], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager.test_rollback_postgres_migration": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 11, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 11, "excluded_lines": 0}, "missing_lines": [211, 212, 214, 215, 218, 227, 228, 229, 231, 233, 235], "excluded_lines": []}, "TestMigrationManager.test_rollback_migration_not_found": {"executed_lines": [239, 241, 243], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "test_migration_sorting": {"executed_lines": [248, 251, 252, 260, 261, 262, 264, 265, 267, 270, 271, 272, 273], "summary": {"covered_lines": 13, "num_statements": 13, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "": {"executed_lines": [1, 3, 4, 5, 6, 7, 8, 10, 13, 15, 18, 19, 26, 27, 36, 37, 45, 46, 48, 63, 64, 66, 74, 75, 87, 88, 99, 106, 124, 135, 162, 163, 192, 208, 209, 237, 246, 276], "summary": {"covered_lines": 35, "num_statements": 36, "percent_covered": 97.22222222222223, "percent_covered_display": "97", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [277], "excluded_lines": []}}, "classes": {"TestMigration": {"executed_lines": [50, 57, 58, 59, 60], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestMigrationManager": {"executed_lines": [68, 70, 71, 72, 101, 102, 104, 108, 109, 111, 112, 115, 116, 119, 120, 121, 122, 126, 127, 129, 132, 133, 137, 140, 148, 149, 150, 153, 154, 156, 158, 159, 160, 194, 196, 204, 206, 239, 241, 243], "summary": {"covered_lines": 40, "num_statements": 73, "percent_covered": 54.794520547945204, "percent_covered_display": "55", "missing_lines": 33, "excluded_lines": 0}, "missing_lines": [77, 78, 80, 81, 83, 84, 85, 90, 91, 93, 94, 96, 97, 165, 166, 168, 169, 171, 186, 188, 189, 190, 211, 212, 214, 215, 218, 227, 228, 229, 231, 233, 235], "excluded_lines": []}, "": {"executed_lines": [1, 3, 4, 5, 6, 7, 8, 10, 13, 15, 18, 19, 21, 22, 23, 26, 27, 29, 30, 31, 32, 33, 36, 37, 39, 40, 41, 42, 45, 46, 48, 63, 64, 66, 74, 75, 87, 88, 99, 106, 124, 135, 162, 163, 192, 208, 209, 237, 246, 248, 251, 252, 260, 261, 262, 264, 265, 267, 270, 271, 272, 273, 276], "summary": {"covered_lines": 60, "num_statements": 61, "percent_covered": 98.36065573770492, "percent_covered_display": "98", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [277], "excluded_lines": []}}}, "tests/test_db_performance_check.py": {"executed_lines": [1, 3, 4, 5, 6, 7, 9, 12, 14, 19, 20, 22, 23, 24, 25, 26, 29, 30, 32, 33, 34, 35, 38, 39, 41, 43, 49, 50, 51, 54, 55, 57, 59, 66, 67, 68, 69, 72, 73, 75, 77, 86, 87, 88, 89, 90, 93, 94, 96, 98, 100, 101, 102, 104, 105, 117, 118, 129, 131, 132, 134, 136, 137, 194, 195, 242, 244, 246, 272, 274, 275, 276, 277, 280, 282, 284, 293, 294, 296, 298, 299, 300, 301, 303, 305, 308, 309, 311, 313, 314, 316, 317, 333, 334, 336, 337, 369], "summary": {"covered_lines": 91, "num_statements": 160, "percent_covered": 56.875, "percent_covered_display": "57", "missing_lines": 69, "excluded_lines": 0}, "missing_lines": [107, 108, 110, 111, 113, 114, 115, 120, 121, 123, 124, 126, 127, 139, 140, 143, 149, 150, 158, 161, 164, 165, 166, 167, 170, 173, 177, 183, 184, 186, 188, 189, 190, 191, 192, 197, 198, 201, 208, 232, 233, 235, 237, 238, 239, 240, 278, 319, 320, 323, 325, 326, 328, 330, 339, 340, 343, 344, 345, 346, 351, 354, 357, 358, 361, 362, 363, 366, 370], "excluded_lines": [], "functions": {"mock_mongo_client": {"executed_lines": [22, 23, 24, 25, 26], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "mock_postgres_conn": {"executed_lines": [32, 33, 34, 35], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestSlowQuery.test_slow_query_creation": {"executed_lines": [43, 49, 50, 51], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestIndexRecommendation.test_recommendation_creation": {"executed_lines": [59, 66, 67, 68, 69], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceReport.test_report_creation": {"executed_lines": [77, 86, 87, 88, 89, 90], "summary": {"covered_lines": 6, "num_statements": 6, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceAnalyzer.test_init": {"executed_lines": [98, 100, 101, 102], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceAnalyzer.test_connect_mongodb": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 7, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 7, "excluded_lines": 0}, "missing_lines": [107, 108, 110, 111, 113, 114, 115], "excluded_lines": []}, "TestPerformanceAnalyzer.test_connect_postgres": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 6, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 6, "excluded_lines": 0}, "missing_lines": [120, 121, 123, 124, 126, 127], "excluded_lines": []}, "TestPerformanceAnalyzer.test_connect_unsupported_db": {"executed_lines": [131, 132, 134], "summary": {"covered_lines": 3, "num_statements": 3, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceAnalyzer.test_analyze_mongodb": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 22, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 22, "excluded_lines": 0}, "missing_lines": [139, 140, 143, 149, 150, 158, 161, 164, 165, 166, 167, 170, 173, 177, 183, 184, 186, 188, 189, 190, 191, 192], "excluded_lines": []}, "TestPerformanceAnalyzer.test_analyze_postgres": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 11, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 11, "excluded_lines": 0}, "missing_lines": [197, 198, 201, 208, 232, 233, 235, 237, 238, 239, 240], "excluded_lines": []}, "TestPerformanceAnalyzer.test_print_report": {"executed_lines": [244, 246, 272, 274, 275, 276, 277], "summary": {"covered_lines": 7, "num_statements": 8, "percent_covered": 87.5, "percent_covered_display": "88", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [278], "excluded_lines": []}, "TestPerformanceAnalyzer.test_save_report": {"executed_lines": [282, 284, 293, 294, 296, 298, 299, 300, 301], "summary": {"covered_lines": 9, "num_statements": 9, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceAnalyzer.test_disconnect": {"executed_lines": [305, 308, 309, 311, 313, 314], "summary": {"covered_lines": 6, "num_statements": 6, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceAnalyzer.test_analyze_error_handling": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 7, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 7, "excluded_lines": 0}, "missing_lines": [319, 320, 323, 325, 326, 328, 330], "excluded_lines": []}, "TestIntegration.test_full_mongodb_workflow": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 14, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 14, "excluded_lines": 0}, "missing_lines": [339, 340, 343, 344, 345, 346, 351, 354, 357, 358, 361, 362, 363, 366], "excluded_lines": []}, "": {"executed_lines": [1, 3, 4, 5, 6, 7, 9, 12, 14, 19, 20, 29, 30, 38, 39, 41, 54, 55, 57, 72, 73, 75, 93, 94, 96, 104, 105, 117, 118, 129, 136, 137, 194, 195, 242, 280, 303, 316, 317, 333, 334, 336, 337, 369], "summary": {"covered_lines": 38, "num_statements": 39, "percent_covered": 97.43589743589743, "percent_covered_display": "97", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [370], "excluded_lines": []}}, "classes": {"TestSlowQuery": {"executed_lines": [43, 49, 50, 51], "summary": {"covered_lines": 4, "num_statements": 4, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestIndexRecommendation": {"executed_lines": [59, 66, 67, 68, 69], "summary": {"covered_lines": 5, "num_statements": 5, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceReport": {"executed_lines": [77, 86, 87, 88, 89, 90], "summary": {"covered_lines": 6, "num_statements": 6, "percent_covered": 100.0, "percent_covered_display": "100", "missing_lines": 0, "excluded_lines": 0}, "missing_lines": [], "excluded_lines": []}, "TestPerformanceAnalyzer": {"executed_lines": [98, 100, 101, 102, 131, 132, 134, 244, 246, 272, 274, 275, 276, 277, 282, 284, 293, 294, 296, 298, 299, 300, 301, 305, 308, 309, 311, 313, 314], "summary": {"covered_lines": 29, "num_statements": 83, "percent_covered": 34.93975903614458, "percent_covered_display": "35", "missing_lines": 54, "excluded_lines": 0}, "missing_lines": [107, 108, 110, 111, 113, 114, 115, 120, 121, 123, 124, 126, 127, 139, 140, 143, 149, 150, 158, 161, 164, 165, 166, 167, 170, 173, 177, 183, 184, 186, 188, 189, 190, 191, 192, 197, 198, 201, 208, 232, 233, 235, 237, 238, 239, 240, 278, 319, 320, 323, 325, 326, 328, 330], "excluded_lines": []}, "TestIntegration": {"executed_lines": [], "summary": {"covered_lines": 0, "num_statements": 14, "percent_covered": 0.0, "percent_covered_display": "0", "missing_lines": 14, "excluded_lines": 0}, "missing_lines": [339, 340, 343, 344, 345, 346, 351, 354, 357, 358, 361, 362, 363, 366], "excluded_lines": []}, "": {"executed_lines": [1, 3, 4, 5, 6, 7, 9, 12, 14, 19, 20, 22, 23, 24, 25, 26, 29, 30, 32, 33, 34, 35, 38, 39, 41, 54, 55, 57, 72, 73, 75, 93, 94, 96, 104, 105, 117, 118, 129, 136, 137, 194, 195, 242, 280, 303, 316, 317, 333, 334, 336, 337, 369], "summary": {"covered_lines": 47, "num_statements": 48, "percent_covered": 97.91666666666667, "percent_covered_display": "98", "missing_lines": 1, "excluded_lines": 0}, "missing_lines": [370], "excluded_lines": []}}}}, "totals": {"covered_lines": 681, "num_statements": 1124, "percent_covered": 60.587188612099645, "percent_covered_display": "61", "missing_lines": 443, "excluded_lines": 0}}
@@ -0,0 +1,4 @@
1
+ pytest>=7.0.0
2
+ pytest-cov>=4.0.0
3
+ pytest-mock>=3.10.0
4
+ mongomock>=4.1.0