@sk8metal/michi-cli 0.0.8 → 0.1.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 (433) hide show
  1. package/CHANGELOG.md +60 -0
  2. package/README.md +420 -49
  3. package/dist/scripts/__tests__/create-project.test.js +24 -28
  4. package/dist/scripts/__tests__/create-project.test.js.map +1 -1
  5. package/dist/scripts/__tests__/jira-transitions.test.d.ts +5 -0
  6. package/dist/scripts/__tests__/jira-transitions.test.d.ts.map +1 -0
  7. package/dist/scripts/__tests__/jira-transitions.test.js +172 -0
  8. package/dist/scripts/__tests__/jira-transitions.test.js.map +1 -0
  9. package/dist/scripts/__tests__/multi-project-estimate.test.js +14 -15
  10. package/dist/scripts/__tests__/multi-project-estimate.test.js.map +1 -1
  11. package/dist/scripts/__tests__/setup-existing-project.test.js +146 -5
  12. package/dist/scripts/__tests__/setup-existing-project.test.js.map +1 -1
  13. package/dist/scripts/__tests__/setup-interactive.test.js +23 -17
  14. package/dist/scripts/__tests__/setup-interactive.test.js.map +1 -1
  15. package/dist/scripts/__tests__/spec-impl-workflow.test.d.ts +5 -0
  16. package/dist/scripts/__tests__/spec-impl-workflow.test.d.ts.map +1 -0
  17. package/dist/scripts/__tests__/spec-impl-workflow.test.js +321 -0
  18. package/dist/scripts/__tests__/spec-impl-workflow.test.js.map +1 -0
  19. package/dist/scripts/__tests__/spec-loader.test.d.ts +5 -0
  20. package/dist/scripts/__tests__/spec-loader.test.d.ts.map +1 -0
  21. package/dist/scripts/__tests__/spec-loader.test.js +153 -0
  22. package/dist/scripts/__tests__/spec-loader.test.js.map +1 -0
  23. package/dist/scripts/__tests__/validate-phase.test.js +26 -22
  24. package/dist/scripts/__tests__/validate-phase.test.js.map +1 -1
  25. package/dist/scripts/config/config-schema.d.ts +17 -0
  26. package/dist/scripts/config/config-schema.d.ts.map +1 -1
  27. package/dist/scripts/config/config-schema.js +55 -26
  28. package/dist/scripts/config/config-schema.js.map +1 -1
  29. package/dist/scripts/config-interactive.d.ts.map +1 -1
  30. package/dist/scripts/config-interactive.js +53 -38
  31. package/dist/scripts/config-interactive.js.map +1 -1
  32. package/dist/scripts/confluence-sync.d.ts.map +1 -1
  33. package/dist/scripts/confluence-sync.js +0 -11
  34. package/dist/scripts/confluence-sync.js.map +1 -1
  35. package/dist/scripts/constants/__tests__/environments.test.d.ts +2 -0
  36. package/dist/scripts/constants/__tests__/environments.test.d.ts.map +1 -0
  37. package/dist/scripts/constants/__tests__/environments.test.js +125 -0
  38. package/dist/scripts/constants/__tests__/environments.test.js.map +1 -0
  39. package/dist/scripts/constants/__tests__/languages.test.d.ts +2 -0
  40. package/dist/scripts/constants/__tests__/languages.test.d.ts.map +1 -0
  41. package/dist/scripts/constants/__tests__/languages.test.js +82 -0
  42. package/dist/scripts/constants/__tests__/languages.test.js.map +1 -0
  43. package/dist/scripts/constants/environments.d.ts +33 -0
  44. package/dist/scripts/constants/environments.d.ts.map +1 -0
  45. package/dist/scripts/constants/environments.js +64 -0
  46. package/dist/scripts/constants/environments.js.map +1 -0
  47. package/dist/scripts/constants/languages.d.ts +23 -0
  48. package/dist/scripts/constants/languages.d.ts.map +1 -0
  49. package/dist/scripts/constants/languages.js +53 -0
  50. package/dist/scripts/constants/languages.js.map +1 -0
  51. package/dist/scripts/constants/test-commands.d.ts +36 -0
  52. package/dist/scripts/constants/test-commands.d.ts.map +1 -0
  53. package/dist/scripts/constants/test-commands.js +70 -0
  54. package/dist/scripts/constants/test-commands.js.map +1 -0
  55. package/dist/scripts/create-project.d.ts +4 -0
  56. package/dist/scripts/create-project.d.ts.map +1 -1
  57. package/dist/scripts/create-project.js +51 -22
  58. package/dist/scripts/create-project.js.map +1 -1
  59. package/dist/scripts/jira-sync.d.ts +89 -3
  60. package/dist/scripts/jira-sync.d.ts.map +1 -1
  61. package/dist/scripts/jira-sync.js +366 -96
  62. package/dist/scripts/jira-sync.js.map +1 -1
  63. package/dist/scripts/markdown-to-confluence.js +1 -1
  64. package/dist/scripts/markdown-to-confluence.js.map +1 -1
  65. package/dist/scripts/phase-runner.d.ts +1 -1
  66. package/dist/scripts/phase-runner.d.ts.map +1 -1
  67. package/dist/scripts/phase-runner.js +809 -13
  68. package/dist/scripts/phase-runner.js.map +1 -1
  69. package/dist/scripts/pr-automation.d.ts.map +1 -1
  70. package/dist/scripts/pr-automation.js.map +1 -1
  71. package/dist/scripts/pre-flight-check.js +1 -1
  72. package/dist/scripts/pre-flight-check.js.map +1 -1
  73. package/dist/scripts/setup-existing-project.d.ts +3 -1
  74. package/dist/scripts/setup-existing-project.d.ts.map +1 -1
  75. package/dist/scripts/setup-existing-project.js +165 -78
  76. package/dist/scripts/setup-existing-project.js.map +1 -1
  77. package/dist/scripts/setup-interactive.js +3 -3
  78. package/dist/scripts/setup-interactive.js.map +1 -1
  79. package/dist/scripts/spec-impl-workflow.d.ts +94 -0
  80. package/dist/scripts/spec-impl-workflow.d.ts.map +1 -0
  81. package/dist/scripts/spec-impl-workflow.js +354 -0
  82. package/dist/scripts/spec-impl-workflow.js.map +1 -0
  83. package/dist/scripts/template/__tests__/renderer.test.d.ts +2 -0
  84. package/dist/scripts/template/__tests__/renderer.test.d.ts.map +1 -0
  85. package/dist/scripts/template/__tests__/renderer.test.js +165 -0
  86. package/dist/scripts/template/__tests__/renderer.test.js.map +1 -0
  87. package/dist/scripts/template/renderer.d.ts +70 -0
  88. package/dist/scripts/template/renderer.d.ts.map +1 -0
  89. package/dist/scripts/template/renderer.js +99 -0
  90. package/dist/scripts/template/renderer.js.map +1 -0
  91. package/dist/scripts/test-execution-generator.d.ts +52 -0
  92. package/dist/scripts/test-execution-generator.d.ts.map +1 -0
  93. package/dist/scripts/test-execution-generator.js +576 -0
  94. package/dist/scripts/test-execution-generator.js.map +1 -0
  95. package/dist/scripts/test-interactive.d.ts +10 -0
  96. package/dist/scripts/test-interactive.d.ts.map +1 -0
  97. package/dist/scripts/test-interactive.js +627 -0
  98. package/dist/scripts/test-interactive.js.map +1 -0
  99. package/dist/scripts/test-new-features.d.ts +5 -0
  100. package/dist/scripts/test-new-features.d.ts.map +1 -0
  101. package/dist/scripts/test-new-features.js +145 -0
  102. package/dist/scripts/test-new-features.js.map +1 -0
  103. package/dist/scripts/test-spec-generator.d.ts +29 -0
  104. package/dist/scripts/test-spec-generator.d.ts.map +1 -0
  105. package/dist/scripts/test-spec-generator.js +494 -0
  106. package/dist/scripts/test-spec-generator.js.map +1 -0
  107. package/dist/scripts/test-workflow-stages.d.ts +6 -0
  108. package/dist/scripts/test-workflow-stages.d.ts.map +1 -0
  109. package/dist/scripts/test-workflow-stages.js +43 -0
  110. package/dist/scripts/test-workflow-stages.js.map +1 -0
  111. package/dist/scripts/utils/__tests__/aidlc-parser.test.d.ts +5 -0
  112. package/dist/scripts/utils/__tests__/aidlc-parser.test.d.ts.map +1 -0
  113. package/dist/scripts/utils/__tests__/aidlc-parser.test.js +315 -0
  114. package/dist/scripts/utils/__tests__/aidlc-parser.test.js.map +1 -0
  115. package/dist/scripts/utils/__tests__/business-days.test.d.ts +5 -0
  116. package/dist/scripts/utils/__tests__/business-days.test.d.ts.map +1 -0
  117. package/dist/scripts/utils/__tests__/business-days.test.js +171 -0
  118. package/dist/scripts/utils/__tests__/business-days.test.js.map +1 -0
  119. package/dist/scripts/utils/__tests__/config-loader.test.js +1 -1
  120. package/dist/scripts/utils/__tests__/config-loader.test.js.map +1 -1
  121. package/dist/scripts/utils/__tests__/config-validator.test.js +164 -35
  122. package/dist/scripts/utils/__tests__/config-validator.test.js.map +1 -1
  123. package/dist/scripts/utils/__tests__/env-config.test.d.ts +5 -0
  124. package/dist/scripts/utils/__tests__/env-config.test.d.ts.map +1 -0
  125. package/dist/scripts/utils/__tests__/env-config.test.js +218 -0
  126. package/dist/scripts/utils/__tests__/env-config.test.js.map +1 -0
  127. package/dist/scripts/utils/__tests__/jira-issue-type-fetcher.test.d.ts +5 -0
  128. package/dist/scripts/utils/__tests__/jira-issue-type-fetcher.test.d.ts.map +1 -0
  129. package/dist/scripts/utils/__tests__/jira-issue-type-fetcher.test.js +202 -0
  130. package/dist/scripts/utils/__tests__/jira-issue-type-fetcher.test.js.map +1 -0
  131. package/dist/scripts/utils/__tests__/tasks-converter.test.d.ts +5 -0
  132. package/dist/scripts/utils/__tests__/tasks-converter.test.d.ts.map +1 -0
  133. package/dist/scripts/utils/__tests__/tasks-converter.test.js +500 -0
  134. package/dist/scripts/utils/__tests__/tasks-converter.test.js.map +1 -0
  135. package/dist/scripts/utils/__tests__/tasks-format-validator.test.d.ts +5 -0
  136. package/dist/scripts/utils/__tests__/tasks-format-validator.test.d.ts.map +1 -0
  137. package/dist/scripts/utils/__tests__/tasks-format-validator.test.js +314 -0
  138. package/dist/scripts/utils/__tests__/tasks-format-validator.test.js.map +1 -0
  139. package/dist/scripts/utils/__tests__/test-runner.test.d.ts +5 -0
  140. package/dist/scripts/utils/__tests__/test-runner.test.d.ts.map +1 -0
  141. package/dist/scripts/utils/__tests__/test-runner.test.js +64 -0
  142. package/dist/scripts/utils/__tests__/test-runner.test.js.map +1 -0
  143. package/dist/scripts/utils/aidlc-parser.d.ts +86 -0
  144. package/dist/scripts/utils/aidlc-parser.d.ts.map +1 -0
  145. package/dist/scripts/utils/aidlc-parser.js +208 -0
  146. package/dist/scripts/utils/aidlc-parser.js.map +1 -0
  147. package/dist/scripts/utils/business-days.d.ts +52 -0
  148. package/dist/scripts/utils/business-days.d.ts.map +1 -0
  149. package/dist/scripts/utils/business-days.js +98 -0
  150. package/dist/scripts/utils/business-days.js.map +1 -0
  151. package/dist/scripts/utils/ci-generator.d.ts +14 -0
  152. package/dist/scripts/utils/ci-generator.d.ts.map +1 -0
  153. package/dist/scripts/utils/ci-generator.js +61 -0
  154. package/dist/scripts/utils/ci-generator.js.map +1 -0
  155. package/dist/scripts/utils/config-loader.js +2 -2
  156. package/dist/scripts/utils/config-loader.js.map +1 -1
  157. package/dist/scripts/utils/config-validator.d.ts +7 -1
  158. package/dist/scripts/utils/config-validator.d.ts.map +1 -1
  159. package/dist/scripts/utils/config-validator.js +136 -23
  160. package/dist/scripts/utils/config-validator.js.map +1 -1
  161. package/dist/scripts/utils/confluence-approval.d.ts +46 -0
  162. package/dist/scripts/utils/confluence-approval.d.ts.map +1 -0
  163. package/dist/scripts/utils/confluence-approval.js +118 -0
  164. package/dist/scripts/utils/confluence-approval.js.map +1 -0
  165. package/dist/scripts/utils/confluence-hierarchy.d.ts.map +1 -1
  166. package/dist/scripts/utils/confluence-hierarchy.js +1 -1
  167. package/dist/scripts/utils/confluence-hierarchy.js.map +1 -1
  168. package/dist/scripts/utils/docker-generator.d.ts +9 -0
  169. package/dist/scripts/utils/docker-generator.d.ts.map +1 -0
  170. package/dist/scripts/utils/docker-generator.js +132 -0
  171. package/dist/scripts/utils/docker-generator.js.map +1 -0
  172. package/dist/scripts/utils/docker-requirement-detector.d.ts +15 -0
  173. package/dist/scripts/utils/docker-requirement-detector.d.ts.map +1 -0
  174. package/dist/scripts/utils/docker-requirement-detector.js +124 -0
  175. package/dist/scripts/utils/docker-requirement-detector.js.map +1 -0
  176. package/dist/scripts/utils/env-config.d.ts +54 -0
  177. package/dist/scripts/utils/env-config.d.ts.map +1 -0
  178. package/dist/scripts/utils/env-config.js +414 -0
  179. package/dist/scripts/utils/env-config.js.map +1 -0
  180. package/dist/scripts/utils/jira-issue-type-fetcher.d.ts +70 -0
  181. package/dist/scripts/utils/jira-issue-type-fetcher.d.ts.map +1 -0
  182. package/dist/scripts/utils/jira-issue-type-fetcher.js +147 -0
  183. package/dist/scripts/utils/jira-issue-type-fetcher.js.map +1 -0
  184. package/dist/scripts/utils/language-detector.d.ts +14 -0
  185. package/dist/scripts/utils/language-detector.d.ts.map +1 -0
  186. package/dist/scripts/utils/language-detector.js +119 -0
  187. package/dist/scripts/utils/language-detector.js.map +1 -0
  188. package/dist/scripts/utils/markdown-parser.d.ts +55 -0
  189. package/dist/scripts/utils/markdown-parser.d.ts.map +1 -0
  190. package/dist/scripts/utils/markdown-parser.js +289 -0
  191. package/dist/scripts/utils/markdown-parser.js.map +1 -0
  192. package/dist/scripts/utils/project-detector.d.ts +17 -0
  193. package/dist/scripts/utils/project-detector.d.ts.map +1 -0
  194. package/dist/scripts/utils/project-detector.js +166 -0
  195. package/dist/scripts/utils/project-detector.js.map +1 -0
  196. package/dist/scripts/utils/project-finder.js +2 -2
  197. package/dist/scripts/utils/project-finder.js.map +1 -1
  198. package/dist/scripts/utils/release-notes-generator.d.ts +56 -0
  199. package/dist/scripts/utils/release-notes-generator.d.ts.map +1 -0
  200. package/dist/scripts/utils/release-notes-generator.js +162 -0
  201. package/dist/scripts/utils/release-notes-generator.js.map +1 -0
  202. package/dist/scripts/utils/spec-loader.d.ts +79 -0
  203. package/dist/scripts/utils/spec-loader.d.ts.map +1 -0
  204. package/dist/scripts/utils/spec-loader.js +80 -0
  205. package/dist/scripts/utils/spec-loader.js.map +1 -0
  206. package/dist/scripts/utils/spec-updater.d.ts +7 -0
  207. package/dist/scripts/utils/spec-updater.d.ts.map +1 -1
  208. package/dist/scripts/utils/spec-updater.js.map +1 -1
  209. package/dist/scripts/utils/tasks-converter.d.ts +57 -0
  210. package/dist/scripts/utils/tasks-converter.d.ts.map +1 -0
  211. package/dist/scripts/utils/tasks-converter.js +322 -0
  212. package/dist/scripts/utils/tasks-converter.js.map +1 -0
  213. package/dist/scripts/utils/tasks-format-validator.d.ts +36 -0
  214. package/dist/scripts/utils/tasks-format-validator.d.ts.map +1 -0
  215. package/dist/scripts/utils/tasks-format-validator.js +158 -0
  216. package/dist/scripts/utils/tasks-format-validator.js.map +1 -0
  217. package/dist/scripts/utils/template-applier.d.ts +37 -0
  218. package/dist/scripts/utils/template-applier.d.ts.map +1 -0
  219. package/dist/scripts/utils/template-applier.js +129 -0
  220. package/dist/scripts/utils/template-applier.js.map +1 -0
  221. package/dist/scripts/utils/template-finder.d.ts +37 -0
  222. package/dist/scripts/utils/template-finder.d.ts.map +1 -0
  223. package/dist/scripts/utils/template-finder.js +63 -0
  224. package/dist/scripts/utils/template-finder.js.map +1 -0
  225. package/dist/scripts/utils/test-config-generator.d.ts +12 -0
  226. package/dist/scripts/utils/test-config-generator.d.ts.map +1 -0
  227. package/dist/scripts/utils/test-config-generator.js +185 -0
  228. package/dist/scripts/utils/test-config-generator.js.map +1 -0
  229. package/dist/scripts/utils/test-runner.d.ts +31 -0
  230. package/dist/scripts/utils/test-runner.d.ts.map +1 -0
  231. package/dist/scripts/utils/test-runner.js +103 -0
  232. package/dist/scripts/utils/test-runner.js.map +1 -0
  233. package/dist/scripts/validate-phase.d.ts +1 -1
  234. package/dist/scripts/validate-phase.d.ts.map +1 -1
  235. package/dist/scripts/validate-phase.js +153 -5
  236. package/dist/scripts/validate-phase.js.map +1 -1
  237. package/dist/scripts/workflow-orchestrator.d.ts +8 -0
  238. package/dist/scripts/workflow-orchestrator.d.ts.map +1 -1
  239. package/dist/scripts/workflow-orchestrator.js +108 -7
  240. package/dist/scripts/workflow-orchestrator.js.map +1 -1
  241. package/dist/src/__tests__/integration/internationalization.test.d.ts +8 -0
  242. package/dist/src/__tests__/integration/internationalization.test.d.ts.map +1 -0
  243. package/dist/src/__tests__/integration/internationalization.test.js +333 -0
  244. package/dist/src/__tests__/integration/internationalization.test.js.map +1 -0
  245. package/dist/src/__tests__/integration/setup/claude-agent.test.d.ts +5 -0
  246. package/dist/src/__tests__/integration/setup/claude-agent.test.d.ts.map +1 -0
  247. package/dist/src/__tests__/integration/setup/claude-agent.test.js +122 -0
  248. package/dist/src/__tests__/integration/setup/claude-agent.test.js.map +1 -0
  249. package/dist/src/__tests__/integration/setup/claude.test.d.ts +5 -0
  250. package/dist/src/__tests__/integration/setup/claude.test.d.ts.map +1 -0
  251. package/dist/src/__tests__/integration/setup/claude.test.js +111 -0
  252. package/dist/src/__tests__/integration/setup/claude.test.js.map +1 -0
  253. package/dist/src/__tests__/integration/setup/cursor.test.d.ts +5 -0
  254. package/dist/src/__tests__/integration/setup/cursor.test.d.ts.map +1 -0
  255. package/dist/src/__tests__/integration/setup/cursor.test.js +166 -0
  256. package/dist/src/__tests__/integration/setup/cursor.test.js.map +1 -0
  257. package/dist/src/__tests__/integration/setup/helpers/fs-assertions.d.ts +32 -0
  258. package/dist/src/__tests__/integration/setup/helpers/fs-assertions.d.ts.map +1 -0
  259. package/dist/src/__tests__/integration/setup/helpers/fs-assertions.js +72 -0
  260. package/dist/src/__tests__/integration/setup/helpers/fs-assertions.js.map +1 -0
  261. package/dist/src/__tests__/integration/setup/helpers/test-project.d.ts +38 -0
  262. package/dist/src/__tests__/integration/setup/helpers/test-project.d.ts.map +1 -0
  263. package/dist/src/__tests__/integration/setup/helpers/test-project.js +83 -0
  264. package/dist/src/__tests__/integration/setup/helpers/test-project.js.map +1 -0
  265. package/dist/src/__tests__/integration/setup/validation.test.d.ts +5 -0
  266. package/dist/src/__tests__/integration/setup/validation.test.d.ts.map +1 -0
  267. package/dist/src/__tests__/integration/setup/validation.test.js +301 -0
  268. package/dist/src/__tests__/integration/setup/validation.test.js.map +1 -0
  269. package/dist/src/cli.d.ts.map +1 -1
  270. package/dist/src/cli.js +228 -18
  271. package/dist/src/cli.js.map +1 -1
  272. package/dist/src/commands/setup-existing.d.ts +25 -0
  273. package/dist/src/commands/setup-existing.d.ts.map +1 -0
  274. package/dist/src/commands/setup-existing.js +695 -0
  275. package/dist/src/commands/setup-existing.js.map +1 -0
  276. package/dist/vitest.config.d.ts.map +1 -1
  277. package/dist/vitest.config.js +4 -3
  278. package/dist/vitest.config.js.map +1 -1
  279. package/docs/README.md +3 -1
  280. package/docs/context.md +59 -0
  281. package/docs/design-issue-55.md +240 -0
  282. package/docs/design-issue-56.md +181 -0
  283. package/docs/michi-development/testing/manual-verification-flow.md +2242 -0
  284. package/docs/michi-development/testing/pre-publish-checklist.md +560 -0
  285. package/docs/plan.md +275 -0
  286. package/docs/user-guide/getting-started/github-token-setup.md +509 -0
  287. package/docs/{getting-started → user-guide/getting-started}/new-repository-setup.md +108 -28
  288. package/docs/{getting-started → user-guide/getting-started}/quick-start.md +73 -6
  289. package/docs/{getting-started → user-guide/getting-started}/setup.md +278 -3
  290. package/docs/{guides → user-guide/guides}/customization.md +3 -3
  291. package/docs/user-guide/guides/internationalization.md +540 -0
  292. package/docs/{guides → user-guide/guides}/multi-project.md +2 -2
  293. package/docs/{guides → user-guide/guides}/phase-automation.md +67 -9
  294. package/docs/user-guide/guides/workflow.md +582 -0
  295. package/docs/user-guide/hands-on/README.md +142 -0
  296. package/docs/user-guide/hands-on/claude-agent-setup.md +455 -0
  297. package/docs/user-guide/hands-on/claude-setup.md +398 -0
  298. package/docs/user-guide/hands-on/cursor-setup.md +352 -0
  299. package/docs/user-guide/hands-on/troubleshooting.md +964 -0
  300. package/docs/user-guide/hands-on/verification-checklist.md +438 -0
  301. package/docs/user-guide/hands-on/workflow-walkthrough.md +906 -0
  302. package/docs/user-guide/reference/config.md +564 -0
  303. package/docs/{reference → user-guide/reference}/quick-reference.md +75 -53
  304. package/docs/user-guide/release/ci-setup.md +541 -0
  305. package/docs/user-guide/release/release-flow.md +476 -0
  306. package/docs/user-guide/templates/test-specs/README.md +173 -0
  307. package/docs/user-guide/templates/test-specs/e2e-test-spec-template.md +547 -0
  308. package/docs/user-guide/templates/test-specs/integration-test-spec-template.md +435 -0
  309. package/docs/user-guide/templates/test-specs/performance-test-spec-template.md +454 -0
  310. package/docs/user-guide/templates/test-specs/security-test-spec-template.md +664 -0
  311. package/docs/user-guide/templates/test-specs/unit-test-spec-template.md +328 -0
  312. package/docs/user-guide/testing/integration-tests.md +312 -0
  313. package/docs/user-guide/testing/tdd-cycle.md +349 -0
  314. package/docs/user-guide/testing/test-execution-flow.md +396 -0
  315. package/docs/user-guide/testing/test-failure-handling.md +521 -0
  316. package/docs/user-guide/testing/test-planning-flow.md +181 -0
  317. package/docs/user-guide/testing-strategy.md +185 -0
  318. package/docs/verification-guide.md +518 -0
  319. package/package.json +13 -3
  320. package/scripts/__tests__/create-project.test.ts +67 -49
  321. package/scripts/__tests__/jira-transitions.test.ts +225 -0
  322. package/scripts/__tests__/multi-project-estimate.test.ts +36 -30
  323. package/scripts/__tests__/setup-existing-project.test.ts +171 -6
  324. package/scripts/__tests__/setup-interactive.test.ts +52 -46
  325. package/scripts/__tests__/spec-impl-workflow.test.ts +429 -0
  326. package/scripts/__tests__/spec-loader.test.ts +199 -0
  327. package/scripts/__tests__/validate-phase.test.ts +78 -54
  328. package/scripts/config/config-schema.ts +89 -50
  329. package/scripts/config-interactive.ts +191 -136
  330. package/scripts/confluence-sync.ts +0 -12
  331. package/scripts/constants/__tests__/environments.test.ts +146 -0
  332. package/scripts/constants/__tests__/languages.test.ts +100 -0
  333. package/scripts/constants/environments.ts +81 -0
  334. package/scripts/constants/languages.ts +70 -0
  335. package/scripts/constants/test-commands.ts +96 -0
  336. package/scripts/create-project.ts +52 -22
  337. package/scripts/jira-sync.ts +767 -232
  338. package/scripts/markdown-to-confluence.ts +1 -1
  339. package/scripts/phase-runner.ts +1056 -63
  340. package/scripts/pr-automation.ts +0 -1
  341. package/scripts/pre-flight-check.ts +1 -1
  342. package/scripts/pre-publish-check.sh +311 -0
  343. package/scripts/quick-verify.sh +115 -0
  344. package/scripts/setup-existing-project.ts +306 -143
  345. package/scripts/setup-interactive.ts +4 -4
  346. package/scripts/spec-impl-workflow.ts +505 -0
  347. package/scripts/template/__tests__/renderer.test.ts +206 -0
  348. package/scripts/template/renderer.ts +133 -0
  349. package/scripts/test-execution-generator.ts +695 -0
  350. package/scripts/test-interactive.ts +779 -0
  351. package/scripts/test-new-features.ts +168 -0
  352. package/scripts/test-npm-package.sh +345 -0
  353. package/scripts/test-spec-generator.ts +574 -0
  354. package/scripts/test-workflow-stages.ts +53 -0
  355. package/scripts/utils/__tests__/aidlc-parser.test.ts +349 -0
  356. package/scripts/utils/__tests__/business-days.test.ts +214 -0
  357. package/scripts/utils/__tests__/config-loader.test.ts +1 -1
  358. package/scripts/utils/__tests__/config-validator.test.ts +309 -88
  359. package/scripts/utils/__tests__/env-config.test.ts +259 -0
  360. package/scripts/utils/__tests__/jira-issue-type-fetcher.test.ts +272 -0
  361. package/scripts/utils/__tests__/tasks-converter.test.ts +582 -0
  362. package/scripts/utils/__tests__/tasks-format-validator.test.ts +338 -0
  363. package/scripts/utils/__tests__/test-runner.test.ts +77 -0
  364. package/scripts/utils/aidlc-parser.ts +289 -0
  365. package/scripts/utils/business-days.ts +115 -0
  366. package/scripts/utils/ci-generator.ts +84 -0
  367. package/scripts/utils/config-loader.ts +2 -2
  368. package/scripts/utils/config-validator.ts +304 -117
  369. package/scripts/utils/confluence-approval.ts +167 -0
  370. package/scripts/utils/confluence-hierarchy.ts +2 -4
  371. package/scripts/utils/docker-generator.ts +151 -0
  372. package/scripts/utils/docker-requirement-detector.ts +153 -0
  373. package/scripts/utils/env-config.ts +526 -0
  374. package/scripts/utils/jira-issue-type-fetcher.ts +199 -0
  375. package/scripts/utils/language-detector.ts +139 -0
  376. package/scripts/utils/markdown-parser.ts +376 -0
  377. package/scripts/utils/project-detector.ts +192 -0
  378. package/scripts/utils/project-finder.ts +2 -2
  379. package/scripts/utils/release-notes-generator.ts +210 -0
  380. package/scripts/utils/spec-loader.ts +125 -0
  381. package/scripts/utils/spec-updater.ts +8 -1
  382. package/scripts/utils/tasks-converter.ts +601 -0
  383. package/scripts/utils/tasks-format-validator.ts +193 -0
  384. package/scripts/utils/template-applier.ts +202 -0
  385. package/scripts/utils/template-finder.ts +75 -0
  386. package/scripts/utils/test-config-generator.ts +210 -0
  387. package/scripts/utils/test-runner.ts +133 -0
  388. package/scripts/validate-phase.ts +186 -9
  389. package/scripts/workflow-orchestrator.ts +130 -12
  390. package/templates/ci/github-actions/java.yml +54 -0
  391. package/templates/ci/github-actions/nodejs.yml +46 -0
  392. package/templates/ci/github-actions/php.yml +52 -0
  393. package/templates/ci/screwdriver/java.yaml +17 -0
  394. package/templates/ci/screwdriver/nodejs.yaml +17 -0
  395. package/templates/ci/screwdriver/php.yaml +20 -0
  396. package/templates/claude/commands/kiro/kiro-spec-impl.md +244 -0
  397. package/templates/claude/commands/kiro/kiro-spec-tasks.md +354 -0
  398. package/templates/claude/commands/michi/confluence-sync.md +38 -0
  399. package/templates/claude/commands/michi/project-switch.md +36 -0
  400. package/templates/claude/rules/atlassian-integration.md +35 -0
  401. package/templates/claude/rules/michi-core.md +54 -0
  402. package/templates/claude-agent/README.md +31 -0
  403. package/templates/claude-agent/agents/.gitkeep +0 -0
  404. package/templates/claude-agent/agents/designer.md +79 -0
  405. package/templates/claude-agent/agents/developer.md +68 -0
  406. package/templates/claude-agent/agents/manager-agent.md +59 -0
  407. package/templates/claude-agent/agents/tester.md +101 -0
  408. package/templates/claude-agent/commands/kiro/.gitkeep +0 -0
  409. package/templates/claude-agent/commands/kiro/kiro-spec-impl.md +244 -0
  410. package/templates/claude-agent/commands/kiro/kiro-spec-tasks.md +354 -0
  411. package/templates/cline/rules/atlassian-integration.md +36 -0
  412. package/templates/cline/rules/michi-core.md +56 -0
  413. package/templates/codex/AGENTS.override.md +277 -0
  414. package/templates/codex/prompts/confluence-sync.md +177 -0
  415. package/templates/codex/rules/README.md +210 -0
  416. package/templates/common/.kiro/project.json.template +21 -0
  417. package/templates/cursor/commands/kiro/kiro-spec-impl.md +244 -0
  418. package/templates/cursor/commands/kiro/kiro-spec-tasks.md +354 -0
  419. package/templates/cursor/commands/michi/confluence-sync.md +76 -0
  420. package/templates/cursor/commands/michi/project-switch.md +69 -0
  421. package/templates/cursor/rules/atlassian-mcp.mdc +188 -0
  422. package/templates/cursor/rules/github-ssot.mdc +151 -0
  423. package/templates/cursor/rules/multi-project.mdc +81 -0
  424. package/templates/gemini/commands/README.md +41 -0
  425. package/templates/gemini/rules/GEMINI.md +80 -0
  426. package/docs/guides/workflow.md +0 -342
  427. package/docs/reference/config.md +0 -545
  428. package/scripts/setup-env.sh +0 -52
  429. package/scripts/setup-existing.sh +0 -152
  430. /package/docs/{contributing → michi-development/contributing}/development.md +0 -0
  431. /package/docs/{contributing → michi-development/contributing}/release.md +0 -0
  432. /package/docs/{testing-strategy.md → michi-development/testing-strategy.md} +0 -0
  433. /package/docs/{reference → user-guide/reference}/tasks-template.md +0 -0
