@k2works/claude-code-booster 0.1.2 → 0.2.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.
- package/README.md +14 -0
- package/bin/claude-code-booster +39 -16
- package/lib/assets/.claude/README.md +44 -40
- package/lib/assets/.claude/commands/analysis.md +230 -0
- package/lib/assets/.claude/commands/kill.md +109 -0
- package/lib/assets/.claude/commands/next.md +136 -0
- package/lib/assets/.claude/commands/plan.md +141 -91
- package/lib/assets/.claude/commands/progress.md +172 -0
- package/lib/assets/docs/reference/UI/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +446 -0
- 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 +1428 -0
- 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 +1879 -0
- 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 +1310 -0
- 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 +312 -0
- 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 +600 -0
- 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 +672 -0
- 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 +524 -0
- 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 +393 -0
- package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +18 -173
- 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 +1231 -0
- 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 +64 -0
- package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +467 -443
- package/package.json +1 -1
|
@@ -0,0 +1,672 @@
|
|
|
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
|
+
- これは1回の作業セッションで完了するか?
|
|
72
|
+
|
|
73
|
+
**要約レベルの判定**
|
|
74
|
+
- 複数のユーザー目的が含まれているか?
|
|
75
|
+
- 時間をかけて実行される長いプロセスか?
|
|
76
|
+
|
|
77
|
+
**サブ機能レベルの判定**
|
|
78
|
+
- これだけでは目的が達成されないか?
|
|
79
|
+
- 他のユースケースから呼び出される共通処理か?
|
|
80
|
+
|
|
81
|
+
## 2. スコープの定義
|
|
82
|
+
|
|
83
|
+
### 設計スコープの種類
|
|
84
|
+
|
|
85
|
+
```plantuml
|
|
86
|
+
@startuml
|
|
87
|
+
title 設計スコープの境界
|
|
88
|
+
|
|
89
|
+
package "🏢組織(企業全体)" {
|
|
90
|
+
package "💻システム(ソフトウェア)" {
|
|
91
|
+
package "💾コンポーネント" {
|
|
92
|
+
[モジュールA]
|
|
93
|
+
[モジュールB]
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
actor 社員
|
|
97
|
+
actor 外部システム
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
actor 顧客
|
|
101
|
+
|
|
102
|
+
顧客 --> 社員 : 依頼
|
|
103
|
+
社員 --> [モジュールA] : 操作
|
|
104
|
+
[モジュールA] --> [モジュールB] : 連携
|
|
105
|
+
[モジュールB] --> 外部システム : API呼び出し
|
|
106
|
+
@enduml
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
### In/Outリストの作成
|
|
110
|
+
|
|
111
|
+
スコープを明確にするために、何が範囲内で何が範囲外かを整理:
|
|
112
|
+
|
|
113
|
+
| トピック | In | Out | 備考 |
|
|
114
|
+
|---------|----|----|------|
|
|
115
|
+
| ユーザー認証 | ✓ | | システムで実装 |
|
|
116
|
+
| 決済処理 | | ✓ | 外部サービス利用 |
|
|
117
|
+
| 在庫管理 | ✓ | | コア機能 |
|
|
118
|
+
| 配送手配 | | ✓ | 物流会社API |
|
|
119
|
+
| レポート生成 | ✓ | | 管理機能 |
|
|
120
|
+
|
|
121
|
+
## 3. アクターの識別
|
|
122
|
+
|
|
123
|
+
### アクター分析チェックリスト
|
|
124
|
+
|
|
125
|
+
```plantuml
|
|
126
|
+
@startuml
|
|
127
|
+
title アクターの種類と関係
|
|
128
|
+
|
|
129
|
+
actor "主アクター" as primary #lightblue
|
|
130
|
+
actor "支援アクター" as support #lightgreen
|
|
131
|
+
actor "オフステージアクター" as offstage #lightyellow
|
|
132
|
+
|
|
133
|
+
rectangle "システム" as system
|
|
134
|
+
|
|
135
|
+
primary --> system : 目的を持って\n操作する
|
|
136
|
+
system --> support : サービスを\n要求する
|
|
137
|
+
offstage ..> system : 利益を持つが\n直接操作しない
|
|
138
|
+
|
|
139
|
+
note right of primary : システムを使って\n目的を達成する人
|
|
140
|
+
note right of support : システムが依存する\n外部サービス
|
|
141
|
+
note right of offstage : 規制当局、\n管理者など
|
|
142
|
+
@enduml
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
### アクター・目的リスト
|
|
146
|
+
|
|
147
|
+
優先度付きでアクターの目的を整理:
|
|
148
|
+
|
|
149
|
+
| アクター | 目的 | レベル | 優先度 | 頻度 |
|
|
150
|
+
|---------|------|--------|--------|------|
|
|
151
|
+
| 購入者 | 商品を検索する | 🌊 | 高 | 100回/日 |
|
|
152
|
+
| 購入者 | 注文する | 🌊 | 高 | 50回/日 |
|
|
153
|
+
| 購入者 | 注文履歴を確認する | 🌊 | 中 | 20回/日 |
|
|
154
|
+
| 管理者 | 在庫を更新する | 🌊 | 高 | 30回/日 |
|
|
155
|
+
| 管理者 | レポートを生成する | ☁️ | 中 | 5回/日 |
|
|
156
|
+
| システム | 在庫を自動補充する | 🌊 | 高 | 10回/日 |
|
|
157
|
+
|
|
158
|
+
## 4. ユースケース記述プロセス
|
|
159
|
+
|
|
160
|
+
### 段階的詳細化アプローチ
|
|
161
|
+
|
|
162
|
+
```plantuml
|
|
163
|
+
@startuml
|
|
164
|
+
title ユースケース作成の段階的詳細化
|
|
165
|
+
|
|
166
|
+
[*] --> 精度レベル1
|
|
167
|
+
精度レベル1 --> 精度レベル2
|
|
168
|
+
精度レベル2 --> 精度レベル3
|
|
169
|
+
精度レベル3 --> 精度レベル4
|
|
170
|
+
精度レベル4 --> [*]
|
|
171
|
+
|
|
172
|
+
精度レベル1 : アクター名と目的
|
|
173
|
+
精度レベル1 : ・アクター・目的リスト
|
|
174
|
+
精度レベル1 : ・1行記述
|
|
175
|
+
|
|
176
|
+
精度レベル2 : ユースケース概要
|
|
177
|
+
精度レベル2 : ・主成功シナリオ
|
|
178
|
+
精度レベル2 : ・段落形式の記述
|
|
179
|
+
|
|
180
|
+
精度レベル3 : 拡張条件の追加
|
|
181
|
+
精度レベル3 : ・例外処理の識別
|
|
182
|
+
精度レベル3 : ・代替パスの定義
|
|
183
|
+
|
|
184
|
+
精度レベル4 : 完全形式
|
|
185
|
+
精度レベル4 : ・拡張処理ステップ
|
|
186
|
+
精度レベル4 : ・事前/事後条件
|
|
187
|
+
精度レベル4 : ・保証の定義
|
|
188
|
+
@enduml
|
|
189
|
+
```
|
|
190
|
+
|
|
191
|
+
### 12ステップの作成プロセス
|
|
192
|
+
|
|
193
|
+
1. **システムのスコープと境界を識別**
|
|
194
|
+
2. **主アクターの一覧作成**
|
|
195
|
+
3. **ユーザー目的の洗い出し**
|
|
196
|
+
4. **要約レベルユースケースの作成**
|
|
197
|
+
5. **要約レベルの見直しと統合**
|
|
198
|
+
6. **詳細化するユースケースの選択**
|
|
199
|
+
7. **利害関係者と保証の定義**
|
|
200
|
+
8. **主成功シナリオの記述**
|
|
201
|
+
9. **例外条件の洗い出し**
|
|
202
|
+
10. **拡張処理ステップの記述**
|
|
203
|
+
11. **複雑なフローの分割と統合**
|
|
204
|
+
12. **全体の整理と見直し**
|
|
205
|
+
|
|
206
|
+
## 5. ユースケーステンプレート
|
|
207
|
+
|
|
208
|
+
### 完全形式テンプレート
|
|
209
|
+
|
|
210
|
+
```markdown
|
|
211
|
+
# UC-[番号]: [スコープアイコン][ユースケース名][レベルアイコン]
|
|
212
|
+
|
|
213
|
+
**コンテキスト**: [一般的に起きる条件や状況の説明]
|
|
214
|
+
|
|
215
|
+
**スコープ**: [設計対象システム]
|
|
216
|
+
|
|
217
|
+
**レベル**: [要約/ユーザー目的/サブ機能]
|
|
218
|
+
|
|
219
|
+
**主アクター**: [目的を持つアクター]
|
|
220
|
+
|
|
221
|
+
**利害関係者と利益**:
|
|
222
|
+
|
|
223
|
+
- [利害関係者1]: [その利益]
|
|
224
|
+
- [利害関係者2]: [その利益]
|
|
225
|
+
|
|
226
|
+
**事前条件**:
|
|
227
|
+
|
|
228
|
+
- [すでに真であると想定している状態]
|
|
229
|
+
|
|
230
|
+
**トリガー**: [ユースケースを開始するイベント]
|
|
231
|
+
|
|
232
|
+
**最低保証**: [失敗時でも守られる利益]
|
|
233
|
+
|
|
234
|
+
**成功時保証**: [成功時に達成される状態]
|
|
235
|
+
|
|
236
|
+
**主成功シナリオ**:
|
|
237
|
+
|
|
238
|
+
1. [アクター]が[アクション]する
|
|
239
|
+
2. システムが[処理]する
|
|
240
|
+
3. ...
|
|
241
|
+
|
|
242
|
+
**拡張**:
|
|
243
|
+
|
|
244
|
+
- 1a. [条件]:
|
|
245
|
+
- 1a1. [代替処理]
|
|
246
|
+
- 2-4a. [いつでも発生する条件]:
|
|
247
|
+
- 2-4a1. [処理]
|
|
248
|
+
|
|
249
|
+
**技術およびデータのバリエーション**:
|
|
250
|
+
|
|
251
|
+
- ステップ1: [バリエーション]
|
|
252
|
+
```
|
|
253
|
+
|
|
254
|
+
### 略式テンプレート(XP向け)
|
|
255
|
+
|
|
256
|
+
```markdown
|
|
257
|
+
# [ユースケース名]
|
|
258
|
+
|
|
259
|
+
**主アクター**: [アクター名]
|
|
260
|
+
**スコープ**: [システム名]
|
|
261
|
+
**レベル**: [レベル]
|
|
262
|
+
|
|
263
|
+
[主成功シナリオを段落形式で記述。システムの振る舞いと
|
|
264
|
+
アクターの相互作用を自然な文章で表現]
|
|
265
|
+
|
|
266
|
+
[代替パスや例外処理を段落形式で記述]
|
|
267
|
+
|
|
268
|
+
**頻度**: [実行頻度]
|
|
269
|
+
```
|
|
270
|
+
|
|
271
|
+
### ユースケース概要(ユーザーストーリー形式)
|
|
272
|
+
|
|
273
|
+
```markdown
|
|
274
|
+
# [機能名]
|
|
275
|
+
|
|
276
|
+
**として**: [アクター]
|
|
277
|
+
**したい**: [目的/機能]
|
|
278
|
+
**なぜなら**: [ビジネス価値]
|
|
279
|
+
|
|
280
|
+
**受入条件**:
|
|
281
|
+
- [ ] [条件1]
|
|
282
|
+
- [ ] [条件2]
|
|
283
|
+
```
|
|
284
|
+
|
|
285
|
+
## 6. シナリオの書き方
|
|
286
|
+
|
|
287
|
+
### 良いステップの書き方
|
|
288
|
+
|
|
289
|
+
```plantuml
|
|
290
|
+
@startuml
|
|
291
|
+
title ステップ記述のレベル
|
|
292
|
+
|
|
293
|
+
participant アクター as A
|
|
294
|
+
participant システム as S
|
|
295
|
+
participant 外部システム as E
|
|
296
|
+
|
|
297
|
+
== 🌊ユーザー目的レベル ==
|
|
298
|
+
A -> S: 1. 商品を注文する
|
|
299
|
+
activate S
|
|
300
|
+
S -> S: 2. 在庫を確認する
|
|
301
|
+
S -> A: 3. 注文を確認する
|
|
302
|
+
deactivate S
|
|
303
|
+
|
|
304
|
+
== 🐟サブ機能レベル(詳細) ==
|
|
305
|
+
A -> S: 1. ユーザー名とパスワードを入力する
|
|
306
|
+
activate S
|
|
307
|
+
S -> S: 2. 認証情報を検証する
|
|
308
|
+
S -> E: 3. 認証サーバーに問い合わせる
|
|
309
|
+
E -> S: 4. 認証結果を返す
|
|
310
|
+
S -> A: 5. ログイン結果を表示する
|
|
311
|
+
deactivate S
|
|
312
|
+
@enduml
|
|
313
|
+
```
|
|
314
|
+
|
|
315
|
+
### ステップ記述のガイドライン
|
|
316
|
+
|
|
317
|
+
**やるべきこと**
|
|
318
|
+
- ✅ アクターの意図を表現する
|
|
319
|
+
- ✅ 「誰が何をする」を明確にする
|
|
320
|
+
- ✅ 成功する目的として記述する
|
|
321
|
+
- ✅ 情報の流れを明確にする
|
|
322
|
+
|
|
323
|
+
**避けるべきこと**
|
|
324
|
+
- ❌ UIの詳細を記述する
|
|
325
|
+
- ❌ 「チェックする」ではなく「確認する」
|
|
326
|
+
- ❌ 実装の詳細に踏み込む
|
|
327
|
+
- ❌ IF文を使う(拡張に記載)
|
|
328
|
+
|
|
329
|
+
### ステップ数の目安
|
|
330
|
+
|
|
331
|
+
```plantuml
|
|
332
|
+
@startuml
|
|
333
|
+
title 適切なステップ数
|
|
334
|
+
|
|
335
|
+
rectangle "理想的" #lightgreen {
|
|
336
|
+
(3〜9ステップ)
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
rectangle "許容範囲" #yellow {
|
|
340
|
+
(2〜10ステップ)
|
|
341
|
+
}
|
|
342
|
+
|
|
343
|
+
rectangle "要分割" #lightcoral {
|
|
344
|
+
(11ステップ以上)
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
note bottom of "理想的" : 読みやすく\n理解しやすい
|
|
348
|
+
note bottom of "許容範囲" : 状況により\n許容
|
|
349
|
+
note bottom of "要分割" : サブユースケース\nに分割を検討
|
|
350
|
+
@enduml
|
|
351
|
+
```
|
|
352
|
+
|
|
353
|
+
## 7. 拡張の記述
|
|
354
|
+
|
|
355
|
+
### 拡張条件の識別
|
|
356
|
+
|
|
357
|
+
```plantuml
|
|
358
|
+
@startuml
|
|
359
|
+
title 拡張の分岐パターン
|
|
360
|
+
|
|
361
|
+
start
|
|
362
|
+
:主成功シナリオ;
|
|
363
|
+
if (条件A?) then (yes)
|
|
364
|
+
:拡張処理A;
|
|
365
|
+
:主シナリオに戻る;
|
|
366
|
+
else (no)
|
|
367
|
+
if (条件B?) then (yes)
|
|
368
|
+
:拡張処理B;
|
|
369
|
+
stop
|
|
370
|
+
else (no)
|
|
371
|
+
:通常処理継続;
|
|
372
|
+
endif
|
|
373
|
+
endif
|
|
374
|
+
:次のステップ;
|
|
375
|
+
stop
|
|
376
|
+
@enduml
|
|
377
|
+
```
|
|
378
|
+
|
|
379
|
+
### 拡張の記述形式
|
|
380
|
+
|
|
381
|
+
```markdown
|
|
382
|
+
**主成功シナリオ**:
|
|
383
|
+
|
|
384
|
+
1. ユーザーが商品を選択する
|
|
385
|
+
2. システムが在庫を確認する
|
|
386
|
+
3. ユーザーが数量を指定する
|
|
387
|
+
4. システムが合計金額を計算する
|
|
388
|
+
5. ユーザーが注文を確定する
|
|
389
|
+
|
|
390
|
+
**拡張**:
|
|
391
|
+
|
|
392
|
+
- 2a. 在庫がない:
|
|
393
|
+
- 2a1. システムが在庫なしを通知する
|
|
394
|
+
- 2a2. ユーザーが別の商品を選択する(ステップ1へ)
|
|
395
|
+
|
|
396
|
+
- 3a. 数量が在庫を超える:
|
|
397
|
+
- 3a1. システムが利用可能数量を表示する
|
|
398
|
+
- 3a2. ユーザーが数量を調整する
|
|
399
|
+
|
|
400
|
+
- *a. ユーザーがキャンセル:
|
|
401
|
+
- *a1. システムがトランザクションを破棄する
|
|
402
|
+
- *a2. 終了
|
|
403
|
+
```
|
|
404
|
+
|
|
405
|
+
## 8. データ記述の精度
|
|
406
|
+
|
|
407
|
+
### 3段階のデータ精度
|
|
408
|
+
|
|
409
|
+
```plantuml
|
|
410
|
+
@startuml
|
|
411
|
+
title データ記述の精度レベル
|
|
412
|
+
|
|
413
|
+
class 精度レベル1 {
|
|
414
|
+
ニックネーム
|
|
415
|
+
--
|
|
416
|
+
"顧客情報"
|
|
417
|
+
"注文データ"
|
|
418
|
+
"商品リスト"
|
|
419
|
+
}
|
|
420
|
+
|
|
421
|
+
class 精度レベル2 {
|
|
422
|
+
フィールド群
|
|
423
|
+
--
|
|
424
|
+
顧客情報:
|
|
425
|
+
- 氏名
|
|
426
|
+
- 住所
|
|
427
|
+
- 電話番号
|
|
428
|
+
}
|
|
429
|
+
|
|
430
|
+
class 精度レベル3 {
|
|
431
|
+
詳細仕様
|
|
432
|
+
--
|
|
433
|
+
氏名: String(100)
|
|
434
|
+
住所: String(200)
|
|
435
|
+
電話番号: String(20)
|
|
436
|
+
+ NotNull制約
|
|
437
|
+
+ 形式チェック
|
|
438
|
+
}
|
|
439
|
+
|
|
440
|
+
精度レベル1 --> 精度レベル2 : 詳細化
|
|
441
|
+
精度レベル2 --> 精度レベル3 : 詳細化
|
|
442
|
+
|
|
443
|
+
note bottom of 精度レベル1 : ユースケースで使用
|
|
444
|
+
note bottom of 精度レベル3 : 設計書で定義
|
|
445
|
+
@enduml
|
|
446
|
+
```
|
|
447
|
+
|
|
448
|
+
## 9. 品質チェックリスト
|
|
449
|
+
|
|
450
|
+
### ユースケース全体のチェック項目
|
|
451
|
+
|
|
452
|
+
| カテゴリ | チェック項目 | ✓ |
|
|
453
|
+
|---------|------------|---|
|
|
454
|
+
| **タイトル** | 動詞句で目的を表現しているか | □ |
|
|
455
|
+
| | システムが達成可能な目的か | □ |
|
|
456
|
+
| **スコープ** | 明確に定義されているか | □ |
|
|
457
|
+
| | ブラックボックスとして扱っているか | □ |
|
|
458
|
+
| **レベル** | 適切なレベルが選択されているか | □ |
|
|
459
|
+
| | 内容がレベルと一致しているか | □ |
|
|
460
|
+
| **主アクター** | 振る舞いを持っているか | □ |
|
|
461
|
+
| | システムへの明確な目的があるか | □ |
|
|
462
|
+
| **事前条件** | 必須かつ検証可能か | □ |
|
|
463
|
+
| | ユースケース内で再チェックしていないか | □ |
|
|
464
|
+
| **保証** | 利害関係者の利益が守られているか | □ |
|
|
465
|
+
| | 成功時に目的が達成されるか | □ |
|
|
466
|
+
| **シナリオ** | 3〜9ステップに収まっているか | □ |
|
|
467
|
+
| | トリガーから保証まで進んでいるか | □ |
|
|
468
|
+
|
|
469
|
+
### ステップ記述のチェック項目
|
|
470
|
+
|
|
471
|
+
- □ 成功する目的として表現されているか
|
|
472
|
+
- □ アクターが明確か
|
|
473
|
+
- □ 意図が明確か
|
|
474
|
+
- □ UI設計を含んでいないか
|
|
475
|
+
- □ 情報の流れが明確か
|
|
476
|
+
- □ 「確認する」を使っているか(「チェックする」ではなく)
|
|
477
|
+
|
|
478
|
+
## 10. XPプロジェクトでの活用
|
|
479
|
+
|
|
480
|
+
### ユーザーストーリーとの連携
|
|
481
|
+
|
|
482
|
+
```plantuml
|
|
483
|
+
@startuml
|
|
484
|
+
title ユースケースからユーザーストーリーへの分解
|
|
485
|
+
|
|
486
|
+
package "ユースケース" {
|
|
487
|
+
rectangle "🌊商品を注文する" as UC
|
|
488
|
+
}
|
|
489
|
+
|
|
490
|
+
package "ユーザーストーリー" {
|
|
491
|
+
rectangle "商品を検索する" as US1
|
|
492
|
+
rectangle "カートに追加する" as US2
|
|
493
|
+
rectangle "配送先を入力する" as US3
|
|
494
|
+
rectangle "支払い方法を選択する" as US4
|
|
495
|
+
rectangle "注文を確定する" as US5
|
|
496
|
+
}
|
|
497
|
+
|
|
498
|
+
UC --> US1
|
|
499
|
+
UC --> US2
|
|
500
|
+
UC --> US3
|
|
501
|
+
UC --> US4
|
|
502
|
+
UC --> US5
|
|
503
|
+
|
|
504
|
+
note right of UC : 1つのユースケース
|
|
505
|
+
note right of US3 : イテレーション単位の\nストーリーに分解
|
|
506
|
+
@enduml
|
|
507
|
+
```
|
|
508
|
+
|
|
509
|
+
### イテレーション計画での利用
|
|
510
|
+
|
|
511
|
+
1. **リリース計画時**
|
|
512
|
+
- 要約レベルのユースケースで全体像を把握
|
|
513
|
+
- 大まかな規模見積もり
|
|
514
|
+
|
|
515
|
+
2. **イテレーション計画時**
|
|
516
|
+
- ユーザー目的レベルをストーリーに分解
|
|
517
|
+
- 詳細な見積もりと優先順位付け
|
|
518
|
+
|
|
519
|
+
3. **実装時**
|
|
520
|
+
- ユースケースを設計ガイドとして利用
|
|
521
|
+
- 受入テストケースの基準
|
|
522
|
+
|
|
523
|
+
### ユースケースから機能リストへ
|
|
524
|
+
|
|
525
|
+
```markdown
|
|
526
|
+
## UC-001: 商品を注文する
|
|
527
|
+
|
|
528
|
+
### 抽出された機能リスト
|
|
529
|
+
|
|
530
|
+
| ID | 機能 | 優先度 | ストーリーポイント |
|
|
531
|
+
|----|------|--------|------------------|
|
|
532
|
+
| F1.1 | 商品検索機能 | 必須 | 3 |
|
|
533
|
+
| F1.2 | カート追加機能 | 必須 | 2 |
|
|
534
|
+
| F1.3 | 在庫確認機能 | 必須 | 3 |
|
|
535
|
+
| F1.4 | 配送先入力機能 | 必須 | 2 |
|
|
536
|
+
| F1.5 | 支払い処理機能 | 必須 | 5 |
|
|
537
|
+
| F1.6 | 注文確認メール送信 | 重要 | 2 |
|
|
538
|
+
| F1.7 | 注文履歴保存 | 重要 | 1 |
|
|
539
|
+
```
|
|
540
|
+
|
|
541
|
+
## 11. テストケースへの変換
|
|
542
|
+
|
|
543
|
+
### ユースケースベースのテスト設計
|
|
544
|
+
|
|
545
|
+
```plantuml
|
|
546
|
+
@startuml
|
|
547
|
+
title ユースケースからテストケースへ
|
|
548
|
+
|
|
549
|
+
rectangle "ユースケース" as UC {
|
|
550
|
+
rectangle "主成功シナリオ" as MSS
|
|
551
|
+
rectangle "拡張1" as EX1
|
|
552
|
+
rectangle "拡張2" as EX2
|
|
553
|
+
rectangle "拡張3" as EX3
|
|
554
|
+
}
|
|
555
|
+
|
|
556
|
+
rectangle "テストケース" as TC {
|
|
557
|
+
rectangle "正常系テスト" as NT
|
|
558
|
+
rectangle "異常系テスト1" as AT1
|
|
559
|
+
rectangle "異常系テスト2" as AT2
|
|
560
|
+
rectangle "異常系テスト3" as AT3
|
|
561
|
+
rectangle "境界値テスト" as BT
|
|
562
|
+
}
|
|
563
|
+
|
|
564
|
+
MSS --> NT
|
|
565
|
+
EX1 --> AT1
|
|
566
|
+
EX2 --> AT2
|
|
567
|
+
EX3 --> AT3
|
|
568
|
+
UC --> BT
|
|
569
|
+
|
|
570
|
+
note bottom of TC : 各パスを網羅する\nテストケースを生成
|
|
571
|
+
@enduml
|
|
572
|
+
```
|
|
573
|
+
|
|
574
|
+
### テストケーステンプレート
|
|
575
|
+
|
|
576
|
+
```markdown
|
|
577
|
+
## テストケース: [ユースケース名]_[パス]
|
|
578
|
+
|
|
579
|
+
**基になるユースケース**: UC-XXX
|
|
580
|
+
**テストパス**: 主成功シナリオ/拡張XX
|
|
581
|
+
|
|
582
|
+
**事前条件**:
|
|
583
|
+
- [システムの初期状態]
|
|
584
|
+
- [必要なテストデータ]
|
|
585
|
+
|
|
586
|
+
**入力**:
|
|
587
|
+
1. [入力データ1]
|
|
588
|
+
2. [入力データ2]
|
|
589
|
+
|
|
590
|
+
**期待結果**:
|
|
591
|
+
- [期待される出力]
|
|
592
|
+
- [期待される状態変化]
|
|
593
|
+
- [期待される副作用]
|
|
594
|
+
|
|
595
|
+
**事後条件**:
|
|
596
|
+
- [システムの最終状態]
|
|
597
|
+
```
|
|
598
|
+
|
|
599
|
+
## 12. よくある問題と対策
|
|
600
|
+
|
|
601
|
+
### 問題パターンと解決策
|
|
602
|
+
|
|
603
|
+
| 問題 | 症状 | 解決策 |
|
|
604
|
+
|------|------|--------|
|
|
605
|
+
| スコープ不明確 | 要求が増え続ける | In/Outリスト作成 |
|
|
606
|
+
| レベル混在 | ステップが不均一 | レベルアイコン使用 |
|
|
607
|
+
| UI記述 | 実装に依存 | 意図の記述に変更 |
|
|
608
|
+
| 長すぎる | 10ステップ以上 | サブユースケース分割 |
|
|
609
|
+
| 曖昧な記述 | 解釈が複数 | 具体例の追加 |
|
|
610
|
+
| 保証なし | 目的が不明 | 利害関係者分析 |
|
|
611
|
+
|
|
612
|
+
### アンチパターン
|
|
613
|
+
|
|
614
|
+
```plantuml
|
|
615
|
+
@startuml
|
|
616
|
+
title ユースケースのアンチパターン
|
|
617
|
+
|
|
618
|
+
rectangle "❌ 悪い例" as bad {
|
|
619
|
+
usecase "データを処理する" as UC1
|
|
620
|
+
usecase "画面を表示する" as UC2
|
|
621
|
+
usecase "ボタンをクリックする" as UC3
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
rectangle "✅ 良い例" as good {
|
|
625
|
+
usecase "注文を確定する" as UC4
|
|
626
|
+
usecase "在庫を確認する" as UC5
|
|
627
|
+
usecase "支払いを処理する" as UC6
|
|
628
|
+
}
|
|
629
|
+
|
|
630
|
+
note bottom of bad : 技術的すぎる\nUI依存\n目的が不明
|
|
631
|
+
note bottom of good : ビジネス目的\n実装独立\n価値が明確
|
|
632
|
+
@enduml
|
|
633
|
+
```
|
|
634
|
+
|
|
635
|
+
## まとめ
|
|
636
|
+
|
|
637
|
+
### ユースケース作成の原則
|
|
638
|
+
|
|
639
|
+
1. **読みやすさ優先**
|
|
640
|
+
- 完璧さより理解しやすさ
|
|
641
|
+
- 自然な言葉で記述
|
|
642
|
+
|
|
643
|
+
2. **段階的詳細化**
|
|
644
|
+
- 広く浅くから始める
|
|
645
|
+
- 必要に応じて深堀り
|
|
646
|
+
|
|
647
|
+
3. **適切なレベル選択**
|
|
648
|
+
- ユーザー目的を中心に
|
|
649
|
+
- サブ機能は最小限に
|
|
650
|
+
|
|
651
|
+
4. **XPとの統合**
|
|
652
|
+
- ユーザーストーリーと連携
|
|
653
|
+
- イテレーション計画で活用
|
|
654
|
+
- テストケースの基準
|
|
655
|
+
|
|
656
|
+
### クイックリファレンス
|
|
657
|
+
|
|
658
|
+
**アイコン凡例**
|
|
659
|
+
- 🏢 組織スコープ
|
|
660
|
+
- 💻 システムスコープ
|
|
661
|
+
- 💾 コンポーネントスコープ
|
|
662
|
+
- ☁️ 要約レベル
|
|
663
|
+
- 🌊 ユーザー目的レベル
|
|
664
|
+
- 🐟 サブ機能レベル
|
|
665
|
+
|
|
666
|
+
**記述の黄金律**
|
|
667
|
+
- 3〜9ステップ
|
|
668
|
+
- アクターの意図を記述
|
|
669
|
+
- UI詳細は書かない
|
|
670
|
+
- 成功する目的として表現
|
|
671
|
+
|
|
672
|
+
このガイドを参考に、プロジェクトに適したユースケースを作成し、XP開発プロセスに統合してください。
|