@k2works/claude-code-booster 3.6.0 → 3.7.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 (713) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +42 -42
  3. package/bin/claude-code-booster +90 -90
  4. package/lib/assets/.claude/README.md +258 -239
  5. package/lib/assets/.claude/agent-memory/xp-programmer/MEMORY.md +6 -0
  6. package/lib/assets/.claude/agent-memory/xp-programmer/project_cargo_tracker.md +11 -0
  7. package/lib/assets/.claude/agent-memory/xp-programmer/project_ddd_patterns.md +27 -0
  8. package/lib/assets/.claude/agent-memory/xp-programmer/project_us07_route_assignment.md +19 -0
  9. package/lib/assets/.claude/scripts/generate-inception-deck.mjs +911 -911
  10. package/lib/assets/.claude/settings.json +11 -11
  11. package/lib/assets/.claude/skills/ai-agent-guidelines/SKILL.md +111 -111
  12. package/lib/assets/.claude/skills/analyzing-architecture/SKILL.md +83 -83
  13. package/lib/assets/.claude/skills/analyzing-business/SKILL.md +95 -95
  14. package/lib/assets/.claude/skills/analyzing-data-model/SKILL.md +77 -77
  15. package/lib/assets/.claude/skills/analyzing-domain-model/SKILL.md +117 -117
  16. package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +84 -84
  17. package/lib/assets/.claude/skills/analyzing-non-functional/SKILL.md +95 -95
  18. package/lib/assets/.claude/skills/analyzing-operation/SKILL.md +95 -95
  19. package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +91 -91
  20. package/lib/assets/.claude/skills/analyzing-tech-stack/SKILL.md +101 -101
  21. package/lib/assets/.claude/skills/analyzing-test-strategy/SKILL.md +89 -89
  22. package/lib/assets/.claude/skills/analyzing-ui-design/SKILL.md +80 -80
  23. package/lib/assets/.claude/skills/analyzing-usecases/SKILL.md +72 -72
  24. package/lib/assets/.claude/skills/creating-adr/SKILL.md +113 -113
  25. package/lib/assets/.claude/skills/developing-backend/SKILL.md +100 -100
  26. package/lib/assets/.claude/skills/developing-frontend/SKILL.md +93 -93
  27. package/lib/assets/.claude/skills/developing-release/SKILL.md +120 -120
  28. package/lib/assets/.claude/skills/generating-bmc/SKILL.md +97 -0
  29. package/lib/assets/.claude/skills/generating-slides/SKILL.md +94 -94
  30. package/lib/assets/.claude/skills/git-commit/SKILL.md +81 -81
  31. package/lib/assets/.claude/skills/killing-processes/SKILL.md +44 -44
  32. package/lib/assets/.claude/skills/operating-backup/SKILL.md +59 -59
  33. package/lib/assets/.claude/skills/operating-cicd/SKILL.md +54 -54
  34. package/lib/assets/.claude/skills/operating-deploy/SKILL.md +67 -67
  35. package/lib/assets/.claude/skills/operating-docs/SKILL.md +219 -219
  36. package/lib/assets/.claude/skills/operating-provision/SKILL.md +77 -77
  37. package/lib/assets/.claude/skills/operating-setup/SKILL.md +63 -63
  38. package/lib/assets/.claude/skills/orchestrating-analysis/SKILL.md +104 -104
  39. package/lib/assets/.claude/skills/orchestrating-development/SKILL.md +162 -162
  40. package/lib/assets/.claude/skills/orchestrating-operation/SKILL.md +158 -158
  41. package/lib/assets/.claude/skills/orchestrating-project/SKILL.md +144 -144
  42. package/lib/assets/.claude/skills/planning-releases/SKILL.md +119 -119
  43. package/lib/assets/.claude/skills/syncing-github-project/SKILL.md +151 -151
  44. package/lib/assets/.claude/skills/tracking-progress/SKILL.md +91 -91
  45. package/lib/assets/.claude/skills/validating-iteration-plan/SKILL.md +215 -215
  46. package/lib/assets/.devcontainer/devcontainer.json +34 -34
  47. package/lib/assets/.env.example +17 -17
  48. package/lib/assets/.gitattributes +4 -4
  49. package/lib/assets/.github/workflows/docker-publish.yml +77 -77
  50. package/lib/assets/.github/workflows/mkdocs.yml +39 -39
  51. package/lib/assets/AGENTS.md +94 -94
  52. package/lib/assets/CLAUDE.md +1 -0
  53. package/lib/assets/README.md +254 -254
  54. package/lib/assets/docker-compose.yml +33 -33
  55. package/lib/assets/docs/adr/index.md +10 -10
  56. package/lib/assets/docs/article/functional-desgin-ppp/all/01-immutability-and-data-transformation.md +475 -475
  57. package/lib/assets/docs/article/functional-desgin-ppp/all/02-function-composition.md +519 -519
  58. package/lib/assets/docs/article/functional-desgin-ppp/all/03-polymorphism.md +537 -537
  59. package/lib/assets/docs/article/functional-desgin-ppp/all/04-data-validation.md +300 -300
  60. package/lib/assets/docs/article/functional-desgin-ppp/all/05-property-based-testing.md +320 -320
  61. package/lib/assets/docs/article/functional-desgin-ppp/all/06-tdd-and-functional.md +498 -498
  62. package/lib/assets/docs/article/functional-desgin-ppp/all/07-composite-pattern.md +298 -298
  63. package/lib/assets/docs/article/functional-desgin-ppp/all/08-decorator-pattern.md +291 -291
  64. package/lib/assets/docs/article/functional-desgin-ppp/all/09-adapter-pattern.md +336 -336
  65. package/lib/assets/docs/article/functional-desgin-ppp/all/10-strategy-pattern.md +303 -303
  66. package/lib/assets/docs/article/functional-desgin-ppp/all/11-command-pattern.md +286 -286
  67. package/lib/assets/docs/article/functional-desgin-ppp/all/12-visitor-pattern.md +322 -322
  68. package/lib/assets/docs/article/functional-desgin-ppp/all/13-abstract-factory-pattern.md +319 -319
  69. package/lib/assets/docs/article/functional-desgin-ppp/all/14-abstract-server-pattern.md +365 -365
  70. package/lib/assets/docs/article/functional-desgin-ppp/all/15-gossiping-bus-drivers.md +156 -156
  71. package/lib/assets/docs/article/functional-desgin-ppp/all/16-payroll-system.md +178 -178
  72. package/lib/assets/docs/article/functional-desgin-ppp/all/17-video-rental-system.md +312 -312
  73. package/lib/assets/docs/article/functional-desgin-ppp/all/18-concurrency-system.md +287 -287
  74. package/lib/assets/docs/article/functional-desgin-ppp/all/19-wa-tor-simulation.md +286 -286
  75. package/lib/assets/docs/article/functional-desgin-ppp/all/20-pattern-interactions.md +274 -274
  76. package/lib/assets/docs/article/functional-desgin-ppp/all/21-best-practices.md +294 -294
  77. package/lib/assets/docs/article/functional-desgin-ppp/all/22-oo-to-fp-migration.md +337 -337
  78. package/lib/assets/docs/article/functional-desgin-ppp/all/index.md +388 -388
  79. package/lib/assets/docs/article/functional-desgin-ppp/clojure/01-immutability-and-data-transformation.md +273 -273
  80. package/lib/assets/docs/article/functional-desgin-ppp/clojure/02-function-composition.md +380 -380
  81. package/lib/assets/docs/article/functional-desgin-ppp/clojure/03-polymorphism.md +384 -384
  82. package/lib/assets/docs/article/functional-desgin-ppp/clojure/04-clojure-spec.md +350 -350
  83. package/lib/assets/docs/article/functional-desgin-ppp/clojure/05-property-based-testing.md +352 -352
  84. package/lib/assets/docs/article/functional-desgin-ppp/clojure/06-tdd-in-functional.md +383 -383
  85. package/lib/assets/docs/article/functional-desgin-ppp/clojure/07-composite-pattern.md +529 -529
  86. package/lib/assets/docs/article/functional-desgin-ppp/clojure/08-decorator-pattern.md +395 -395
  87. package/lib/assets/docs/article/functional-desgin-ppp/clojure/09-adapter-pattern.md +399 -399
  88. package/lib/assets/docs/article/functional-desgin-ppp/clojure/10-strategy-pattern.md +485 -485
  89. package/lib/assets/docs/article/functional-desgin-ppp/clojure/11-command-pattern.md +566 -566
  90. package/lib/assets/docs/article/functional-desgin-ppp/clojure/12-visitor-pattern.md +567 -567
  91. package/lib/assets/docs/article/functional-desgin-ppp/clojure/13-abstract-factory-pattern.md +475 -475
  92. package/lib/assets/docs/article/functional-desgin-ppp/clojure/14-abstract-server-pattern.md +462 -462
  93. package/lib/assets/docs/article/functional-desgin-ppp/clojure/15-gossiping-bus-drivers.md +325 -325
  94. package/lib/assets/docs/article/functional-desgin-ppp/clojure/16-payroll-system.md +401 -401
  95. package/lib/assets/docs/article/functional-desgin-ppp/clojure/17-video-rental-system.md +450 -450
  96. package/lib/assets/docs/article/functional-desgin-ppp/clojure/18-concurrency-system.md +475 -475
  97. package/lib/assets/docs/article/functional-desgin-ppp/clojure/19-wator-simulation.md +739 -739
  98. package/lib/assets/docs/article/functional-desgin-ppp/clojure/20-pattern-interactions.md +567 -567
  99. package/lib/assets/docs/article/functional-desgin-ppp/clojure/21-best-practices.md +518 -518
  100. package/lib/assets/docs/article/functional-desgin-ppp/clojure/22-oo-to-fp-migration.md +532 -532
  101. package/lib/assets/docs/article/functional-desgin-ppp/clojure/index.md +241 -241
  102. package/lib/assets/docs/article/functional-desgin-ppp/elixir/01-immutability-and-data-transformation.md +383 -383
  103. package/lib/assets/docs/article/functional-desgin-ppp/elixir/02-function-composition.md +374 -374
  104. package/lib/assets/docs/article/functional-desgin-ppp/elixir/03-polymorphism.md +375 -375
  105. package/lib/assets/docs/article/functional-desgin-ppp/elixir/04-data-validation.md +195 -195
  106. package/lib/assets/docs/article/functional-desgin-ppp/elixir/05-property-based-testing.md +268 -268
  107. package/lib/assets/docs/article/functional-desgin-ppp/elixir/06-tdd-and-fp.md +294 -294
  108. package/lib/assets/docs/article/functional-desgin-ppp/elixir/07-effects-and-pure-functions.md +164 -164
  109. package/lib/assets/docs/article/functional-desgin-ppp/elixir/08-error-handling-strategies.md +168 -168
  110. package/lib/assets/docs/article/functional-desgin-ppp/elixir/09-io-and-external-systems.md +254 -254
  111. package/lib/assets/docs/article/functional-desgin-ppp/elixir/10-concurrency-patterns.md +269 -269
  112. package/lib/assets/docs/article/functional-desgin-ppp/elixir/11-command-pattern.md +148 -148
  113. package/lib/assets/docs/article/functional-desgin-ppp/elixir/12-visitor-pattern.md +176 -176
  114. package/lib/assets/docs/article/functional-desgin-ppp/elixir/13-abstract-factory-pattern.md +604 -604
  115. package/lib/assets/docs/article/functional-desgin-ppp/elixir/14-abstract-server-pattern.md +729 -729
  116. package/lib/assets/docs/article/functional-desgin-ppp/elixir/15-gossiping-bus-drivers.md +291 -291
  117. package/lib/assets/docs/article/functional-desgin-ppp/elixir/16-payroll-system.md +420 -420
  118. package/lib/assets/docs/article/functional-desgin-ppp/elixir/17-video-rental-system.md +319 -319
  119. package/lib/assets/docs/article/functional-desgin-ppp/elixir/18-concurrency-system.md +466 -466
  120. package/lib/assets/docs/article/functional-desgin-ppp/elixir/19-wator-simulation.md +523 -523
  121. package/lib/assets/docs/article/functional-desgin-ppp/elixir/20-pattern-interactions.md +287 -287
  122. package/lib/assets/docs/article/functional-desgin-ppp/elixir/21-best-practices.md +340 -340
  123. package/lib/assets/docs/article/functional-desgin-ppp/elixir/22-oo-to-fp-migration.md +395 -395
  124. package/lib/assets/docs/article/functional-desgin-ppp/elixir/index.md +248 -248
  125. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/01-immutability-and-data-transformation.md +384 -384
  126. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/02-function-composition.md +452 -452
  127. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/03-polymorphism.md +495 -495
  128. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/04-data-validation.md +416 -416
  129. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/05-property-based-testing.md +382 -382
  130. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/06-tdd-functional.md +687 -687
  131. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/07-composite-pattern.md +442 -442
  132. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/08-decorator-pattern.md +479 -479
  133. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/09-adapter-pattern.md +479 -479
  134. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/10-strategy-pattern.md +427 -427
  135. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/11-command-pattern.md +428 -428
  136. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/12-visitor-pattern.md +339 -339
  137. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/13-abstract-factory-pattern.md +309 -309
  138. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/14-abstract-server-pattern.md +596 -596
  139. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/15-gossiping-bus-drivers.md +355 -355
  140. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/16-payroll-system.md +350 -350
  141. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/17-video-rental-system.md +414 -414
  142. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/18-concurrency-system.md +367 -367
  143. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/19-wator-simulation.md +403 -403
  144. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/20-pattern-interactions.md +291 -291
  145. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/21-best-practices.md +324 -324
  146. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/22-oo-to-fp-migration.md +332 -332
  147. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/index.md +274 -274
  148. package/lib/assets/docs/article/functional-desgin-ppp/haskell/01-immutability-and-data-transformation.md +298 -298
  149. package/lib/assets/docs/article/functional-desgin-ppp/haskell/02-function-composition.md +304 -304
  150. package/lib/assets/docs/article/functional-desgin-ppp/haskell/03-polymorphism.md +362 -362
  151. package/lib/assets/docs/article/functional-desgin-ppp/haskell/04-data-validation.md +257 -257
  152. package/lib/assets/docs/article/functional-desgin-ppp/haskell/05-property-based-testing.md +254 -254
  153. package/lib/assets/docs/article/functional-desgin-ppp/haskell/06-tdd-functional.md +283 -283
  154. package/lib/assets/docs/article/functional-desgin-ppp/haskell/07-composite-pattern.md +395 -395
  155. package/lib/assets/docs/article/functional-desgin-ppp/haskell/08-decorator-pattern.md +319 -319
  156. package/lib/assets/docs/article/functional-desgin-ppp/haskell/09-adapter-pattern.md +382 -382
  157. package/lib/assets/docs/article/functional-desgin-ppp/haskell/10-strategy-pattern.md +287 -287
  158. package/lib/assets/docs/article/functional-desgin-ppp/haskell/11-command-pattern.md +303 -303
  159. package/lib/assets/docs/article/functional-desgin-ppp/haskell/12-visitor-pattern.md +326 -326
  160. package/lib/assets/docs/article/functional-desgin-ppp/haskell/13-abstract-factory-pattern.md +332 -332
  161. package/lib/assets/docs/article/functional-desgin-ppp/haskell/14-abstract-server-pattern.md +379 -379
  162. package/lib/assets/docs/article/functional-desgin-ppp/haskell/15-gossiping-bus-drivers.md +177 -177
  163. package/lib/assets/docs/article/functional-desgin-ppp/haskell/16-payroll-system.md +219 -219
  164. package/lib/assets/docs/article/functional-desgin-ppp/haskell/17-video-rental-system.md +244 -244
  165. package/lib/assets/docs/article/functional-desgin-ppp/haskell/18-concurrency-system.md +363 -363
  166. package/lib/assets/docs/article/functional-desgin-ppp/haskell/19-wator-simulation.md +438 -438
  167. package/lib/assets/docs/article/functional-desgin-ppp/haskell/20-pattern-interactions.md +325 -325
  168. package/lib/assets/docs/article/functional-desgin-ppp/haskell/21-best-practices.md +403 -403
  169. package/lib/assets/docs/article/functional-desgin-ppp/haskell/22-oo-to-fp-migration.md +469 -469
  170. package/lib/assets/docs/article/functional-desgin-ppp/haskell/index.md +174 -174
  171. package/lib/assets/docs/article/functional-desgin-ppp/index.md +90 -90
  172. package/lib/assets/docs/article/functional-desgin-ppp/rust/01-immutability-and-data-transformation.md +450 -450
  173. package/lib/assets/docs/article/functional-desgin-ppp/rust/02-function-composition.md +463 -463
  174. package/lib/assets/docs/article/functional-desgin-ppp/rust/03-polymorphism.md +425 -425
  175. package/lib/assets/docs/article/functional-desgin-ppp/rust/04-data-validation.md +273 -273
  176. package/lib/assets/docs/article/functional-desgin-ppp/rust/05-property-based-testing.md +247 -247
  177. package/lib/assets/docs/article/functional-desgin-ppp/rust/06-tdd-and-functional.md +841 -841
  178. package/lib/assets/docs/article/functional-desgin-ppp/rust/07-composite-pattern.md +384 -384
  179. package/lib/assets/docs/article/functional-desgin-ppp/rust/08-decorator-pattern.md +383 -383
  180. package/lib/assets/docs/article/functional-desgin-ppp/rust/09-adapter-pattern.md +339 -339
  181. package/lib/assets/docs/article/functional-desgin-ppp/rust/10-strategy-pattern.md +331 -331
  182. package/lib/assets/docs/article/functional-desgin-ppp/rust/11-command-pattern.md +356 -356
  183. package/lib/assets/docs/article/functional-desgin-ppp/rust/12-visitor-pattern.md +379 -379
  184. package/lib/assets/docs/article/functional-desgin-ppp/rust/13-abstract-factory-pattern.md +361 -361
  185. package/lib/assets/docs/article/functional-desgin-ppp/rust/14-abstract-server-pattern.md +392 -392
  186. package/lib/assets/docs/article/functional-desgin-ppp/rust/15-gossiping-bus-drivers.md +300 -300
  187. package/lib/assets/docs/article/functional-desgin-ppp/rust/16-payroll-system.md +297 -297
  188. package/lib/assets/docs/article/functional-desgin-ppp/rust/17-video-rental-system.md +304 -304
  189. package/lib/assets/docs/article/functional-desgin-ppp/rust/18-concurrency-system.md +315 -315
  190. package/lib/assets/docs/article/functional-desgin-ppp/rust/19-wator-simulation.md +311 -311
  191. package/lib/assets/docs/article/functional-desgin-ppp/rust/20-pattern-interactions.md +304 -304
  192. package/lib/assets/docs/article/functional-desgin-ppp/rust/21-best-practices.md +336 -336
  193. package/lib/assets/docs/article/functional-desgin-ppp/rust/22-oo-to-fp-migration.md +349 -349
  194. package/lib/assets/docs/article/functional-desgin-ppp/rust/index.md +243 -243
  195. package/lib/assets/docs/article/functional-desgin-ppp/scala/01-immutability-and-data-transformation.md +328 -328
  196. package/lib/assets/docs/article/functional-desgin-ppp/scala/02-function-composition.md +348 -348
  197. package/lib/assets/docs/article/functional-desgin-ppp/scala/03-polymorphism.md +357 -357
  198. package/lib/assets/docs/article/functional-desgin-ppp/scala/04-data-validation.md +364 -364
  199. package/lib/assets/docs/article/functional-desgin-ppp/scala/05-property-based-testing.md +515 -515
  200. package/lib/assets/docs/article/functional-desgin-ppp/scala/06-tdd-functional.md +557 -557
  201. package/lib/assets/docs/article/functional-desgin-ppp/scala/07-composite-pattern.md +363 -363
  202. package/lib/assets/docs/article/functional-desgin-ppp/scala/08-decorator-pattern.md +327 -327
  203. package/lib/assets/docs/article/functional-desgin-ppp/scala/09-adapter-pattern.md +517 -517
  204. package/lib/assets/docs/article/functional-desgin-ppp/scala/10-strategy-pattern.md +441 -441
  205. package/lib/assets/docs/article/functional-desgin-ppp/scala/11-command-pattern.md +407 -407
  206. package/lib/assets/docs/article/functional-desgin-ppp/scala/12-visitor-pattern.md +379 -379
  207. package/lib/assets/docs/article/functional-desgin-ppp/scala/13-abstract-factory-pattern.md +398 -398
  208. package/lib/assets/docs/article/functional-desgin-ppp/scala/14-abstract-server-pattern.md +476 -476
  209. package/lib/assets/docs/article/functional-desgin-ppp/scala/15-gossiping-bus-drivers.md +391 -391
  210. package/lib/assets/docs/article/functional-desgin-ppp/scala/16-payroll-system.md +342 -342
  211. package/lib/assets/docs/article/functional-desgin-ppp/scala/17-video-rental-system.md +324 -324
  212. package/lib/assets/docs/article/functional-desgin-ppp/scala/18-concurrency-system.md +730 -730
  213. package/lib/assets/docs/article/functional-desgin-ppp/scala/19-wator-simulation.md +624 -624
  214. package/lib/assets/docs/article/functional-desgin-ppp/scala/20-pattern-interactions.md +512 -512
  215. package/lib/assets/docs/article/functional-desgin-ppp/scala/21-best-practices.md +433 -433
  216. package/lib/assets/docs/article/functional-desgin-ppp/scala/22-oo-to-fp-migration.md +688 -688
  217. package/lib/assets/docs/article/functional-desgin-ppp/scala/index.md +243 -243
  218. package/lib/assets/docs/article/getting-start-tdd/clojure/01-todo-list-and-first-test.md +166 -166
  219. package/lib/assets/docs/article/getting-start-tdd/clojure/02-fake-it-and-triangulation.md +162 -162
  220. package/lib/assets/docs/article/getting-start-tdd/clojure/03-obvious-implementation-and-refactoring.md +135 -135
  221. package/lib/assets/docs/article/getting-start-tdd/clojure/04-version-control-and-conventional-commits.md +88 -88
  222. package/lib/assets/docs/article/getting-start-tdd/clojure/05-package-management-and-static-analysis.md +299 -299
  223. package/lib/assets/docs/article/getting-start-tdd/clojure/06-task-runner-and-ci-cd.md +241 -241
  224. package/lib/assets/docs/article/getting-start-tdd/clojure/07-protocols-and-records.md +131 -131
  225. package/lib/assets/docs/article/getting-start-tdd/clojure/08-multimethods-and-design-patterns.md +130 -130
  226. package/lib/assets/docs/article/getting-start-tdd/clojure/09-namespaces-and-module-design.md +127 -127
  227. package/lib/assets/docs/article/getting-start-tdd/clojure/10-higher-order-functions-and-composition.md +114 -114
  228. package/lib/assets/docs/article/getting-start-tdd/clojure/11-persistent-data-and-pipeline.md +138 -138
  229. package/lib/assets/docs/article/getting-start-tdd/clojure/12-error-handling-and-spec.md +161 -161
  230. package/lib/assets/docs/article/getting-start-tdd/clojure/index.md +65 -65
  231. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter01.md +232 -232
  232. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter02.md +244 -244
  233. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter03.md +202 -202
  234. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter04.md +92 -92
  235. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter05.md +256 -256
  236. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter06.md +195 -195
  237. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter07.md +214 -214
  238. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter08.md +249 -249
  239. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter09.md +174 -174
  240. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter10.md +166 -166
  241. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter11.md +192 -192
  242. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter12.md +211 -211
  243. package/lib/assets/docs/article/getting-start-tdd/csharp/index.md +83 -83
  244. package/lib/assets/docs/article/getting-start-tdd/elixir/01-todo-list-and-first-test.md +87 -87
  245. package/lib/assets/docs/article/getting-start-tdd/elixir/02-fake-it-and-triangulation.md +95 -95
  246. package/lib/assets/docs/article/getting-start-tdd/elixir/03-obvious-implementation-and-refactoring.md +109 -109
  247. package/lib/assets/docs/article/getting-start-tdd/elixir/04-version-control-and-conventional-commits.md +96 -96
  248. package/lib/assets/docs/article/getting-start-tdd/elixir/05-package-management-and-static-analysis.md +88 -88
  249. package/lib/assets/docs/article/getting-start-tdd/elixir/06-task-runner-and-ci-cd.md +71 -71
  250. package/lib/assets/docs/article/getting-start-tdd/elixir/07-structs-and-protocols.md +110 -110
  251. package/lib/assets/docs/article/getting-start-tdd/elixir/08-pattern-matching-and-guards.md +108 -108
  252. package/lib/assets/docs/article/getting-start-tdd/elixir/09-module-design-and-behaviours.md +104 -104
  253. package/lib/assets/docs/article/getting-start-tdd/elixir/10-higher-order-functions-and-pipeline.md +178 -178
  254. package/lib/assets/docs/article/getting-start-tdd/elixir/11-stream-and-lazy-evaluation.md +142 -142
  255. package/lib/assets/docs/article/getting-start-tdd/elixir/12-error-handling-and-with.md +145 -145
  256. package/lib/assets/docs/article/getting-start-tdd/elixir/index.md +35 -35
  257. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter01.md +202 -202
  258. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter02.md +246 -246
  259. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter03.md +218 -218
  260. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter04.md +179 -179
  261. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter05.md +267 -267
  262. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter06.md +190 -190
  263. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter07.md +161 -161
  264. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter08.md +175 -175
  265. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter09.md +222 -222
  266. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter10.md +189 -189
  267. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter11.md +212 -212
  268. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter12.md +215 -215
  269. package/lib/assets/docs/article/getting-start-tdd/fsharp/index.md +71 -71
  270. package/lib/assets/docs/article/getting-start-tdd/go/01-todo-list-and-first-test.md +213 -213
  271. package/lib/assets/docs/article/getting-start-tdd/go/02-fake-it-and-triangulation.md +302 -302
  272. package/lib/assets/docs/article/getting-start-tdd/go/03-obvious-implementation-and-refactoring.md +339 -339
  273. package/lib/assets/docs/article/getting-start-tdd/go/04-version-control-and-conventional-commits.md +112 -112
  274. package/lib/assets/docs/article/getting-start-tdd/go/05-package-management-and-static-analysis.md +272 -272
  275. package/lib/assets/docs/article/getting-start-tdd/go/06-task-runner-and-ci-cd.md +233 -233
  276. package/lib/assets/docs/article/getting-start-tdd/go/07-encapsulation-and-polymorphism.md +394 -394
  277. package/lib/assets/docs/article/getting-start-tdd/go/08-design-patterns.md +422 -422
  278. package/lib/assets/docs/article/getting-start-tdd/go/09-solid-principles-and-module-design.md +400 -400
  279. package/lib/assets/docs/article/getting-start-tdd/go/10-higher-order-functions-and-composition.md +226 -226
  280. package/lib/assets/docs/article/getting-start-tdd/go/11-immutable-data-and-pipeline.md +296 -296
  281. package/lib/assets/docs/article/getting-start-tdd/go/12-error-handling-and-type-safety.md +411 -411
  282. package/lib/assets/docs/article/getting-start-tdd/go/index.md +83 -83
  283. package/lib/assets/docs/article/getting-start-tdd/haskell/01-todo-list-and-first-test.md +279 -279
  284. package/lib/assets/docs/article/getting-start-tdd/haskell/02-fake-it-and-triangulation.md +337 -337
  285. package/lib/assets/docs/article/getting-start-tdd/haskell/03-obvious-implementation-and-refactoring.md +257 -257
  286. package/lib/assets/docs/article/getting-start-tdd/haskell/04-version-control-and-conventional-commits.md +182 -182
  287. package/lib/assets/docs/article/getting-start-tdd/haskell/05-package-management-and-static-analysis.md +313 -313
  288. package/lib/assets/docs/article/getting-start-tdd/haskell/06-task-runner-and-ci-cd.md +309 -309
  289. package/lib/assets/docs/article/getting-start-tdd/haskell/07-algebraic-data-types-and-type-classes.md +412 -412
  290. package/lib/assets/docs/article/getting-start-tdd/haskell/08-pattern-matching-and-guards.md +390 -390
  291. package/lib/assets/docs/article/getting-start-tdd/haskell/09-module-design-and-smart-constructors.md +461 -461
  292. package/lib/assets/docs/article/getting-start-tdd/haskell/10-higher-order-functions-and-currying.md +434 -434
  293. package/lib/assets/docs/article/getting-start-tdd/haskell/11-function-composition-and-point-free.md +392 -392
  294. package/lib/assets/docs/article/getting-start-tdd/haskell/12-monad-and-error-handling.md +631 -631
  295. package/lib/assets/docs/article/getting-start-tdd/haskell/index.md +49 -49
  296. package/lib/assets/docs/article/getting-start-tdd/index.md +93 -93
  297. package/lib/assets/docs/article/getting-start-tdd/integration/01-language-overview.md +375 -375
  298. package/lib/assets/docs/article/getting-start-tdd/integration/02-test-framework-comparison.md +349 -349
  299. package/lib/assets/docs/article/getting-start-tdd/integration/03-tdd-pattern-comparison.md +445 -445
  300. package/lib/assets/docs/article/getting-start-tdd/integration/04-type-system-comparison.md +409 -409
  301. package/lib/assets/docs/article/getting-start-tdd/integration/05-dev-environment-comparison.md +330 -330
  302. package/lib/assets/docs/article/getting-start-tdd/integration/06-learning-roadmap.md +290 -290
  303. package/lib/assets/docs/article/getting-start-tdd/integration/index.md +69 -69
  304. package/lib/assets/docs/article/getting-start-tdd/java/01-todo-list-and-first-test.md +234 -234
  305. package/lib/assets/docs/article/getting-start-tdd/java/02-fake-it-and-triangulation.md +261 -261
  306. package/lib/assets/docs/article/getting-start-tdd/java/03-obvious-implementation-and-refactoring.md +185 -185
  307. package/lib/assets/docs/article/getting-start-tdd/java/04-version-control-and-conventional-commits.md +115 -115
  308. package/lib/assets/docs/article/getting-start-tdd/java/05-package-management-and-static-analysis.md +382 -382
  309. package/lib/assets/docs/article/getting-start-tdd/java/06-task-runner-and-ci-cd.md +272 -272
  310. package/lib/assets/docs/article/getting-start-tdd/java/07-encapsulation-and-polymorphism.md +626 -626
  311. package/lib/assets/docs/article/getting-start-tdd/java/08-design-patterns.md +393 -393
  312. package/lib/assets/docs/article/getting-start-tdd/java/09-solid-principles-and-module-design.md +310 -310
  313. package/lib/assets/docs/article/getting-start-tdd/java/10-higher-order-functions-and-composition.md +188 -188
  314. package/lib/assets/docs/article/getting-start-tdd/java/11-immutable-data-and-pipeline.md +167 -167
  315. package/lib/assets/docs/article/getting-start-tdd/java/12-error-handling-and-type-safety.md +205 -205
  316. package/lib/assets/docs/article/getting-start-tdd/java/index.md +61 -61
  317. package/lib/assets/docs/article/getting-start-tdd/node/01-todo-list-and-first-test.md +244 -244
  318. package/lib/assets/docs/article/getting-start-tdd/node/02-fake-it-and-triangulation.md +262 -262
  319. package/lib/assets/docs/article/getting-start-tdd/node/03-obvious-implementation-and-refactoring.md +169 -169
  320. package/lib/assets/docs/article/getting-start-tdd/node/04-version-control-and-conventional-commits.md +112 -112
  321. package/lib/assets/docs/article/getting-start-tdd/node/05-package-management-and-static-analysis.md +314 -314
  322. package/lib/assets/docs/article/getting-start-tdd/node/06-task-runner-and-ci-cd.md +235 -235
  323. package/lib/assets/docs/article/getting-start-tdd/node/07-encapsulation-and-polymorphism.md +327 -327
  324. package/lib/assets/docs/article/getting-start-tdd/node/08-design-patterns.md +322 -322
  325. package/lib/assets/docs/article/getting-start-tdd/node/09-solid-principles-and-module-design.md +285 -285
  326. package/lib/assets/docs/article/getting-start-tdd/node/10-higher-order-functions-and-composition.md +199 -199
  327. package/lib/assets/docs/article/getting-start-tdd/node/11-immutable-data-and-pipeline.md +207 -207
  328. package/lib/assets/docs/article/getting-start-tdd/node/12-error-handling-and-type-safety.md +295 -295
  329. package/lib/assets/docs/article/getting-start-tdd/node/index.md +56 -56
  330. package/lib/assets/docs/article/getting-start-tdd/php/01-todo-list-and-first-test.md +259 -259
  331. package/lib/assets/docs/article/getting-start-tdd/php/02-fake-it-and-triangulation.md +200 -200
  332. package/lib/assets/docs/article/getting-start-tdd/php/03-obvious-implementation-and-refactoring.md +248 -248
  333. package/lib/assets/docs/article/getting-start-tdd/php/04-version-control-and-conventional-commits.md +141 -141
  334. package/lib/assets/docs/article/getting-start-tdd/php/05-package-management-and-static-analysis.md +410 -410
  335. package/lib/assets/docs/article/getting-start-tdd/php/06-task-runner-and-ci-cd.md +321 -321
  336. package/lib/assets/docs/article/getting-start-tdd/php/07-encapsulation-and-polymorphism.md +372 -372
  337. package/lib/assets/docs/article/getting-start-tdd/php/08-design-patterns.md +453 -453
  338. package/lib/assets/docs/article/getting-start-tdd/php/09-solid-principles-and-module-design.md +460 -460
  339. package/lib/assets/docs/article/getting-start-tdd/php/10-higher-order-functions-and-composition.md +182 -182
  340. package/lib/assets/docs/article/getting-start-tdd/php/11-immutable-data-and-pipeline.md +266 -266
  341. package/lib/assets/docs/article/getting-start-tdd/php/12-error-handling-and-type-safety.md +308 -308
  342. package/lib/assets/docs/article/getting-start-tdd/php/index.md +84 -84
  343. package/lib/assets/docs/article/getting-start-tdd/python/01-todo-list-and-first-test.md +201 -201
  344. package/lib/assets/docs/article/getting-start-tdd/python/02-fake-it-and-triangulation.md +247 -247
  345. package/lib/assets/docs/article/getting-start-tdd/python/03-obvious-implementation-and-refactoring.md +199 -199
  346. package/lib/assets/docs/article/getting-start-tdd/python/04-version-control-and-conventional-commits.md +87 -87
  347. package/lib/assets/docs/article/getting-start-tdd/python/05-package-management-and-static-analysis.md +274 -274
  348. package/lib/assets/docs/article/getting-start-tdd/python/06-task-runner-and-ci-cd.md +190 -190
  349. package/lib/assets/docs/article/getting-start-tdd/python/07-encapsulation-and-polymorphism.md +208 -208
  350. package/lib/assets/docs/article/getting-start-tdd/python/08-design-patterns.md +172 -172
  351. package/lib/assets/docs/article/getting-start-tdd/python/09-solid-principles-and-module-design.md +130 -130
  352. package/lib/assets/docs/article/getting-start-tdd/python/10-higher-order-functions-and-composition.md +122 -122
  353. package/lib/assets/docs/article/getting-start-tdd/python/11-immutable-data-and-pipeline.md +116 -116
  354. package/lib/assets/docs/article/getting-start-tdd/python/12-error-handling-and-type-safety.md +126 -126
  355. package/lib/assets/docs/article/getting-start-tdd/python/index.md +55 -55
  356. package/lib/assets/docs/article/getting-start-tdd/ruby/01-todo-list-and-first-test.md +231 -231
  357. package/lib/assets/docs/article/getting-start-tdd/ruby/02-fake-it-and-triangulation.md +238 -238
  358. package/lib/assets/docs/article/getting-start-tdd/ruby/03-obvious-implementation-and-refactoring.md +228 -228
  359. package/lib/assets/docs/article/getting-start-tdd/ruby/04-version-control-and-conventional-commits.md +112 -112
  360. package/lib/assets/docs/article/getting-start-tdd/ruby/05-package-management-and-static-analysis.md +287 -287
  361. package/lib/assets/docs/article/getting-start-tdd/ruby/06-task-runner-and-ci-cd.md +248 -248
  362. package/lib/assets/docs/article/getting-start-tdd/ruby/07-encapsulation-and-polymorphism.md +279 -279
  363. package/lib/assets/docs/article/getting-start-tdd/ruby/08-design-patterns.md +329 -329
  364. package/lib/assets/docs/article/getting-start-tdd/ruby/09-solid-principles-and-module-design.md +196 -196
  365. package/lib/assets/docs/article/getting-start-tdd/ruby/10-higher-order-functions-and-composition.md +175 -175
  366. package/lib/assets/docs/article/getting-start-tdd/ruby/11-immutable-data-and-pipeline.md +237 -237
  367. package/lib/assets/docs/article/getting-start-tdd/ruby/12-error-handling-and-type-safety.md +398 -398
  368. package/lib/assets/docs/article/getting-start-tdd/ruby/index.md +83 -83
  369. package/lib/assets/docs/article/getting-start-tdd/rust/01-todo-list-and-first-test.md +211 -211
  370. package/lib/assets/docs/article/getting-start-tdd/rust/02-fake-it-and-triangulation.md +264 -264
  371. package/lib/assets/docs/article/getting-start-tdd/rust/03-obvious-implementation-and-refactoring.md +233 -233
  372. package/lib/assets/docs/article/getting-start-tdd/rust/04-version-control-and-conventional-commits.md +92 -92
  373. package/lib/assets/docs/article/getting-start-tdd/rust/05-package-management-and-static-analysis.md +212 -212
  374. package/lib/assets/docs/article/getting-start-tdd/rust/06-task-runner-and-ci-cd.md +164 -164
  375. package/lib/assets/docs/article/getting-start-tdd/rust/07-encapsulation-and-polymorphism.md +142 -142
  376. package/lib/assets/docs/article/getting-start-tdd/rust/08-design-patterns.md +145 -145
  377. package/lib/assets/docs/article/getting-start-tdd/rust/09-solid-principles-and-module-design.md +110 -110
  378. package/lib/assets/docs/article/getting-start-tdd/rust/10-higher-order-functions-and-composition.md +94 -94
  379. package/lib/assets/docs/article/getting-start-tdd/rust/11-immutable-data-and-pipeline.md +105 -105
  380. package/lib/assets/docs/article/getting-start-tdd/rust/12-error-handling-and-type-safety.md +112 -112
  381. package/lib/assets/docs/article/getting-start-tdd/rust/index.md +83 -83
  382. package/lib/assets/docs/article/getting-start-tdd/scala/01-todo-list-and-first-test.md +111 -111
  383. package/lib/assets/docs/article/getting-start-tdd/scala/02-fake-it-and-triangulation.md +107 -107
  384. package/lib/assets/docs/article/getting-start-tdd/scala/03-obvious-implementation-and-refactoring.md +99 -99
  385. package/lib/assets/docs/article/getting-start-tdd/scala/04-version-control-and-conventional-commits.md +123 -123
  386. package/lib/assets/docs/article/getting-start-tdd/scala/05-package-management-and-static-analysis.md +196 -196
  387. package/lib/assets/docs/article/getting-start-tdd/scala/06-task-runner-and-ci-cd.md +186 -186
  388. package/lib/assets/docs/article/getting-start-tdd/scala/07-case-classes-and-traits.md +139 -139
  389. package/lib/assets/docs/article/getting-start-tdd/scala/08-pattern-matching-and-sealed-traits.md +106 -106
  390. package/lib/assets/docs/article/getting-start-tdd/scala/09-packages-and-module-design.md +75 -75
  391. package/lib/assets/docs/article/getting-start-tdd/scala/10-higher-order-functions-and-composition.md +104 -104
  392. package/lib/assets/docs/article/getting-start-tdd/scala/11-collections-and-lazy-evaluation.md +94 -94
  393. package/lib/assets/docs/article/getting-start-tdd/scala/12-error-handling-and-type-safety.md +92 -92
  394. package/lib/assets/docs/article/getting-start-tdd/scala/index.md +65 -65
  395. package/lib/assets/docs/article/grokking-concurrency/all/index.md +404 -404
  396. package/lib/assets/docs/article/grokking-concurrency/all/part-1-ch02-sequential.md +554 -554
  397. package/lib/assets/docs/article/grokking-concurrency/all/part-2-ch04-05-threads.md +469 -469
  398. package/lib/assets/docs/article/grokking-concurrency/all/part-3-ch06-multitasking.md +520 -520
  399. package/lib/assets/docs/article/grokking-concurrency/all/part-4-ch07-parallel-patterns.md +420 -420
  400. package/lib/assets/docs/article/grokking-concurrency/all/part-5-ch08-09-synchronization.md +510 -510
  401. package/lib/assets/docs/article/grokking-concurrency/all/part-6-ch10-11-nonblocking-io.md +435 -435
  402. package/lib/assets/docs/article/grokking-concurrency/all/part-7-ch12-async.md +465 -465
  403. package/lib/assets/docs/article/grokking-concurrency/all/part-8-ch13-mapreduce.md +377 -377
  404. package/lib/assets/docs/article/grokking-concurrency/clojure/index.md +116 -116
  405. package/lib/assets/docs/article/grokking-concurrency/clojure/part-1.md +108 -108
  406. package/lib/assets/docs/article/grokking-concurrency/clojure/part-2.md +101 -101
  407. package/lib/assets/docs/article/grokking-concurrency/clojure/part-3.md +122 -122
  408. package/lib/assets/docs/article/grokking-concurrency/clojure/part-4.md +123 -123
  409. package/lib/assets/docs/article/grokking-concurrency/clojure/part-5.md +118 -118
  410. package/lib/assets/docs/article/grokking-concurrency/clojure/part-6.md +89 -89
  411. package/lib/assets/docs/article/grokking-concurrency/clojure/part-7.md +100 -100
  412. package/lib/assets/docs/article/grokking-concurrency/clojure/part-8.md +120 -120
  413. package/lib/assets/docs/article/grokking-concurrency/csharp/index.md +101 -101
  414. package/lib/assets/docs/article/grokking-concurrency/csharp/part-1.md +97 -97
  415. package/lib/assets/docs/article/grokking-concurrency/csharp/part-2.md +123 -123
  416. package/lib/assets/docs/article/grokking-concurrency/csharp/part-3.md +101 -101
  417. package/lib/assets/docs/article/grokking-concurrency/csharp/part-4.md +112 -112
  418. package/lib/assets/docs/article/grokking-concurrency/csharp/part-5.md +99 -99
  419. package/lib/assets/docs/article/grokking-concurrency/csharp/part-6.md +61 -61
  420. package/lib/assets/docs/article/grokking-concurrency/csharp/part-7.md +84 -84
  421. package/lib/assets/docs/article/grokking-concurrency/csharp/part-8.md +92 -92
  422. package/lib/assets/docs/article/grokking-concurrency/fsharp/index.md +65 -65
  423. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-1.md +80 -80
  424. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-2.md +103 -103
  425. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-3.md +94 -94
  426. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-4.md +110 -110
  427. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-5.md +104 -104
  428. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-6.md +93 -93
  429. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-7.md +121 -121
  430. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-8.md +107 -107
  431. package/lib/assets/docs/article/grokking-concurrency/haskell/index.md +248 -248
  432. package/lib/assets/docs/article/grokking-concurrency/haskell/part-1.md +96 -96
  433. package/lib/assets/docs/article/grokking-concurrency/haskell/part-2.md +96 -96
  434. package/lib/assets/docs/article/grokking-concurrency/haskell/part-3.md +91 -91
  435. package/lib/assets/docs/article/grokking-concurrency/haskell/part-4.md +106 -106
  436. package/lib/assets/docs/article/grokking-concurrency/haskell/part-5.md +99 -99
  437. package/lib/assets/docs/article/grokking-concurrency/haskell/part-6.md +95 -95
  438. package/lib/assets/docs/article/grokking-concurrency/haskell/part-7.md +111 -111
  439. package/lib/assets/docs/article/grokking-concurrency/haskell/part-8.md +118 -118
  440. package/lib/assets/docs/article/grokking-concurrency/index.md +66 -66
  441. package/lib/assets/docs/article/grokking-concurrency/java/index.md +102 -102
  442. package/lib/assets/docs/article/grokking-concurrency/java/part-1.md +308 -308
  443. package/lib/assets/docs/article/grokking-concurrency/java/part-2.md +334 -334
  444. package/lib/assets/docs/article/grokking-concurrency/java/part-3.md +221 -221
  445. package/lib/assets/docs/article/grokking-concurrency/java/part-4.md +213 -213
  446. package/lib/assets/docs/article/grokking-concurrency/java/part-5.md +112 -112
  447. package/lib/assets/docs/article/grokking-concurrency/java/part-6.md +69 -69
  448. package/lib/assets/docs/article/grokking-concurrency/java/part-7.md +101 -101
  449. package/lib/assets/docs/article/grokking-concurrency/java/part-8.md +101 -101
  450. package/lib/assets/docs/article/grokking-concurrency/python/index.md +313 -313
  451. package/lib/assets/docs/article/grokking-concurrency/python/part-1.md +239 -239
  452. package/lib/assets/docs/article/grokking-concurrency/python/part-2.md +418 -418
  453. package/lib/assets/docs/article/grokking-concurrency/python/part-3.md +227 -227
  454. package/lib/assets/docs/article/grokking-concurrency/python/part-4.md +299 -299
  455. package/lib/assets/docs/article/grokking-concurrency/python/part-5.md +315 -315
  456. package/lib/assets/docs/article/grokking-concurrency/python/part-6.md +297 -297
  457. package/lib/assets/docs/article/grokking-concurrency/python/part-7.md +314 -314
  458. package/lib/assets/docs/article/grokking-concurrency/python/part-8.md +360 -360
  459. package/lib/assets/docs/article/grokking-concurrency/rust/index.md +270 -270
  460. package/lib/assets/docs/article/grokking-concurrency/rust/part-1.md +108 -108
  461. package/lib/assets/docs/article/grokking-concurrency/rust/part-2.md +120 -120
  462. package/lib/assets/docs/article/grokking-concurrency/rust/part-3.md +126 -126
  463. package/lib/assets/docs/article/grokking-concurrency/rust/part-4.md +175 -175
  464. package/lib/assets/docs/article/grokking-concurrency/rust/part-5.md +158 -158
  465. package/lib/assets/docs/article/grokking-concurrency/rust/part-6.md +94 -94
  466. package/lib/assets/docs/article/grokking-concurrency/rust/part-7.md +133 -133
  467. package/lib/assets/docs/article/grokking-concurrency/rust/part-8.md +155 -155
  468. package/lib/assets/docs/article/grokking-concurrency/scala/index.md +69 -69
  469. package/lib/assets/docs/article/grokking-concurrency/scala/part-1.md +78 -78
  470. package/lib/assets/docs/article/grokking-concurrency/scala/part-2.md +112 -112
  471. package/lib/assets/docs/article/grokking-concurrency/scala/part-3.md +93 -93
  472. package/lib/assets/docs/article/grokking-concurrency/scala/part-4.md +110 -110
  473. package/lib/assets/docs/article/grokking-concurrency/scala/part-5.md +119 -119
  474. package/lib/assets/docs/article/grokking-concurrency/scala/part-6.md +83 -83
  475. package/lib/assets/docs/article/grokking-concurrency/scala/part-7.md +131 -131
  476. package/lib/assets/docs/article/grokking-concurrency/scala/part-8.md +129 -129
  477. package/lib/assets/docs/article/grokkingfp/all/index.md +368 -368
  478. package/lib/assets/docs/article/grokkingfp/all/part-1-ch01-fp-introduction.md +530 -530
  479. package/lib/assets/docs/article/grokkingfp/all/part-1-ch02-pure-functions.md +923 -923
  480. package/lib/assets/docs/article/grokkingfp/all/part-2-ch03-immutable-data.md +1128 -1128
  481. package/lib/assets/docs/article/grokkingfp/all/part-2-ch04-higher-order-functions.md +1104 -1104
  482. package/lib/assets/docs/article/grokkingfp/all/part-2-ch05-flatmap.md +1026 -1026
  483. package/lib/assets/docs/article/grokkingfp/all/part-3-ch06-option.md +785 -785
  484. package/lib/assets/docs/article/grokkingfp/all/part-3-ch07-either-adt.md +871 -871
  485. package/lib/assets/docs/article/grokkingfp/all/part-4-ch08-io-monad.md +972 -972
  486. package/lib/assets/docs/article/grokkingfp/all/part-4-ch09-streams.md +926 -926
  487. package/lib/assets/docs/article/grokkingfp/all/part-5-ch10-concurrency.md +870 -870
  488. package/lib/assets/docs/article/grokkingfp/all/part-6-ch11-application.md +715 -715
  489. package/lib/assets/docs/article/grokkingfp/all/part-6-ch12-testing.md +626 -626
  490. package/lib/assets/docs/article/grokkingfp/all/writing-plan.md +712 -712
  491. package/lib/assets/docs/article/grokkingfp/clojure/index.md +276 -276
  492. package/lib/assets/docs/article/grokkingfp/clojure/part-1.md +667 -667
  493. package/lib/assets/docs/article/grokkingfp/clojure/part-2.md +643 -643
  494. package/lib/assets/docs/article/grokkingfp/clojure/part-3.md +620 -620
  495. package/lib/assets/docs/article/grokkingfp/clojure/part-4.md +697 -697
  496. package/lib/assets/docs/article/grokkingfp/clojure/part-5.md +751 -751
  497. package/lib/assets/docs/article/grokkingfp/clojure/part-6.md +721 -721
  498. package/lib/assets/docs/article/grokkingfp/csharp/index.md +246 -246
  499. package/lib/assets/docs/article/grokkingfp/csharp/part-1.md +811 -811
  500. package/lib/assets/docs/article/grokkingfp/csharp/part-2.md +971 -971
  501. package/lib/assets/docs/article/grokkingfp/csharp/part-3.md +981 -981
  502. package/lib/assets/docs/article/grokkingfp/csharp/part-4.md +949 -949
  503. package/lib/assets/docs/article/grokkingfp/csharp/part-5.md +947 -947
  504. package/lib/assets/docs/article/grokkingfp/csharp/part-6.md +739 -739
  505. package/lib/assets/docs/article/grokkingfp/elixir/index.md +203 -203
  506. package/lib/assets/docs/article/grokkingfp/elixir/part-1.md +712 -712
  507. package/lib/assets/docs/article/grokkingfp/elixir/part-2.md +838 -838
  508. package/lib/assets/docs/article/grokkingfp/elixir/part-3.md +985 -985
  509. package/lib/assets/docs/article/grokkingfp/elixir/part-4.md +974 -974
  510. package/lib/assets/docs/article/grokkingfp/elixir/part-5.md +1286 -1286
  511. package/lib/assets/docs/article/grokkingfp/elixir/part-6.md +1049 -1049
  512. package/lib/assets/docs/article/grokkingfp/fsharp/index.md +210 -210
  513. package/lib/assets/docs/article/grokkingfp/fsharp/part-1.md +714 -714
  514. package/lib/assets/docs/article/grokkingfp/fsharp/part-2.md +961 -961
  515. package/lib/assets/docs/article/grokkingfp/fsharp/part-3.md +972 -972
  516. package/lib/assets/docs/article/grokkingfp/fsharp/part-4.md +832 -832
  517. package/lib/assets/docs/article/grokkingfp/fsharp/part-5.md +911 -911
  518. package/lib/assets/docs/article/grokkingfp/fsharp/part-6.md +922 -922
  519. package/lib/assets/docs/article/grokkingfp/haskell/index.md +234 -234
  520. package/lib/assets/docs/article/grokkingfp/haskell/part-1.md +591 -591
  521. package/lib/assets/docs/article/grokkingfp/haskell/part-2.md +866 -866
  522. package/lib/assets/docs/article/grokkingfp/haskell/part-3.md +915 -915
  523. package/lib/assets/docs/article/grokkingfp/haskell/part-4.md +878 -878
  524. package/lib/assets/docs/article/grokkingfp/haskell/part-5.md +845 -845
  525. package/lib/assets/docs/article/grokkingfp/haskell/part-6.md +844 -844
  526. package/lib/assets/docs/article/grokkingfp/index.md +143 -143
  527. package/lib/assets/docs/article/grokkingfp/java/index.md +211 -211
  528. package/lib/assets/docs/article/grokkingfp/java/part-1.md +648 -648
  529. package/lib/assets/docs/article/grokkingfp/java/part-2.md +675 -675
  530. package/lib/assets/docs/article/grokkingfp/java/part-3.md +672 -672
  531. package/lib/assets/docs/article/grokkingfp/java/part-4.md +771 -771
  532. package/lib/assets/docs/article/grokkingfp/java/part-5.md +959 -959
  533. package/lib/assets/docs/article/grokkingfp/java/part-6.md +1328 -1328
  534. package/lib/assets/docs/article/grokkingfp/python/index.md +258 -258
  535. package/lib/assets/docs/article/grokkingfp/python/part-1.md +443 -443
  536. package/lib/assets/docs/article/grokkingfp/python/part-2.md +958 -958
  537. package/lib/assets/docs/article/grokkingfp/python/part-3.md +1004 -1004
  538. package/lib/assets/docs/article/grokkingfp/python/part-4.md +765 -765
  539. package/lib/assets/docs/article/grokkingfp/python/part-5.md +747 -747
  540. package/lib/assets/docs/article/grokkingfp/python/part-6.md +861 -861
  541. package/lib/assets/docs/article/grokkingfp/ruby/index.md +330 -330
  542. package/lib/assets/docs/article/grokkingfp/ruby/part-1.md +755 -755
  543. package/lib/assets/docs/article/grokkingfp/ruby/part-2.md +938 -938
  544. package/lib/assets/docs/article/grokkingfp/ruby/part-3.md +946 -946
  545. package/lib/assets/docs/article/grokkingfp/ruby/part-4.md +921 -921
  546. package/lib/assets/docs/article/grokkingfp/ruby/part-5.md +908 -908
  547. package/lib/assets/docs/article/grokkingfp/ruby/part-6.md +1412 -1412
  548. package/lib/assets/docs/article/grokkingfp/rust/index.md +242 -242
  549. package/lib/assets/docs/article/grokkingfp/rust/part-1.md +634 -634
  550. package/lib/assets/docs/article/grokkingfp/rust/part-2.md +1060 -1060
  551. package/lib/assets/docs/article/grokkingfp/rust/part-3.md +994 -994
  552. package/lib/assets/docs/article/grokkingfp/rust/part-4.md +573 -573
  553. package/lib/assets/docs/article/grokkingfp/rust/part-5.md +705 -705
  554. package/lib/assets/docs/article/grokkingfp/rust/part-6.md +508 -508
  555. package/lib/assets/docs/article/grokkingfp/scala/index.md +171 -171
  556. package/lib/assets/docs/article/grokkingfp/scala/part-1.md +543 -543
  557. package/lib/assets/docs/article/grokkingfp/scala/part-2.md +946 -946
  558. package/lib/assets/docs/article/grokkingfp/scala/part-3.md +919 -919
  559. package/lib/assets/docs/article/grokkingfp/scala/part-4.md +742 -742
  560. package/lib/assets/docs/article/grokkingfp/scala/part-5.md +722 -722
  561. package/lib/assets/docs/article/grokkingfp/scala/part-6.md +867 -867
  562. package/lib/assets/docs/article/grokkingfp/typescript/index.md +273 -273
  563. package/lib/assets/docs/article/grokkingfp/typescript/part-1.md +561 -561
  564. package/lib/assets/docs/article/grokkingfp/typescript/part-2.md +1129 -1129
  565. package/lib/assets/docs/article/grokkingfp/typescript/part-3.md +842 -842
  566. package/lib/assets/docs/article/grokkingfp/typescript/part-4.md +1087 -1087
  567. package/lib/assets/docs/article/grokkingfp/typescript/part-5.md +717 -717
  568. package/lib/assets/docs/article/grokkingfp/typescript/part-6.md +982 -982
  569. package/lib/assets/docs/article/practical-database-design/index.md +121 -121
  570. package/lib/assets/docs/article/practical-database-design/part1/chapter01.md +288 -288
  571. package/lib/assets/docs/article/practical-database-design/part1/chapter02.md +518 -518
  572. package/lib/assets/docs/article/practical-database-design/part1/chapter03.md +557 -557
  573. package/lib/assets/docs/article/practical-database-design/part2/chapter04.md +924 -924
  574. package/lib/assets/docs/article/practical-database-design/part2/chapter05.md +1627 -1627
  575. package/lib/assets/docs/article/practical-database-design/part2/chapter06.md +2716 -2716
  576. package/lib/assets/docs/article/practical-database-design/part2/chapter07.md +2082 -2082
  577. package/lib/assets/docs/article/practical-database-design/part2/chapter08.md +2105 -2105
  578. package/lib/assets/docs/article/practical-database-design/part2/chapter09.md +2031 -2031
  579. package/lib/assets/docs/article/practical-database-design/part2/chapter10.md +1387 -1387
  580. package/lib/assets/docs/article/practical-database-design/part2/chapter11.md +1677 -1677
  581. package/lib/assets/docs/article/practical-database-design/part2/chapter12.md +1417 -1417
  582. package/lib/assets/docs/article/practical-database-design/part2/chapter13.md +1434 -1434
  583. package/lib/assets/docs/article/practical-database-design/part3/chapter14.md +667 -667
  584. package/lib/assets/docs/article/practical-database-design/part3/chapter15.md +1625 -1625
  585. package/lib/assets/docs/article/practical-database-design/part3/chapter16.md +1915 -1915
  586. package/lib/assets/docs/article/practical-database-design/part3/chapter17.md +1708 -1708
  587. package/lib/assets/docs/article/practical-database-design/part3/chapter18.md +2095 -2095
  588. package/lib/assets/docs/article/practical-database-design/part3/chapter19.md +1123 -1123
  589. package/lib/assets/docs/article/practical-database-design/part3/chapter20.md +1031 -1031
  590. package/lib/assets/docs/article/practical-database-design/part3/chapter21.md +1382 -1382
  591. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter14-orm.md +991 -991
  592. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter15-orm.md +1300 -1300
  593. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter16-orm.md +1166 -1166
  594. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter17-orm.md +1584 -1584
  595. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter18-orm.md +1183 -1183
  596. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter19-orm.md +1016 -1016
  597. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter20-orm.md +1753 -1753
  598. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter21-orm.md +1447 -1447
  599. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter22-orm.md +1878 -1878
  600. package/lib/assets/docs/article/practical-database-design/part4/chapter22.md +965 -965
  601. package/lib/assets/docs/article/practical-database-design/part4/chapter23.md +2069 -2069
  602. package/lib/assets/docs/article/practical-database-design/part4/chapter24.md +2439 -2439
  603. package/lib/assets/docs/article/practical-database-design/part4/chapter25.md +3661 -3661
  604. package/lib/assets/docs/article/practical-database-design/part4/chapter26.md +2916 -2916
  605. package/lib/assets/docs/article/practical-database-design/part4/chapter27.md +3105 -3105
  606. package/lib/assets/docs/article/practical-database-design/part4/chapter28.md +2697 -2697
  607. package/lib/assets/docs/article/practical-database-design/part4/chapter29.md +2544 -2544
  608. package/lib/assets/docs/article/practical-database-design/part4/chapter30.md +2180 -2180
  609. package/lib/assets/docs/article/practical-database-design/part4/chapter31.md +1192 -1192
  610. package/lib/assets/docs/article/practical-database-design/part4/chapter32.md +2101 -2101
  611. package/lib/assets/docs/article/practical-database-design/part5/chapter33.md +1032 -1032
  612. package/lib/assets/docs/article/practical-database-design/part5/chapter34.md +1609 -1609
  613. package/lib/assets/docs/article/practical-database-design/part5/chapter35.md +1453 -1453
  614. package/lib/assets/docs/article/practical-database-design/part5/chapter36.md +1292 -1292
  615. package/lib/assets/docs/article/practical-database-design/part5/chapter37.md +1470 -1470
  616. package/lib/assets/docs/article/practical-database-design/part5/chapter38.md +1698 -1698
  617. package/lib/assets/docs/article/practical-database-design/part5/chapter39.md +2334 -2334
  618. package/lib/assets/docs/article/practical-database-design/study/study2-1.md +1693 -1693
  619. package/lib/assets/docs/article/practical-database-design/study/study2-2.md +1347 -1347
  620. package/lib/assets/docs/article/practical-database-design/study/study2-3.md +2044 -2044
  621. package/lib/assets/docs/article/practical-database-design/study/study2-4.md +2229 -2229
  622. package/lib/assets/docs/article/practical-database-design/study/study2-5.md +2418 -2418
  623. package/lib/assets/docs/article/practical-database-design/study/study3-1.md +2205 -2205
  624. package/lib/assets/docs/article/practical-database-design/study/study3-2.md +2221 -2221
  625. package/lib/assets/docs/article/practical-database-design/study/study3-3.md +2253 -2253
  626. package/lib/assets/docs/article/practical-database-design/study/study3-4.md +2106 -2106
  627. package/lib/assets/docs/article/practical-database-design/study/study3-5.md +2507 -2507
  628. package/lib/assets/docs/article/practical-database-design/study/study4-1.md +2587 -2587
  629. package/lib/assets/docs/article/practical-database-design/study/study4-2.md +2075 -2075
  630. package/lib/assets/docs/article/practical-database-design/study/study4-3.md +1805 -1805
  631. package/lib/assets/docs/article/practical-database-design/study/study4-4.md +1895 -1895
  632. package/lib/assets/docs/article/practical-database-design/study/study4-5.md +2878 -2878
  633. package/lib/assets/docs/assets/css/extra.css +29 -29
  634. package/lib/assets/docs/assets/js/extra.js +44 -44
  635. package/lib/assets/docs/development/index.md +39 -39
  636. package/lib/assets/docs/operation/index.md +11 -11
  637. package/lib/assets/docs/reference/CodexCLIMCP/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/343/203/225/343/203/255/343/203/274.md +532 -532
  638. package/lib/assets/docs/reference/CodexCLIMCP/343/202/265/343/203/274/343/203/220/343/203/274/350/250/255/345/256/232/346/211/213/351/240/206.md +341 -341
  639. package/lib/assets/docs/reference/Java/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +581 -581
  640. package/lib/assets/docs/reference/SonarQube/343/203/255/343/203/274/343/202/253/343/203/253/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +642 -642
  641. package/lib/assets/docs/reference/TypeScript/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +465 -465
  642. package/lib/assets/docs/reference/UI/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +450 -450
  643. package/lib/assets/docs/reference/images/Ansoff.drawio.svg +3 -3
  644. package/lib/assets/docs/reference/images/BrandBasicStrategy.drawio.svg +3 -3
  645. package/lib/assets/docs/reference/images/BrandCategorization.drawio.svg +3 -3
  646. package/lib/assets/docs/reference/images/BrandRecurutementStrategy.drawio.svg +3 -3
  647. package/lib/assets/docs/reference/images/BrandValue.drawio.svg +3 -3
  648. package/lib/assets/docs/reference/images/BusinessActivitiy.svg +3 -3
  649. package/lib/assets/docs/reference/images/HRM.drawio.svg +3 -3
  650. package/lib/assets/docs/reference/images/MarketingStructure.drawio.svg +3 -3
  651. package/lib/assets/docs/reference/images/OrganizationElemnts.svg +3 -3
  652. package/lib/assets/docs/reference/images/PPM.drawio.svg +3 -3
  653. package/lib/assets/docs/reference/images/PositioningMap.drawio.svg +3 -3
  654. package/lib/assets/docs/reference/images/ProductLayer.drawio.svg +3 -3
  655. package/lib/assets/docs/reference/images/ProductMix.drawio.svg +3 -3
  656. package/lib/assets/docs/reference/images/SWOT.drawio.svg +3 -3
  657. package/lib/assets/docs/reference/images/TargetMarket.drawio.svg +3 -3
  658. package/lib/assets/docs/reference/images/ThreeGenericStrategies.drawio.svg +3 -3
  659. package/lib/assets/docs/reference/images/VRIO.drawio.svg +3 -3
  660. package/lib/assets/docs/reference/images/ValueChain.drawio.svg +3 -3
  661. package/lib/assets/docs/reference/index.md +52 -52
  662. package/lib/assets/docs/reference//343/202/210/343/201/204/343/202/275/343/203/225/343/203/210/343/202/246/343/202/247/343/202/242/343/201/250/343/201/257.md +250 -250
  663. package/lib/assets/docs/reference//343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +2216 -2216
  664. package/lib/assets/docs/reference//343/202/244/343/203/263/343/203/225/343/203/251/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +1878 -1878
  665. package/lib/assets/docs/reference//343/202/250/343/202/257/343/202/271/343/203/210/343/203/252/343/203/274/343/203/240/343/203/227/343/203/255/343/202/260/343/203/251/343/203/237/343/203/263/343/202/260.md +550 -550
  666. package/lib/assets/docs/reference//343/202/263/343/203/274/343/203/207/343/202/243/343/203/263/343/202/260/343/201/250/343/203/206/343/202/271/343/203/210/343/202/254/343/202/244/343/203/211.md +705 -705
  667. package/lib/assets/docs/reference//343/203/206/343/202/271/343/203/210/346/210/246/347/225/245/343/202/254/343/202/244/343/203/211.md +1313 -1313
  668. package/lib/assets/docs/reference//343/203/207/343/203/274/343/202/277/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +311 -311
  669. package/lib/assets/docs/reference//343/203/211/343/203/241/343/202/244/343/203/263/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +599 -599
  670. package/lib/assets/docs/reference//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/345/210/206/346/236/220/343/202/254/343/202/244/343/203/211.md +528 -528
  671. package/lib/assets/docs/reference//343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +689 -689
  672. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/202/254/343/202/244/343/203/211.md +461 -461
  673. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/203/273/343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/350/250/210/347/224/273/343/202/254/343/202/244/343/203/211.md +580 -580
  674. package/lib/assets/docs/reference//343/203/255/343/202/270/343/202/253/343/203/253/343/202/267/343/203/263/343/202/255/343/203/263/343/202/260.md +1367 -1367
  675. package/lib/assets/docs/reference//344/274/201/346/245/255/347/265/214/345/226/266/350/253/226.md +2637 -2637
  676. package/lib/assets/docs/reference//347/222/260/345/242/203/345/244/211/346/225/260/347/256/241/347/220/206/343/202/254/343/202/244/343/203/211.md +665 -665
  677. package/lib/assets/docs/reference//350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1248 -1248
  678. package/lib/assets/docs/reference//350/250/200/350/252/236/345/210/245/351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +518 -518
  679. package/lib/assets/docs/reference//351/201/213/345/226/266/347/256/241/347/220/206.md +1482 -1482
  680. package/lib/assets/docs/reference//351/201/213/347/224/250/343/202/271/343/202/257/343/203/252/343/203/227/343/203/210/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +421 -421
  681. package/lib/assets/docs/reference//351/201/213/347/224/250/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +392 -392
  682. package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +299 -299
  683. package/lib/assets/docs/reference//351/235/236/346/251/237/350/203/275/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1236 -1236
  684. package/lib/assets/docs/review/index.md +5 -5
  685. package/lib/assets/docs/strategy/index.md +1 -1
  686. package/lib/assets/docs/template/ADR.md +30 -30
  687. package/lib/assets/docs/template/AWS/343/202/271/343/203/206/343/203/274/343/202/270/343/203/263/343/202/260/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +1366 -1366
  688. package/lib/assets/docs/template/AWS/343/203/227/343/203/255/343/203/200/343/202/257/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +634 -634
  689. package/lib/assets/docs/template/README.md +50 -50
  690. package/lib/assets/docs/template/index.md +23 -23
  691. package/lib/assets/docs/template//343/201/276/343/201/232/343/201/223/343/202/214/343/202/222/350/252/255/343/202/202/343/201/206/343/203/252/343/202/271/343/203/210.md +12 -12
  692. package/lib/assets/docs/template//343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +547 -547
  693. package/lib/assets/docs/template//343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/345/256/214/344/272/206/345/240/261/345/221/212/346/233/270.md +58 -58
  694. package/lib/assets/docs/template//343/202/244/343/203/263/343/202/273/343/203/227/343/202/267/343/203/247/343/203/263/343/203/207/343/203/203/343/202/255.md +13 -13
  695. package/lib/assets/docs/template//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243.md +379 -379
  696. package/lib/assets/docs/template//344/274/201/346/245/255/345/210/206/346/236/220.md +573 -573
  697. package/lib/assets/docs/template//345/256/214/345/205/250/345/275/242/345/274/217/343/201/256/343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271.md +69 -69
  698. package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +669 -669
  699. package/lib/assets/docs/template//350/250/255/350/250/210.md +173 -173
  700. package/lib/assets/docs/template//351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +688 -688
  701. package/lib/assets/gulpfile.js +25 -25
  702. package/lib/assets/mkdocs.yml +136 -136
  703. package/lib/assets/ops/docker/mkdoc/Dockerfile +19 -19
  704. package/lib/assets/ops/scripts/journal.js +180 -180
  705. package/lib/assets/ops/scripts/mkdocs.js +82 -82
  706. package/lib/assets/ops/scripts/release.js +431 -431
  707. package/lib/assets/ops/scripts/sonar_local.js +726 -726
  708. package/lib/assets/ops/scripts/ssh.js +190 -190
  709. package/lib/assets/ops/scripts/vault.js +299 -299
  710. package/lib/assets/package-lock.json +1653 -1653
  711. package/lib/assets/package.json +40 -40
  712. package/lib/gulpfile.js +37 -37
  713. package/package.json +41 -41