@@ -0,0 +1,167 @@
1
+ /**
2
+ * Confluence承認状態ポーリングユーティリティ
3
+ * Confluence APIを使用してページの承認状態を確認
4
+ */
5
+
6
+ import axios from 'axios';
7
+
8
+ /**
9
+ * Confluence設定
10
+ */
11
+ export interface ConfluenceConfig {
12
+ url: string;
13
+ email: string;
14
+ apiToken: string;
15
+ }
16
+
17
+ /**
18
+ * 承認状態
19
+ */
20
+ export interface ApprovalStatus {
21
+ approved: boolean;
22
+ approvers: string[];
23
+ pendingApprovers: string[];
24
+ pageId: string;
25
+ pageTitle: string;
26
+ }
27
+
28
+ /**
29
+ * Confluenceページの承認状態を取得
30
+ * @param pageId ページID
31
+ * @param config Confluence設定
32
+ * @returns 承認状態
33
+ */
34
+ export async function getApprovalStatus(
35
+ pageId: string,
36
+ config: ConfluenceConfig
37
+ ): Promise<ApprovalStatus> {
38
+ const baseUrl = `${config.url}/wiki/rest/api`;
39
+ const auth = Buffer.from(`${config.email}:${config.apiToken}`).toString('base64');
40
+
41
+ try {
42
+ // ページ情報を取得
43
+ const pageResponse = await axios.get(`${baseUrl}/content/${pageId}`, {
44
+ params: {
45
+ expand: 'metadata.labels'
46
+ },
47
+ headers: {
48
+ 'Authorization': `Basic ${auth}`,
49
+ 'Content-Type': 'application/json'
50
+ }
51
+ });
52
+
53
+ const pageTitle = pageResponse.data.title;
54
+ const labels = pageResponse.data.metadata?.labels?.results || [];
55
+
56
+ // 承認ラベルをチェック
57
+ // Confluenceでは通常、承認はカスタムラベルやメタデータで管理される
58
+ // ここでは "approved" ラベルの存在で判定
59
+ const hasApprovedLabel = labels.some((label: any) =>
60
+ label.name === 'approved' || label.name === '承認済み'
61
+ );
62
+
63
+ // ページのコメントから承認者を取得
64
+ const commentsResponse = await axios.get(`${baseUrl}/content/${pageId}/child/comment`, {
65
+ params: {
66
+ expand: 'body.view'
67
+ },
68
+ headers: {
69
+ 'Authorization': `Basic ${auth}`,
70
+ 'Content-Type': 'application/json'
71
+ }
72
+ });
73
+
74
+ const comments = commentsResponse.data.results || [];
75
+ const approvers: string[] = [];
76
+
77
+ // "承認" または "Approved" を含むコメントから承認者を抽出
78
+ for (const comment of comments) {
79
+ const body = comment.body?.view?.value || '';
80
+ const author = comment.version?.by?.displayName || 'Unknown';
81
+
82
+ if (
83
+ body.includes('承認') ||
84
+ body.toLowerCase().includes('approved') ||
85
+ body.toLowerCase().includes('lgtm')
86
+ ) {
87
+ if (!approvers.includes(author)) {
88
+ approvers.push(author);
89
+ }
90
+ }
91
+ }
92
+
93
+ return {
94
+ approved: hasApprovedLabel && approvers.length > 0,
95
+ approvers,
96
+ pendingApprovers: [],
97
+ pageId,
98
+ pageTitle
99
+ };
100
+ } catch (error: any) {
101
+ console.error('Failed to get approval status:', error.message);
102
+ throw error;
103
+ }
104
+ }
105
+
106
+ /**
107
+ * 承認状態をポーリング
108
+ * @param pageId ページID
109
+ * @param config Confluence設定
110
+ * @param interval チェック間隔 (ミリ秒)
111
+ * @param timeout タイムアウト (ミリ秒)
112
+ * @returns 承認状態
113
+ */
114
+ export async function pollForApproval(
115
+ pageId: string,
116
+ config: ConfluenceConfig,
117
+ interval: number = 30000, // 30秒
118
+ timeout: number = 1800000 // 30分
119
+ ): Promise<ApprovalStatus> {
120
+ const startTime = Date.now();
121
+
122
+ while (true) {
123
+ try {
124
+ const status = await getApprovalStatus(pageId, config);
125
+
126
+ if (status.approved) {
127
+ return status;
128
+ }
129
+
130
+ // タイムアウトチェック
131
+ if (Date.now() - startTime > timeout) {
132
+ throw new Error('Approval timeout: No approval received within the specified time');
133
+ }
134
+
135
+ // 次のチェックまで待機
136
+ await new Promise(resolve => setTimeout(resolve, interval));
137
+ } catch (error: any) {
138
+ // エラーがタイムアウト以外の場合はリトライ
139
+ if (error.message.includes('timeout')) {
140
+ throw error;
141
+ }
142
+
143
+ console.warn('Error checking approval status, will retry:', error.message);
144
+ await new Promise(resolve => setTimeout(resolve, interval));
145
+ }
146
+ }
147
+ }
148
+
149
+ /**
150
+ * 手動承認を待つ (コンソール出力のみ)
151
+ * @param pageUrl ページURL
152
+ * @param requiredApprovers 必要な承認者リスト
153
+ */
154
+ export function waitForManualApproval(
155
+ pageUrl: string,
156
+ requiredApprovers: string[] = []
157
+ ): void {
158
+ console.log('\n⏸️ 承認待ち\n');
159
+ console.log(`📄 ページURL: ${pageUrl}`);
160
+
161
+ if (requiredApprovers.length > 0) {
162
+ console.log(`👥 承認者: ${requiredApprovers.join(', ')}`);
163
+ }
164
+
165
+ console.log('\n承認が完了したら、このプロセスを再開してください。');
166
+ console.log('(自動ポーリングを有効にするには、環境変数 CONFLUENCE_AUTO_POLL=true を設定してください)');
167
+ }
@@ -3,12 +3,10 @@
3
3
  * 各パターン(single, by-section, by-hierarchy, manual)に対応
