- phase-runner: レポートを上書きせずタイムスタンプ付きで同ディレクトリに保存し、fix が過去指摘の傾向を追跡できるよう改善
- output-contracts: persists/reopened/family_tag フィールドを追加してレビュー指摘の継続性を明示
- pieces: 全ビルトインピースに reviewers↔fix の loop_monitors を追加し、発散ループを自動検知
- fix.md: 過去レポートの参照方法を「Glob で {レポート名}.* を検索、最大2件読む」と具体化
- loop-monitor-reviewers-fix.md: ループモニタ判定用の共通インストラクションを新規追加
48 lines
1.9 KiB
Markdown
48 lines
1.9 KiB
Markdown
```markdown
|
||
# Terraform 規約レビュー
|
||
|
||
## 結果: APPROVE / REJECT
|
||
|
||
## サマリー
|
||
{1-2文で結果を要約}
|
||
|
||
## 確認した観点
|
||
- [x] 変数宣言(type, description, sensitive)
|
||
- [x] リソース命名(name_prefix パターン)
|
||
- [x] ファイル構成(1ファイル1関心事)
|
||
- [x] セキュリティ設定
|
||
- [x] タグ管理
|
||
- [x] lifecycle ルール
|
||
- [x] コストトレードオフ文書化
|
||
|
||
## 今回の指摘(new)
|
||
| # | finding_id | family_tag | スコープ | 場所 | 問題 | 修正案 |
|
||
|---|------------|------------|---------|------|------|--------|
|
||
| 1 | TF-NEW-file-L42 | tf-convention | スコープ内 | `modules/example/main.tf:42` | 問題の説明 | 修正方法 |
|
||
|
||
スコープ: 「スコープ内」(今回修正可能)/ 「スコープ外」(既存問題・非ブロッキング)
|
||
|
||
## 継続指摘(persists)
|
||
| # | finding_id | family_tag | 前回根拠 | 今回根拠 | 問題 | 修正案 |
|
||
|---|------------|------------|----------|----------|------|--------|
|
||
| 1 | TF-PERSIST-file-L77 | tf-convention | `file.tf:77` | `file.tf:77` | 未解消 | 既存修正方針を適用 |
|
||
|
||
## 解消済み(resolved)
|
||
| finding_id | 解消根拠 |
|
||
|------------|----------|
|
||
| TF-RESOLVED-file-L10 | `file.tf:10` は規約を満たす |
|
||
|
||
## 再開指摘(reopened)
|
||
| # | finding_id | family_tag | 解消根拠(前回) | 再発根拠 | 問題 | 修正案 |
|
||
|---|------------|------------|----------------|---------|------|--------|
|
||
| 1 | TF-REOPENED-file-L55 | tf-convention | `前回: file.tf:10 で修正済み` | `file.tf:55 で再発` | 問題の説明 | 修正方法 |
|
||
|
||
## REJECT判定条件
|
||
- `new`、`persists`、または `reopened` が1件以上ある場合のみ REJECT 可
|
||
- `finding_id` なしの指摘は無効
|
||
```
|
||
|
||
**認知負荷軽減ルール:**
|
||
- APPROVE → サマリーのみ(5行以内)
|
||
- REJECT → 該当指摘のみ表で記載(30行以内)
|