@@ -1,690 +1,690 @@
1
- # ユースケース作成ガイド
2
-
3
- ## はじめに
4
-
5
- このガイドは、XPプログラマ向けの実用的なユースケース作成手法を提供します。ユースケースはシステムの振る舞いに関する利害関係者との契約であり、アジャイル開発においても要求を明確化する重要なツールです。
6
-
7
- ## ユースケースの基本概念
8
-
9
- ### ユースケースとは
10
-
11
- ユースケースは、システムの振る舞いに関する利害関係者間の契約を表現するものです。
12
-
13
- ```plantuml
14
- @startuml
15
- title ユースケースの構成要素
16
-
17
- actor ユーザー as user
18
- actor 管理者 as admin
19
- actor 外部システム as external
20
-
21
- rectangle システム {
22
- usecase "商品を注文する" as UC1
23
- usecase "在庫を確認する" as UC2
24
- usecase "ユーザーを認証する" as UC3
25
- usecase "レポートを生成する" as UC4
26
- }
27
-
28
- user --> UC1
29
- user --> UC2
30
- admin --> UC4
31
- UC1 ..> UC3 : <<include>>
32
- UC1 ..> UC2 : <<include>>
33
- external --> UC2
34
- @enduml
35
- ```
36
-
37
- ### XPとユースケース
38
-
39
- XPのユーザーストーリーとユースケースの関係:
40
-
41
- - **ユーザーストーリー**:イテレーション単位の小さな要求
42
- - **ユースケース概要**:ユーザーストーリーをまとめた機能群
43
- - **完全形式ユースケース**:詳細な振る舞いの定義
44
-
45
- ## 1. ユースケースの3つのレベル
46
-
47
- ### レベルの階層構造
48
-
49
- ```plantuml
50
- @startmindmap
51
- * システム全体
52
- ++ ☁️要約レベル(数日〜数ヶ月)
53
- +++ 🌊ユーザー目的レベル(数分〜数時間)
54
- ++++ 🐟サブ機能レベル(数秒〜数分)
55
- -- ビジネスプロセス全体
56
- --- 複数のユーザー目的を含む
57
- --- ライフサイクル全体を表現
58
- -- 個別の目的達成
59
- --- ユーザーが満足して立ち去れる単位
60
- --- 基本ビジネスプロセス
61
- -- 目的達成のための部品
62
- --- 共通機能の切り出し
63
- --- 再利用可能な処理
64
- @endmindmap
65
- ```
66
-
67
- ### レベル判定の質問
68
-
69
- **ユーザー目的レベルの判定**
70
-
71
- - 主アクターはこれを実行した後で満足して立ち去れるか?
72
- - これは1回の作業セッションで完了するか?
73
-
74
- **要約レベルの判定**
75
-
76
- - 複数のユーザー目的が含まれているか?
77
- - 時間をかけて実行される長いプロセスか?
78
-
79
- **サブ機能レベルの判定**
80
-
81
- - これだけでは目的が達成されないか?
82
- - 他のユースケースから呼び出される共通処理か?
83
-
84
- ## 2. スコープの定義
85
-
86
- ### 設計スコープの種類
87
-
88
- ```plantuml
89
- @startuml
90
- title 設計スコープの境界
91
-
92
- package "🏢組織(企業全体)" {
93
- package "💻システム(ソフトウェア)" {
94
- package "💾コンポーネント" {
95
- [モジュールA]
96
- [モジュールB]
97
- }
98
- }
99
- actor 社員
100
- actor 外部システム
101
- }
102
-
103
- actor 顧客
104
-
105
- 顧客 --> 社員 : 依頼
106
- 社員 --> [モジュールA] : 操作
107
- [モジュールA] --> [モジュールB] : 連携
108
- [モジュールB] --> 外部システム : API呼び出し
109
- @enduml
110
- ```
111
-
112
- ### In/Outリストの作成
113
-
114
- スコープを明確にするために、何が範囲内で何が範囲外かを整理:
115
-
116
- | トピック | In | Out | 備考 |
117
- |---------|----|----|------|
118
- | ユーザー認証 | ✓ | | システムで実装 |
119
- | 決済処理 | | ✓ | 外部サービス利用 |
120
- | 在庫管理 | ✓ | | コア機能 |
121
- | 配送手配 | | ✓ | 物流会社API |
122
- | レポート生成 | ✓ | | 管理機能 |
123
-
124
- ## 3. アクターの識別
125
-
126
- ### アクター分析チェックリスト
127
-
128
- ```plantuml
129
- @startuml
130
- title アクターの種類と関係
131
-
132
- actor "主アクター" as primary #lightblue
133
- actor "支援アクター" as support #lightgreen
134
- actor "オフステージアクター" as offstage #lightyellow
135
-
136
- rectangle "システム" as system
137
-
138
- primary --> system : 目的を持って\n操作する
139
- system --> support : サービスを\n要求する
140
- offstage ..> system : 利益を持つが\n直接操作しない
141
-
142
- note right of primary : システムを使って\n目的を達成する人
143
- note right of support : システムが依存する\n外部サービス
144
- note right of offstage : 規制当局、\n管理者など
145
- @enduml
146
- ```
147
-
148
- ### アクター・目的リスト
149
-
150
- 優先度付きでアクターの目的を整理:
151
-
152
- | アクター | 目的 | レベル | 優先度 | 頻度 |
153
- |---------|------|--------|--------|------|
154
- | 購入者 | 商品を検索する | 🌊 | 高 | 100回/日 |
155
- | 購入者 | 注文する | 🌊 | 高 | 50回/日 |
156
- | 購入者 | 注文履歴を確認する | 🌊 | 中 | 20回/日 |
157
- | 管理者 | 在庫を更新する | 🌊 | 高 | 30回/日 |
158
- | 管理者 | レポートを生成する | ☁️ | 中 | 5回/日 |
159
- | システム | 在庫を自動補充する | 🌊 | 高 | 10回/日 |
160
-
161
- ## 4. ユースケース記述プロセス
162
-
163
- ### 段階的詳細化アプローチ
164
-
165
- ```plantuml
166
- @startuml
167
- title ユースケース作成の段階的詳細化
168
-
169
- [*] --> 精度レベル1
170
- 精度レベル1 --> 精度レベル2
171
- 精度レベル2 --> 精度レベル3
172
- 精度レベル3 --> 精度レベル4
173
- 精度レベル4 --> [*]
174
-
175
- 精度レベル1 : アクター名と目的
176
- 精度レベル1 : ・アクター・目的リスト
177
- 精度レベル1 : ・1行記述
178
-
179
- 精度レベル2 : ユースケース概要
180
- 精度レベル2 : ・主成功シナリオ
181
- 精度レベル2 : ・段落形式の記述
182
-
183
- 精度レベル3 : 拡張条件の追加
184
- 精度レベル3 : ・例外処理の識別
185
- 精度レベル3 : ・代替パスの定義
186
-
187
- 精度レベル4 : 完全形式
188
- 精度レベル4 : ・拡張処理ステップ
189
- 精度レベル4 : ・事前/事後条件
190
- 精度レベル4 : ・保証の定義
191
- @enduml
192
- ```
193
-
194
- ### 12ステップの作成プロセス
195
-
196
- 1. **システムのスコープと境界を識別**
197
- 2. **主アクターの一覧作成**
198
- 3. **ユーザー目的の洗い出し**
199
- 4. **要約レベルユースケースの作成**
200
- 5. **要約レベルの見直しと統合**
201
- 6. **詳細化するユースケースの選択**
202
- 7. **利害関係者と保証の定義**
203
- 8. **主成功シナリオの記述**
204
- 9. **例外条件の洗い出し**
205
- 10. **拡張処理ステップの記述**
206
- 11. **複雑なフローの分割と統合**
207
- 12. **全体の整理と見直し**
208
-
209
- ## 5. ユースケーステンプレート
210
-
211
- ### 完全形式テンプレート
212
-
213
- ```markdown
214
- # UC-[番号]: [スコープアイコン][ユースケース名][レベルアイコン]
215
-
216
- **コンテキスト**: [一般的に起きる条件や状況の説明]
217
-
218
- **スコープ**: [設計対象システム]
219
-
220
- **レベル**: [要約/ユーザー目的/サブ機能]
221
-
222
- **主アクター**: [目的を持つアクター]
223
-
224
- **利害関係者と利益**:
225
-
226
- - [利害関係者1]: [その利益]
227
- - [利害関係者2]: [その利益]
228
-
229
- **事前条件**:
230
-
231
- - [すでに真であると想定している状態]
232
-
233
- **トリガー**: [ユースケースを開始するイベント]
234
-
235
- **最低保証**: [失敗時でも守られる利益]
236
-
237
- **成功時保証**: [成功時に達成される状態]
238
-
239
- **主成功シナリオ**:
240
-
241
- 1. [アクター]が[アクション]する
242
- 2. システムが[処理]する
243
- 3. ...
244
-
245
- **拡張**:
246
-
247
- - 1a. [条件]:
248
- - 1a1. [代替処理]
249
- - 2-4a. [いつでも発生する条件]:
250
- - 2-4a1. [処理]
251
-
252
- **技術およびデータのバリエーション**:
253
-
254
- - ステップ1: [バリエーション]
255
- ```
256
-
257
- ### 略式テンプレート(XP向け)
258
-
259
- ```markdown
260
- # [ユースケース名]
261
-
262
- **主アクター**: [アクター名]
263
- **スコープ**: [システム名]
264
- **レベル**: [レベル]
265
-
266
- [主成功シナリオを段落形式で記述。システムの振る舞いと
267
- アクターの相互作用を自然な文章で表現]
268
-
269
- [代替パスや例外処理を段落形式で記述]
270
-
271
- **頻度**: [実行頻度]
272
- ```
273
-
274
- ### ユースケース概要(ユーザーストーリー形式)
275
-
276
- ```markdown
277
- # [機能名]
278
-
279
- **として**: [アクター]
280
- **したい**: [目的/機能]
281
- **なぜなら**: [ビジネス価値]
282
-
283
- **受入条件**:
284
-
285
- - [ ] [条件1]
286
- - [ ] [条件2]
287
- ```
288
-
289
- ## 6. シナリオの書き方
290
-
291
- ### 良いステップの書き方
292
-
293
- ```plantuml
294
- @startuml
295
- title ステップ記述のレベル
296
-
297
- participant アクター as A
298
- participant システム as S
299
- participant 外部システム as E
300
-
301
- == 🌊ユーザー目的レベル ==
302
- A -> S: 1. 商品を注文する
303
- activate S
304
- S -> S: 2. 在庫を確認する
305
- S -> A: 3. 注文を確認する
306
- deactivate S
307
-
308
- == 🐟サブ機能レベル(詳細) ==
309
- A -> S: 1. ユーザー名とパスワードを入力する
310
- activate S
311
- S -> S: 2. 認証情報を検証する
312
- S -> E: 3. 認証サーバーに問い合わせる
313
- E -> S: 4. 認証結果を返す
314
- S -> A: 5. ログイン結果を表示する
315
- deactivate S
316
- @enduml
317
- ```
318
-
319
- ### ステップ記述のガイドライン
320
-
321
- **やるべきこと**
322
-
323
- - ✅ アクターの意図を表現する
324
- - ✅ 「誰が何をする」を明確にする
325
- - ✅ 成功する目的として記述する
326
- - ✅ 情報の流れを明確にする
327
-
328
- **避けるべきこと**
329
-
330
- - ❌ UIの詳細を記述する
331
- - ❌ 「チェックする」ではなく「確認する」
332
- - ❌ 実装の詳細に踏み込む
333
- - ❌ IF文を使う(拡張に記載)
334
-
335
- ### ステップ数の目安
336
-
337
- ```plantuml
338
- @startuml
339
- title 適切なステップ数
340
-
341
- rectangle "理想的" #lightgreen {
342
- (3〜9ステップ)
343
- }
344
-
345
- rectangle "許容範囲" #yellow {
346
- (2〜10ステップ)
347
- }
348
-
349
- rectangle "要分割" #lightcoral {
350
- (11ステップ以上)
351
- }
352
-
353
- note bottom of "理想的" : 読みやすく\n理解しやすい
354
- note bottom of "許容範囲" : 状況により\n許容
355
- note bottom of "要分割" : サブユースケース\nに分割を検討
356
- @enduml
357
- ```
358
-
359
- ## 7. 拡張の記述
360
-
361
- ### 拡張条件の識別
362
-
363
- ```plantuml
364
- @startuml
365
- title 拡張の分岐パターン
366
-
367
- start
368
- :主成功シナリオ;
369
- if (条件A?) then (yes)
370
- :拡張処理A;
371
- :主シナリオに戻る;
372
- else (no)
373
- if (条件B?) then (yes)
374
- :拡張処理B;
375
- stop
376
- else (no)
377
- :通常処理継続;
378
- endif
379
- endif
380
- :次のステップ;
381
- stop
382
- @enduml
383
- ```
384
-
385
- ### 拡張の記述形式
386
-
387
- ```markdown
388
- **主成功シナリオ**:
389
-
390
- 1. ユーザーが商品を選択する
391
- 2. システムが在庫を確認する
392
- 3. ユーザーが数量を指定する
393
- 4. システムが合計金額を計算する
394
- 5. ユーザーが注文を確定する
395
-
396
- **拡張**:
397
-
398
- - 2a. 在庫がない:
399
- - 2a1. システムが在庫なしを通知する
400
- - 2a2. ユーザーが別の商品を選択する(ステップ1へ)
401
-
402
- - 3a. 数量が在庫を超える:
403
- - 3a1. システムが利用可能数量を表示する
404
- - 3a2. ユーザーが数量を調整する
405
-
406
- - *a. ユーザーがキャンセル:
407
- - *a1. システムがトランザクションを破棄する
408
- - *a2. 終了
409
- ```
410
-
411
- ## 8. データ記述の精度
412
-
413
- ### 3段階のデータ精度
414
-
415
- ```plantuml
416
- @startuml
417
- title データ記述の精度レベル
418
-
419
- class 精度レベル1 {
420
- ニックネーム
421
- --
422
- "顧客情報"
423
- "注文データ"
424
- "商品リスト"
425
- }
426
-
427
- class 精度レベル2 {
428
- フィールド群
429
- --
430
- 顧客情報:
431
- - 氏名
432
- - 住所
433
- - 電話番号
434
- }
435
-
436
- class 精度レベル3 {
437
- 詳細仕様
438
- --
439
- 氏名: String(100)
440
- 住所: String(200)
441
- 電話番号: String(20)
442
- + NotNull制約
443
- + 形式チェック
444
- }
445
-
446
- 精度レベル1 --> 精度レベル2 : 詳細化
447
- 精度レベル2 --> 精度レベル3 : 詳細化
448
-
449
- note bottom of 精度レベル1 : ユースケースで使用
450
- note bottom of 精度レベル3 : 設計書で定義
451
- @enduml
452
- ```
453
-
454
- ## 9. 品質チェックリスト
455
-
456
- ### ユースケース全体のチェック項目
457
-
458
- | カテゴリ | チェック項目 | ✓ |
459
- |---------|------------|---|
460
- | **タイトル** | 動詞句で目的を表現しているか | □ |
461
- | | システムが達成可能な目的か | □ |
462
- | **スコープ** | 明確に定義されているか | □ |
463
- | | ブラックボックスとして扱っているか | □ |
464
- | **レベル** | 適切なレベルが選択されているか | □ |
465
- | | 内容がレベルと一致しているか | □ |
466
- | **主アクター** | 振る舞いを持っているか | □ |
467
- | | システムへの明確な目的があるか | □ |
468
- | **事前条件** | 必須かつ検証可能か | □ |
469
- | | ユースケース内で再チェックしていないか | □ |
470
- | **保証** | 利害関係者の利益が守られているか | □ |
471
- | | 成功時に目的が達成されるか | □ |
472
- | **シナリオ** | 3〜9ステップに収まっているか | □ |
473
- | | トリガーから保証まで進んでいるか | □ |
474
-
475
- ### ステップ記述のチェック項目
476
-
477
- - □ 成功する目的として表現されているか
478
- - □ アクターが明確か
479
- - □ 意図が明確か
480
- - □ UI設計を含んでいないか
481
- - □ 情報の流れが明確か
482
- - □ 「確認する」を使っているか(「チェックする」ではなく)
483
-
484
- ## 10. XPプロジェクトでの活用
485
-
486
- ### ユーザーストーリーとの連携
487
-
488
- ```plantuml
489
- @startuml
490
- title ユースケースからユーザーストーリーへの分解
491
-
492
- package "ユースケース" {
493
- rectangle "🌊商品を注文する" as UC
494
- }
495
-
496
- package "ユーザーストーリー" {
497
- rectangle "商品を検索する" as US1
498
- rectangle "カートに追加する" as US2
499
- rectangle "配送先を入力する" as US3
500
- rectangle "支払い方法を選択する" as US4
501
- rectangle "注文を確定する" as US5
502
- }
503
-
504
- UC --> US1
505
- UC --> US2
506
- UC --> US3
507
- UC --> US4
508
- UC --> US5
509
-
510
- note right of UC : 1つのユースケース
511
- note right of US3 : イテレーション単位の\nストーリーに分解
512
- @enduml
513
- ```
514
-
515
- ### イテレーション計画での利用
516
-
517
- 1. **リリース計画時**
518
-
519
- - 要約レベルのユースケースで全体像を把握
520
- - 大まかな規模見積もり
521
-
522
- 2. **イテレーション計画時**
523
-
524
- - ユーザー目的レベルをストーリーに分解
525
- - 詳細な見積もりと優先順位付け
526
-
527
- 3. **実装時**
528
-
529
- - ユースケースを設計ガイドとして利用
530
- - 受入テストケースの基準
531
-
532
- ### ユースケースから機能リストへ
533
-
534
- ```markdown
535
- ## UC-001: 商品を注文する
536
-
537
- ### 抽出された機能リスト
538
-
539
- | ID | 機能 | 優先度 | ストーリーポイント |
540
- |----|------|--------|------------------|
541
- | F1.1 | 商品検索機能 | 必須 | 3 |
542
- | F1.2 | カート追加機能 | 必須 | 2 |
543
- | F1.3 | 在庫確認機能 | 必須 | 3 |
544
- | F1.4 | 配送先入力機能 | 必須 | 2 |
545
- | F1.5 | 支払い処理機能 | 必須 | 5 |
546
- | F1.6 | 注文確認メール送信 | 重要 | 2 |
547
- | F1.7 | 注文履歴保存 | 重要 | 1 |
548
- ```
549
-
550
- ## 11. テストケースへの変換
551
-
552
- ### ユースケースベースのテスト設計
553
-
554
- ```plantuml
555
- @startuml
556
- title ユースケースからテストケースへ
557
-
558
- rectangle "ユースケース" as UC {
559
- rectangle "主成功シナリオ" as MSS
560
- rectangle "拡張1" as EX1
561
- rectangle "拡張2" as EX2
562
- rectangle "拡張3" as EX3
563
- }
564
-
565
- rectangle "テストケース" as TC {
566
- rectangle "正常系テスト" as NT
567
- rectangle "異常系テスト1" as AT1
568
- rectangle "異常系テスト2" as AT2
569
- rectangle "異常系テスト3" as AT3
570
- rectangle "境界値テスト" as BT
571
- }
572
-
573
- MSS --> NT
574
- EX1 --> AT1
575
- EX2 --> AT2
576
- EX3 --> AT3
577
- UC --> BT
578
-
579
- note bottom of TC : 各パスを網羅する\nテストケースを生成
580
- @enduml
581
- ```
582
-
583
- ### テストケーステンプレート
584
-
585
- ```markdown
586
- ## テストケース: [ユースケース名]_[パス]
587
-
588
- **基になるユースケース**: UC-XXX
589
- **テストパス**: 主成功シナリオ/拡張XX
590
-
591
- **事前条件**:
592
-
593
- - [システムの初期状態]
594
- - [必要なテストデータ]
595
-
596
- **入力**:
597
- 1. [入力データ1]
598
- 2. [入力データ2]
599
-
600
- **期待結果**:
601
-
602
- - [期待される出力]
603
- - [期待される状態変化]
604
- - [期待される副作用]
605
-
606
- **事後条件**:
607
-
608
- - [システムの最終状態]
609
- ```
610
-
611
- ## 12. よくある問題と対策
612
-
613
- ### 問題パターンと解決策
614
-
615
- | 問題 | 症状 | 解決策 |
616
- |------|------|--------|
617
- | スコープ不明確 | 要求が増え続ける | In/Outリスト作成 |
618
- | レベル混在 | ステップが不均一 | レベルアイコン使用 |
619
- | UI記述 | 実装に依存 | 意図の記述に変更 |
620
- | 長すぎる | 10ステップ以上 | サブユースケース分割 |
621
- | 曖昧な記述 | 解釈が複数 | 具体例の追加 |
622
- | 保証なし | 目的が不明 | 利害関係者分析 |
623
-
624
- ### アンチパターン
625
-
626
- ```plantuml
627
- @startuml
628
- title ユースケースのアンチパターン
629
-
630
- rectangle "❌ 悪い例" as bad {
631
- usecase "データを処理する" as UC1
632
- usecase "画面を表示する" as UC2
633
- usecase "ボタンをクリックする" as UC3
634
- }
635
-
636
- rectangle "✅ 良い例" as good {
637
- usecase "注文を確定する" as UC4
638
- usecase "在庫を確認する" as UC5
639
- usecase "支払いを処理する" as UC6
640
- }
641
-
642
- note bottom of bad : 技術的すぎる\nUI依存\n目的が不明
643
- note bottom of good : ビジネス目的\n実装独立\n価値が明確
644
- @enduml
645
- ```
646
-
647
- ## まとめ
648
-
649
- ### ユースケース作成の原則
650
-
651
- 1. **読みやすさ優先**
652
-
653
- - 完璧さより理解しやすさ
654
- - 自然な言葉で記述
655
-
656
- 2. **段階的詳細化**
657
-
658
- - 広く浅くから始める
659
- - 必要に応じて深堀り
660
-
661
- 3. **適切なレベル選択**
662
-
663
- - ユーザー目的を中心に
664
- - サブ機能は最小限に
665
-
666
- 4. **XPとの統合**
667
-
668
- - ユーザーストーリーと連携
669
- - イテレーション計画で活用
670
- - テストケースの基準
671
-
672
- ### クイックリファレンス
673
-
674
- **アイコン凡例**
675
-
676
- - 🏢 組織スコープ
677
- - 💻 システムスコープ
678
- - 💾 コンポーネントスコープ
679
- - ☁️ 要約レベル
680
- - 🌊 ユーザー目的レベル
681
- - 🐟 サブ機能レベル
682
-
683
- **記述の黄金律**
684
-
685
- - 3〜9ステップ
686
- - アクターの意図を記述
687
- - UI詳細は書かない
688
- - 成功する目的として表現
689
-
1
+ # ユースケース作成ガイド
2
+
3
+ ## はじめに
4
+
5
+ このガイドは、XPプログラマ向けの実用的なユースケース作成手法を提供します。ユースケースはシステムの振る舞いに関する利害関係者との契約であり、アジャイル開発においても要求を明確化する重要なツールです。
6
+
7
+ ## ユースケースの基本概念
8
+
9
+ ### ユースケースとは
10
+
11
+ ユースケースは、システムの振る舞いに関する利害関係者間の契約を表現するものです。
12
+
13
+ ```plantuml
14
+ @startuml
15
+ title ユースケースの構成要素
16
+
17
+ actor ユーザー as user
18
+ actor 管理者 as admin
19
+ actor 外部システム as external
20
+
21
+ rectangle システム {
22
+ usecase "商品を注文する" as UC1
23
+ usecase "在庫を確認する" as UC2
24
+ usecase "ユーザーを認証する" as UC3
25
+ usecase "レポートを生成する" as UC4
26
+ }
27
+
28
+ user --> UC1
29
+ user --> UC2
30
+ admin --> UC4
31
+ UC1 ..> UC3 : <<include>>
32
+ UC1 ..> UC2 : <<include>>
33
+ external --> UC2
34
+ @enduml
35
+ ```
36
+
37
+ ### XPとユースケース
38
+
39
+ XPのユーザーストーリーとユースケースの関係:
40
+
41
+ - **ユーザーストーリー**:イテレーション単位の小さな要求
42
+ - **ユースケース概要**:ユーザーストーリーをまとめた機能群
43
+ - **完全形式ユースケース**:詳細な振る舞いの定義
44
+
45
+ ## 1. ユースケースの3つのレベル
46
+
47
+ ### レベルの階層構造
48
+
49
+ ```plantuml
50
+ @startmindmap
51
+ * システム全体
52
+ ++ ☁️要約レベル(数日〜数ヶ月)
53
+ +++ 🌊ユーザー目的レベル(数分〜数時間)
54
+ ++++ 🐟サブ機能レベル(数秒〜数分)
55
+ -- ビジネスプロセス全体
56
+ --- 複数のユーザー目的を含む
57
+ --- ライフサイクル全体を表現
58
+ -- 個別の目的達成
59
+ --- ユーザーが満足して立ち去れる単位
60
+ --- 基本ビジネスプロセス
61
+ -- 目的達成のための部品
62
+ --- 共通機能の切り出し
63
+ --- 再利用可能な処理
64
+ @endmindmap
65
+ ```
66
+
67
+ ### レベル判定の質問
68
+
69
+ **ユーザー目的レベルの判定**
70
+
71
+ - 主アクターはこれを実行した後で満足して立ち去れるか?
72
+ - これは1回の作業セッションで完了するか?
73
+
74
+ **要約レベルの判定**
75
+
76
+ - 複数のユーザー目的が含まれているか?
77
+ - 時間をかけて実行される長いプロセスか?
78
+
79
+ **サブ機能レベルの判定**
80
+
81
+ - これだけでは目的が達成されないか?
82
+ - 他のユースケースから呼び出される共通処理か?
83
+
84
+ ## 2. スコープの定義
85
+
86
+ ### 設計スコープの種類
87
+
88
+ ```plantuml
89
+ @startuml
90
+ title 設計スコープの境界
91
+
92
+ package "🏢組織(企業全体)" {
93
+ package "💻システム(ソフトウェア)" {
94
+ package "💾コンポーネント" {
95
+ [モジュールA]
96
+ [モジュールB]
97
+ }
98
+ }
99
+ actor 社員
100
+ actor 外部システム
101
+ }
102
+
103
+ actor 顧客
104
+
105
+ 顧客 --> 社員 : 依頼
106
+ 社員 --> [モジュールA] : 操作
107
+ [モジュールA] --> [モジュールB] : 連携
108
+ [モジュールB] --> 外部システム : API呼び出し
109
+ @enduml
110
+ ```
111
+
112
+ ### In/Outリストの作成
113
+
114
+ スコープを明確にするために、何が範囲内で何が範囲外かを整理:
115
+
116
+ | トピック | In | Out | 備考 |
117
+ |---------|----|----|------|
118
+ | ユーザー認証 | ✓ | | システムで実装 |
119
+ | 決済処理 | | ✓ | 外部サービス利用 |
120
+ | 在庫管理 | ✓ | | コア機能 |
121
+ | 配送手配 | | ✓ | 物流会社API |
122
+ | レポート生成 | ✓ | | 管理機能 |
123
+
124
+ ## 3. アクターの識別
125
+
126
+ ### アクター分析チェックリスト
127
+
128
+ ```plantuml
129
+ @startuml
130
+ title アクターの種類と関係
131
+
132
+ actor "主アクター" as primary #lightblue
133
+ actor "支援アクター" as support #lightgreen
134
+ actor "オフステージアクター" as offstage #lightyellow
135
+
136
+ rectangle "システム" as system
137
+
138
+ primary --> system : 目的を持って\n操作する
139
+ system --> support : サービスを\n要求する
140
+ offstage ..> system : 利益を持つが\n直接操作しない
141
+
142
+ note right of primary : システムを使って\n目的を達成する人
143
+ note right of support : システムが依存する\n外部サービス
144
+ note right of offstage : 規制当局、\n管理者など
145
+ @enduml
146
+ ```
147
+
148
+ ### アクター・目的リスト
149
+
150
+ 優先度付きでアクターの目的を整理:
151
+
152
+ | アクター | 目的 | レベル | 優先度 | 頻度 |
153
+ |---------|------|--------|--------|------|
154
+ | 購入者 | 商品を検索する | 🌊 | 高 | 100回/日 |
155
+ | 購入者 | 注文する | 🌊 | 高 | 50回/日 |
156
+ | 購入者 | 注文履歴を確認する | 🌊 | 中 | 20回/日 |
157
+ | 管理者 | 在庫を更新する | 🌊 | 高 | 30回/日 |
158
+ | 管理者 | レポートを生成する | ☁️ | 中 | 5回/日 |
159
+ | システム | 在庫を自動補充する | 🌊 | 高 | 10回/日 |
160
+
161
+ ## 4. ユースケース記述プロセス
162
+
163
+ ### 段階的詳細化アプローチ
164
+
165
+ ```plantuml
166
+ @startuml
167
+ title ユースケース作成の段階的詳細化
168
+
169
+ [*] --> 精度レベル1
170
+ 精度レベル1 --> 精度レベル2
171
+ 精度レベル2 --> 精度レベル3
172
+ 精度レベル3 --> 精度レベル4
173
+ 精度レベル4 --> [*]
174
+
175
+ 精度レベル1 : アクター名と目的
176
+ 精度レベル1 : ・アクター・目的リスト
177
+ 精度レベル1 : ・1行記述
178
+
179
+ 精度レベル2 : ユースケース概要
180
+ 精度レベル2 : ・主成功シナリオ
181
+ 精度レベル2 : ・段落形式の記述
182
+
183
+ 精度レベル3 : 拡張条件の追加
184
+ 精度レベル3 : ・例外処理の識別
185
+ 精度レベル3 : ・代替パスの定義
186
+
187
+ 精度レベル4 : 完全形式
188
+ 精度レベル4 : ・拡張処理ステップ
189
+ 精度レベル4 : ・事前/事後条件
190
+ 精度レベル4 : ・保証の定義
191
+ @enduml
192
+ ```
193
+
194
+ ### 12ステップの作成プロセス
195
+
196
+ 1. **システムのスコープと境界を識別**
197
+ 2. **主アクターの一覧作成**
198
+ 3. **ユーザー目的の洗い出し**
199
+ 4. **要約レベルユースケースの作成**
200
+ 5. **要約レベルの見直しと統合**
201
+ 6. **詳細化するユースケースの選択**
202
+ 7. **利害関係者と保証の定義**
203
+ 8. **主成功シナリオの記述**
204
+ 9. **例外条件の洗い出し**
205
+ 10. **拡張処理ステップの記述**
206
+ 11. **複雑なフローの分割と統合**
207
+ 12. **全体の整理と見直し**
208
+
209
+ ## 5. ユースケーステンプレート
210
+
211
+ ### 完全形式テンプレート
212
+
213
+ ```markdown
214
+ # UC-[番号]: [スコープアイコン][ユースケース名][レベルアイコン]
215
+
216
+ **コンテキスト**: [一般的に起きる条件や状況の説明]
217
+
218
+ **スコープ**: [設計対象システム]
219
+
220
+ **レベル**: [要約/ユーザー目的/サブ機能]
221
+
222
+ **主アクター**: [目的を持つアクター]
223
+
224
+ **利害関係者と利益**:
225
+
226
+ - [利害関係者1]: [その利益]
227
+ - [利害関係者2]: [その利益]
228
+
229
+ **事前条件**:
230
+
231
+ - [すでに真であると想定している状態]
232
+
233
+ **トリガー**: [ユースケースを開始するイベント]
234
+
235
+ **最低保証**: [失敗時でも守られる利益]
236
+
237
+ **成功時保証**: [成功時に達成される状態]
238
+
239
+ **主成功シナリオ**:
240
+
241
+ 1. [アクター]が[アクション]する
242
+ 2. システムが[処理]する
243
+ 3. ...
244
+
245
+ **拡張**:
246
+
247
+ - 1a. [条件]:
248
+ - 1a1. [代替処理]
249
+ - 2-4a. [いつでも発生する条件]:
250
+ - 2-4a1. [処理]
251
+
252
+ **技術およびデータのバリエーション**:
253
+
254
+ - ステップ1: [バリエーション]
255
+ ```
256
+
257
+ ### 略式テンプレート(XP向け)
258
+
259
+ ```markdown
260
+ # [ユースケース名]
261
+
262
+ **主アクター**: [アクター名]
263
+ **スコープ**: [システム名]
264
+ **レベル**: [レベル]
265
+
266
+ [主成功シナリオを段落形式で記述。システムの振る舞いと
267
+ アクターの相互作用を自然な文章で表現]
268
+
269
+ [代替パスや例外処理を段落形式で記述]
270
+
271
+ **頻度**: [実行頻度]
272
+ ```
273
+
274
+ ### ユースケース概要(ユーザーストーリー形式)
275
+
276
+ ```markdown
277
+ # [機能名]
278
+
279
+ **として**: [アクター]
280
+ **したい**: [目的/機能]
281
+ **なぜなら**: [ビジネス価値]
282
+
283
+ **受入条件**:
284
+
285
+ - [ ] [条件1]
286
+ - [ ] [条件2]
287
+ ```
288
+
289
+ ## 6. シナリオの書き方
290
+
291
+ ### 良いステップの書き方
292
+
293
+ ```plantuml
294
+ @startuml
295
+ title ステップ記述のレベル
296
+
297
+ participant アクター as A
298
+ participant システム as S
299
+ participant 外部システム as E
300
+
301
+ == 🌊ユーザー目的レベル ==
302
+ A -> S: 1. 商品を注文する
303
+ activate S
304
+ S -> S: 2. 在庫を確認する
305
+ S -> A: 3. 注文を確認する
306
+ deactivate S
307
+
308
+ == 🐟サブ機能レベル(詳細) ==
309
+ A -> S: 1. ユーザー名とパスワードを入力する
310
+ activate S
311
+ S -> S: 2. 認証情報を検証する
312
+ S -> E: 3. 認証サーバーに問い合わせる
313
+ E -> S: 4. 認証結果を返す
314
+ S -> A: 5. ログイン結果を表示する
315
+ deactivate S
316
+ @enduml
317
+ ```
318
+
319
+ ### ステップ記述のガイドライン
320
+
321
+ **やるべきこと**
322
+
323
+ - ✅ アクターの意図を表現する
324
+ - ✅ 「誰が何をする」を明確にする
325
+ - ✅ 成功する目的として記述する
326
+ - ✅ 情報の流れを明確にする
327
+
328
+ **避けるべきこと**
329
+
330
+ - ❌ UIの詳細を記述する
331
+ - ❌ 「チェックする」ではなく「確認する」
332
+ - ❌ 実装の詳細に踏み込む
333
+ - ❌ IF文を使う(拡張に記載)
334
+
335
+ ### ステップ数の目安
336
+
337
+ ```plantuml
338
+ @startuml
339
+ title 適切なステップ数
340
+
341
+ rectangle "理想的" #lightgreen {
342
+ (3〜9ステップ)
343
+ }
344
+
345
+ rectangle "許容範囲" #yellow {
346
+ (2〜10ステップ)
347
+ }
348
+
349
+ rectangle "要分割" #lightcoral {
350
+ (11ステップ以上)
351
+ }
352
+
353
+ note bottom of "理想的" : 読みやすく\n理解しやすい
354
+ note bottom of "許容範囲" : 状況により\n許容
355
+ note bottom of "要分割" : サブユースケース\nに分割を検討
356
+ @enduml
357
+ ```
358
+
359
+ ## 7. 拡張の記述
360
+
361
+ ### 拡張条件の識別
362
+
363
+ ```plantuml
364
+ @startuml
365
+ title 拡張の分岐パターン
366
+
367
+ start
368
+ :主成功シナリオ;
369
+ if (条件A?) then (yes)
370
+ :拡張処理A;
371
+ :主シナリオに戻る;
372
+ else (no)
373
+ if (条件B?) then (yes)
374
+ :拡張処理B;
375
+ stop
376
+ else (no)
377
+ :通常処理継続;
378
+ endif
379
+ endif
380
+ :次のステップ;
381
+ stop
382
+ @enduml
383
+ ```
384
+
385
+ ### 拡張の記述形式
386
+
387
+ ```markdown
388
+ **主成功シナリオ**:
389
+
390
+ 1. ユーザーが商品を選択する
391
+ 2. システムが在庫を確認する
392
+ 3. ユーザーが数量を指定する
393
+ 4. システムが合計金額を計算する
394
+ 5. ユーザーが注文を確定する
395
+
396
+ **拡張**:
397
+
398
+ - 2a. 在庫がない:
399
+ - 2a1. システムが在庫なしを通知する
400
+ - 2a2. ユーザーが別の商品を選択する(ステップ1へ)
401
+
402
+ - 3a. 数量が在庫を超える:
403
+ - 3a1. システムが利用可能数量を表示する
404
+ - 3a2. ユーザーが数量を調整する
405
+
406
+ - *a. ユーザーがキャンセル:
407
+ - *a1. システムがトランザクションを破棄する
408
+ - *a2. 終了
409
+ ```
410
+
411
+ ## 8. データ記述の精度
412
+
413
+ ### 3段階のデータ精度
414
+
415
+ ```plantuml
416
+ @startuml
417
+ title データ記述の精度レベル
418
+
419
+ class 精度レベル1 {
420
+ ニックネーム
421
+ --
422
+ "顧客情報"
423
+ "注文データ"
424
+ "商品リスト"
425
+ }
426
+
427
+ class 精度レベル2 {
428
+ フィールド群
429
+ --
430
+ 顧客情報:
431
+ - 氏名
432
+ - 住所
433
+ - 電話番号
434
+ }
435
+
436
+ class 精度レベル3 {
437
+ 詳細仕様
438
+ --
439
+ 氏名: String(100)
440
+ 住所: String(200)
441
+ 電話番号: String(20)
442
+ + NotNull制約
443
+ + 形式チェック
444
+ }
445
+
446
+ 精度レベル1 --> 精度レベル2 : 詳細化
447
+ 精度レベル2 --> 精度レベル3 : 詳細化
448
+
449
+ note bottom of 精度レベル1 : ユースケースで使用
450
+ note bottom of 精度レベル3 : 設計書で定義
451
+ @enduml
452
+ ```
453
+
454
+ ## 9. 品質チェックリスト
455
+
456
+ ### ユースケース全体のチェック項目
457
+
458
+ | カテゴリ | チェック項目 | ✓ |
459
+ |---------|------------|---|
460
+ | **タイトル** | 動詞句で目的を表現しているか | □ |
461
+ | | システムが達成可能な目的か | □ |
462
+ | **スコープ** | 明確に定義されているか | □ |
463
+ | | ブラックボックスとして扱っているか | □ |
464
+ | **レベル** | 適切なレベルが選択されているか | □ |
465
+ | | 内容がレベルと一致しているか | □ |
466
+ | **主アクター** | 振る舞いを持っているか | □ |
467
+ | | システムへの明確な目的があるか | □ |
468
+ | **事前条件** | 必須かつ検証可能か | □ |
469
+ | | ユースケース内で再チェックしていないか | □ |
470
+ | **保証** | 利害関係者の利益が守られているか | □ |
471
+ | | 成功時に目的が達成されるか | □ |
472
+ | **シナリオ** | 3〜9ステップに収まっているか | □ |
473
+ | | トリガーから保証まで進んでいるか | □ |
474
+
475
+ ### ステップ記述のチェック項目
476
+
477
+ - □ 成功する目的として表現されているか
478
+ - □ アクターが明確か
479
+ - □ 意図が明確か
480
+ - □ UI設計を含んでいないか
481
+ - □ 情報の流れが明確か
482
+ - □ 「確認する」を使っているか(「チェックする」ではなく)
483
+
484
+ ## 10. XPプロジェクトでの活用
485
+
486
+ ### ユーザーストーリーとの連携
487
+
488
+ ```plantuml
489
+ @startuml
490
+ title ユースケースからユーザーストーリーへの分解
491
+
492
+ package "ユースケース" {
493
+ rectangle "🌊商品を注文する" as UC
494
+ }
495
+
496
+ package "ユーザーストーリー" {
497
+ rectangle "商品を検索する" as US1
498
+ rectangle "カートに追加する" as US2
499
+ rectangle "配送先を入力する" as US3
500
+ rectangle "支払い方法を選択する" as US4
501
+ rectangle "注文を確定する" as US5
502
+ }
503
+
504
+ UC --> US1
505
+ UC --> US2
506
+ UC --> US3
507
+ UC --> US4
508
+ UC --> US5
509
+
510
+ note right of UC : 1つのユースケース
511
+ note right of US3 : イテレーション単位の\nストーリーに分解
512
+ @enduml
513
+ ```
514
+
515
+ ### イテレーション計画での利用
516
+
517
+ 1. **リリース計画時**
518
+
519
+ - 要約レベルのユースケースで全体像を把握
520
+ - 大まかな規模見積もり
521
+
522
+ 2. **イテレーション計画時**
523
+
524
+ - ユーザー目的レベルをストーリーに分解
525
+ - 詳細な見積もりと優先順位付け
526
+
527
+ 3. **実装時**
528
+
529
+ - ユースケースを設計ガイドとして利用
530
+ - 受入テストケースの基準
531
+
532
+ ### ユースケースから機能リストへ
533
+
534
+ ```markdown
535
+ ## UC-001: 商品を注文する
536
+
537
+ ### 抽出された機能リスト
538
+
539
+ | ID | 機能 | 優先度 | ストーリーポイント |
540
+ |----|------|--------|------------------|
541
+ | F1.1 | 商品検索機能 | 必須 | 3 |
542
+ | F1.2 | カート追加機能 | 必須 | 2 |
543
+ | F1.3 | 在庫確認機能 | 必須 | 3 |
544
+ | F1.4 | 配送先入力機能 | 必須 | 2 |
545
+ | F1.5 | 支払い処理機能 | 必須 | 5 |
546
+ | F1.6 | 注文確認メール送信 | 重要 | 2 |
547
+ | F1.7 | 注文履歴保存 | 重要 | 1 |
548
+ ```
549
+
550
+ ## 11. テストケースへの変換
551
+
552
+ ### ユースケースベースのテスト設計
553
+
554
+ ```plantuml
555
+ @startuml
556
+ title ユースケースからテストケースへ
557
+
558
+ rectangle "ユースケース" as UC {
559
+ rectangle "主成功シナリオ" as MSS
560
+ rectangle "拡張1" as EX1
561
+ rectangle "拡張2" as EX2
562
+ rectangle "拡張3" as EX3
563
+ }
564
+
565
+ rectangle "テストケース" as TC {
566
+ rectangle "正常系テスト" as NT
567
+ rectangle "異常系テスト1" as AT1
568
+ rectangle "異常系テスト2" as AT2
569
+ rectangle "異常系テスト3" as AT3
570
+ rectangle "境界値テスト" as BT
571
+ }
572
+
573
+ MSS --> NT
574
+ EX1 --> AT1
575
+ EX2 --> AT2
576
+ EX3 --> AT3
577
+ UC --> BT
578
+
579
+ note bottom of TC : 各パスを網羅する\nテストケースを生成
580
+ @enduml
581
+ ```
582
+
583
+ ### テストケーステンプレート
584
+
585
+ ```markdown
586
+ ## テストケース: [ユースケース名]_[パス]
587
+
588
+ **基になるユースケース**: UC-XXX
589
+ **テストパス**: 主成功シナリオ/拡張XX
590
+
591
+ **事前条件**:
592
+
593
+ - [システムの初期状態]
594
+ - [必要なテストデータ]
595
+
596
+ **入力**:
597
+ 1. [入力データ1]
598
+ 2. [入力データ2]
599
+
600
+ **期待結果**:
601
+
602
+ - [期待される出力]
603
+ - [期待される状態変化]
604
+ - [期待される副作用]
605
+
606
+ **事後条件**:
607
+
608
+ - [システムの最終状態]
609
+ ```
610
+
611
+ ## 12. よくある問題と対策
612
+
613
+ ### 問題パターンと解決策
614
+
615
+ | 問題 | 症状 | 解決策 |
616
+ |------|------|--------|
617
+ | スコープ不明確 | 要求が増え続ける | In/Outリスト作成 |
618
+ | レベル混在 | ステップが不均一 | レベルアイコン使用 |
619
+ | UI記述 | 実装に依存 | 意図の記述に変更 |
620
+ | 長すぎる | 10ステップ以上 | サブユースケース分割 |
621
+ | 曖昧な記述 | 解釈が複数 | 具体例の追加 |
622
+ | 保証なし | 目的が不明 | 利害関係者分析 |
623
+
624
+ ### アンチパターン
625
+
626
+ ```plantuml
627
+ @startuml
628
+ title ユースケースのアンチパターン
629
+
630
+ rectangle "❌ 悪い例" as bad {
631
+ usecase "データを処理する" as UC1
632
+ usecase "画面を表示する" as UC2
633
+ usecase "ボタンをクリックする" as UC3
634
+ }
635
+
636
+ rectangle "✅ 良い例" as good {
637
+ usecase "注文を確定する" as UC4
638
+ usecase "在庫を確認する" as UC5
639
+ usecase "支払いを処理する" as UC6
640
+ }
641
+
642
+ note bottom of bad : 技術的すぎる\nUI依存\n目的が不明
643
+ note bottom of good : ビジネス目的\n実装独立\n価値が明確
644
+ @enduml
645
+ ```
646
+
647
+ ## まとめ
648
+
649
+ ### ユースケース作成の原則
650
+
651
+ 1. **読みやすさ優先**
652
+
653
+ - 完璧さより理解しやすさ
654
+ - 自然な言葉で記述
655
+
656
+ 2. **段階的詳細化**
657
+
658
+ - 広く浅くから始める
659
+ - 必要に応じて深堀り
660
+
661
+ 3. **適切なレベル選択**
662
+
663
+ - ユーザー目的を中心に
664
+ - サブ機能は最小限に
665
+
666
+ 4. **XPとの統合**
667
+
668
+ - ユーザーストーリーと連携
669
+ - イテレーション計画で活用
670
+ - テストケースの基準
671
+
672
+ ### クイックリファレンス
673
+
674
+ **アイコン凡例**
675
+
676
+ - 🏢 組織スコープ
677
+ - 💻 システムスコープ
678
+ - 💾 コンポーネントスコープ
679
+ - ☁️ 要約レベル
680
+ - 🌊 ユーザー目的レベル
681
+ - 🐟 サブ機能レベル
682
+
683
+ **記述の黄金律**
684
+
685
+ - 3〜9ステップ
686
+ - アクターの意図を記述
687
+ - UI詳細は書かない
688
+ - 成功する目的として表現
689
+
690
690
  このガイドを参考に、プロジェクトに適したユースケースを作成し、XP開発プロセスに統合してください。