4
4
  */
5
5
 
6
- import { readFileSync } from 'fs';
7
- import { resolve } from 'path';
8
6
  import type { ConfluenceClient } from '../confluence-sync.js';
9
7
  import { convertMarkdownToConfluence, createConfluencePage } from '../markdown-to-confluence.js';
10
8
  import type { ProjectMetadata } from './project-meta.js';
11
- import type { ConfluenceConfig, ConfluencePageCreationGranularity } from '../config/config-schema.js';
9
+ import type { ConfluenceConfig } from '../config/config-schema.js';
12
10
 
13
11
  /**
14
12
  * ページ作成結果
@@ -200,7 +198,7 @@ async function getOrCreateParentPage(
200
198
  parentTitle: string,
201
199
  projectMeta: ProjectMetadata,
202
200
  featureName: string,
203
- githubUrl: string
201
+ _githubUrl: string
204
202
  ): Promise<string> {
205
203
  // 既存の親ページを検索
206
204
  const existingParent = await client.searchPage(spaceKey, parentTitle);
@@ -0,0 +1,151 @@
1
+ /**
2
+ * Docker Compose設定生成ユーティリティ
3
+ * 選択されたサービスに応じてdocker-compose.ymlを生成
4
+ */
5
+
6
+ import { writeFileSync, existsSync } from 'fs';
7
+ import { join } from 'path';
8
+ import inquirer from 'inquirer';
9
+
10
+ /**
11
+ * Docker Compose設定を生成
12
+ */
13
+ export async function generateDockerCompose(
14
+ feature: string,
15
+ suggestedServices: string[] = [],
16
+ projectRoot: string = process.cwd()
17
+ ): Promise<void> {
18
+ // サービスを選択(推奨サービスはデフォルトで選択)
19
+ const answers = await inquirer.prompt([
20
+ {
21
+ type: 'checkbox',
22
+ name: 'services',
23
+ message: '必要なサービスを選択してください:',
24
+ choices: [
25
+ { name: 'PostgreSQL', value: 'postgres', checked: suggestedServices.includes('postgres') },
26
+ { name: 'MySQL', value: 'mysql', checked: suggestedServices.includes('mysql') },
27
+ { name: 'Redis', value: 'redis', checked: suggestedServices.includes('redis') },
28
+ { name: 'MongoDB', value: 'mongodb', checked: suggestedServices.includes('mongodb') },
29
+ { name: 'Mock API Server', value: 'mockapi', checked: suggestedServices.includes('mockapi') }
30
+ ]
31
+ }
32
+ ]);
33
+
34
+ if (answers.services.length === 0) {
35
+ console.log(' ⏭️ Docker Compose: スキップ(サービス未選択)');
36
+ return;
37
+ }
38
+
39
+ // docker-compose.ymlを生成
40
+ const compose = generateDockerComposeYaml(answers.services);
41
+ const outputPath = join(projectRoot, 'docker-compose.yml');
42
+
43
+ // 既存ファイルがある場合は確認
44
+ if (existsSync(outputPath)) {
45
+ console.log(' ⚠️ docker-compose.yml: 既存(上書きスキップ)');
46
+ return;
47
+ }
48
+
49
+ writeFileSync(outputPath, compose, 'utf-8');
50
+ console.log(` ✅ Docker Compose: docker-compose.yml (${answers.services.join(', ')})`);
51
+ }
52
+
53
+ /**
54
+ * Docker Compose YAMLを生成
55
+ */
56
+ function generateDockerComposeYaml(services: string[]): string {
57
+ let yaml = `version: '3.8'
58
+
59
+ services:
60
+ `;
61
+
62
+ if (services.includes('postgres')) {
63
+ yaml += ` postgres:
64
+ image: postgres:15-alpine
65
+ environment:
66
+ POSTGRES_USER: testuser
67
+ POSTGRES_PASSWORD: testpass
68
+ POSTGRES_DB: testdb
69
+ ports:
70
+ - "5432:5432"
71
+ volumes:
72
+ - postgres_data:/var/lib/postgresql/data
73
+
74
+ `;
75
+ }
76
+
77
+ if (services.includes('mysql')) {
78
+ yaml += ` mysql:
79
+ image: mysql:8.0
80
+ environment:
81
+ MYSQL_ROOT_PASSWORD: rootpass
82
+ MYSQL_DATABASE: testdb
83
+ MYSQL_USER: testuser
84
+ MYSQL_PASSWORD: testpass
85
+ ports:
86
+ - "3306:3306"
87
+ volumes:
88
+ - mysql_data:/var/lib/mysql
89
+
90
+ `;
91
+ }
92
+
93
+ if (services.includes('redis')) {
94
+ yaml += ` redis:
95
+ image: redis:7-alpine
96
+ ports:
97
+ - "6379:6379"
98
+ volumes:
99
+ - redis_data:/data
100
+
101
+ `;
102
+ }
103
+
104
+ if (services.includes('mongodb')) {
105
+ yaml += ` mongodb:
106
+ image: mongo:7
107
+ environment:
108
+ MONGO_INITDB_ROOT_USERNAME: root
109
+ MONGO_INITDB_ROOT_PASSWORD: rootpass
110
+ MONGO_INITDB_DATABASE: testdb
111
+ ports:
112
+ - "27017:27017"
113
+ volumes:
114
+ - mongodb_data:/data/db
115
+
116
+ `;
117
+ }
118
+
119
+ if (services.includes('mockapi')) {
120
+ yaml += ` mockapi:
121
+ image: mockserver/mockserver:latest
122
+ ports:
123
+ - "1080:1080"
124
+ environment:
125
+ MOCKSERVER_INITIALIZATION_JSON_PATH: /config/initializerJson.json
126
+ volumes:
127
+ - ./mock-config:/config
128
+
129
+ `;
130
+ }
131
+
132
+ // ボリューム定義
133
+ yaml += `volumes:
134
+ `;
135
+
136
+ if (services.includes('postgres')) {
137
+ yaml += ' postgres_data:\n';
138
+ }
139
+ if (services.includes('mysql')) {
140
+ yaml += ' mysql_data:\n';
141
+ }
142
+ if (services.includes('redis')) {
143
+ yaml += ' redis_data:\n';
144
+ }
145
+ if (services.includes('mongodb')) {
146
+ yaml += ' mongodb_data:\n';
147
+ }
148
+
149
+ return yaml;
150
+ }
151
+
@@ -0,0 +1,153 @@
1
+ /**
2
+ * Docker Compose要件検出ユーティリティ
3
+ * design.md、requirements.md、test-type-selectionからDocker Composeの必要性を自動判断
4
+ */
5
+
6
+ import { readFileSync, existsSync } from 'fs';
7
+ import { join } from 'path';
8
+ import { extractSection } from './markdown-parser.js';
9
+
10
+ export interface DockerRecommendation {
11
+ recommended: boolean;
12
+ confidence: 'high' | 'medium' | 'low';
13
+ reasons: string[];
14
+ suggestedServices: string[];
15
+ }
16
+
17
+ /**
18
+ * Docker Composeの必要性を分析
19
+ */
20
+ export function analyzeDockerRequirement(feature: string, projectRoot: string = process.cwd()): DockerRecommendation {
21
+ const reasons: string[] = [];
22
+ const services: string[] = [];
23
+ let score = 0;
24
+
25
+ // design.mdを解析
26
+ const designPath = join(projectRoot, '.kiro', 'specs', feature, 'design.md');
27
+ if (existsSync(designPath)) {
28
+ const design = readFileSync(designPath, 'utf-8');
29
+
30
+ // Technology Stackセクションを確認
31
+ const techStack = extractSection(design, 'Technology Stack');
32
+ const dataModels = extractSection(design, 'Data Models');
33
+
34
+ // データベースの検出
35
+ if (techStack.match(/PostgreSQL|Postgres/i) || dataModels.match(/PostgreSQL|Postgres/i)) {
36
+ score += 3;
37
+ services.push('postgres');
38
+ reasons.push('PostgreSQLがTechnology Stackに含まれている');
39
+ }
40
+
41
+ if (techStack.match(/MySQL/i) || dataModels.match(/MySQL/i)) {
42
+ score += 3;
43
+ services.push('mysql');
44
+ reasons.push('MySQLがTechnology Stackに含まれている');
45
+ }
46
+
47
+ if (techStack.match(/MongoDB|Mongo/i) || dataModels.match(/MongoDB|Mongo/i)) {
48
+ score += 3;
49
+ services.push('mongodb');
50
+ reasons.push('MongoDBがTechnology Stackに含まれている');
51
+ }
52
+
53
+ // ミドルウェアの検出
54
+ if (techStack.match(/Redis/i)) {
55
+ score += 2;
56
+ services.push('redis');
57
+ reasons.push('RedisがTechnology Stackに含まれている');
58
+ }
59
+
60
+ if (techStack.match(/Elasticsearch/i)) {
61
+ score += 2;
62
+ reasons.push('ElasticsearchがTechnology Stackに含まれている');
63
+ }
64
+
65
+ if (techStack.match(/RabbitMQ|Kafka/i)) {
66
+ score += 2;
67
+ reasons.push('メッセージキュー(RabbitMQ/Kafka)がTechnology Stackに含まれている');
68
+ }
69
+
70
+ // Data Modelsセクションの分析
71
+ if (dataModels.match(/Relational Database|RDBMS/i)) {
72
+ score += 2;
73
+ reasons.push('リレーショナルデータベースがData Modelsに定義されている');
74
+ }
75
+
76
+ if (dataModels.match(/Document Store|NoSQL/i)) {
77
+ score += 2;
78
+ reasons.push('NoSQLデータベースがData Modelsに定義されている');
79
+ }
80
+
81
+ // File Storageのみの場合は減点
82
+ if (techStack.match(/File System|File Storage/i) &&
83
+ !techStack.match(/PostgreSQL|MySQL|MongoDB|Redis/i)) {
84
+ score -= 1;
85
+ reasons.push('File Storageのみ(データベース不要の可能性)');
86
+ }
87
+ }
88
+
89
+ // test-type-selection.jsonを解析
90
+ const testSelectionPath = join(projectRoot, '.kiro', 'specs', feature, 'test-type-selection.json');
91
+ if (existsSync(testSelectionPath)) {
92
+ try {
93
+ const testSelection = JSON.parse(readFileSync(testSelectionPath, 'utf-8'));
94
+ const testTypes = testSelection.selectedTypes || [];
95
+
96
+ // 統合テストが選択されている
97
+ if (testTypes.includes('integration')) {
98
+ score += 2;
99
+ reasons.push('統合テストが選択されている(データベースやミドルウェアのテストに有用)');
100
+ }
101
+
102
+ // E2Eテストが選択されている
103
+ if (testTypes.includes('e2e')) {
104
+ score += 2;
105
+ reasons.push('E2Eテストが選択されている(実環境に近い状態でのテストに有用)');
106
+ }
107
+
108
+ // パフォーマンステストが選択されている
109
+ if (testTypes.includes('performance')) {
110
+ score += 1;
111
+ reasons.push('パフォーマンステストが選択されている(負荷テストにデータベースが有用)');
112
+ }
113
+ } catch {
114
+ // test-type-selection.jsonの読み込みエラーは無視
115
+ }
116
+ }
117
+
118
+ // requirements.mdを解析
119
+ const requirementsPath = join(projectRoot, '.kiro', 'specs', feature, 'requirements.md');
120
+ if (existsSync(requirementsPath)) {
121
+ const requirements = readFileSync(requirementsPath, 'utf-8');
122
+
123
+ // データ永続化の要件
124
+ if (requirements.match(/データベース|database|永続化|persist/i)) {
125
+ score += 1;
126
+ reasons.push('データ永続化の要件が含まれている');
127
+ }
128
+
129
+ // 外部サービス連携の要件
130
+ if (requirements.match(/外部.*API|external.*API|mock.*server/i)) {
131
+ score += 1;
132
+ if (!services.includes('mockapi')) {
133
+ services.push('mockapi');
134
+ }
135
+ reasons.push('外部API連携の要件が含まれている(Mock API Serverが有用)');
136
+ }
137
+ }
138
+
139
+ // 判定
140
+ const recommended = score >= 3;
141
+ const confidence: 'high' | 'medium' | 'low' =
142
+ score >= 5 ? 'high' :
143
+ score >= 3 ? 'medium' :
144
+ 'low';
145
+
146
+ return {
147
+ recommended,
148
+ confidence,
149
+ reasons,
150
+ suggestedServices: [...new Set(services)] // 重複削除
151
+ };
152
+ }
153
+