create-einja-app 0.3.2 → 0.3.4
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 +33 -0
- package/dist/cli.js +60 -64
- package/dist/cli.js.map +1 -1
- package/package.json +1 -1
- package/templates/default/.changeset/config.json +11 -0
- package/templates/default/.claude/hooks/einja/plan-mode-skill-loader.sh +5 -1
- package/templates/default/.claude/settings.json +14 -4
- package/templates/default/.claude/skills/_einja-general-context-loader/SKILL.md +258 -0
- package/templates/default/.claude/skills/_einja-output-format/SKILL.md +211 -0
- package/templates/default/.claude/skills/_einja-project-overview/SKILL.md +29 -0
- package/templates/default/.claude/skills/_einja-spec-context-loader/SKILL.md +181 -0
- package/templates/default/.claude/skills/cli-package-specs/SKILL.md +294 -0
- package/templates/default/.einja-sync.json +1 -1
- package/templates/default/.github/release.yml +10 -0
- package/templates/default/.github/workflows/changeset-status.yml +60 -0
- package/templates/default/.github/workflows/deploy-stable-branches.yml +289 -59
- package/templates/default/CLAUDE.md +50 -10
- package/templates/default/README.md +20 -8
- package/templates/default/docs/plans/agile-munching-knuth.md +161 -0
- package/templates/default/docs/plans/agile-riding-nova.md +158 -0
- package/templates/default/docs/plans/agile-wibbling-dusk.md +91 -0
- package/templates/default/docs/plans/ancient-watching-otter.md +152 -0
- package/templates/default/docs/plans/bright-sauteeing-bumblebee.md +30 -0
- package/templates/default/docs/plans/composed-doodling-mountain.md +362 -0
- package/templates/default/docs/plans/dazzling-foraging-cascade.md +32 -0
- package/templates/default/docs/plans/enchanted-wiggling-ember-agent-a5befd57d0ca4c7c7.md +177 -0
- package/templates/default/docs/plans/enchanted-wiggling-ember.md +170 -0
- package/templates/default/docs/plans/federated-questing-kahan.md +47 -0
- package/templates/default/docs/plans/flickering-pondering-hearth.md +26 -0
- package/templates/default/docs/plans/fluttering-snuggling-sprout.md +172 -0
- package/templates/default/docs/plans/generic-sleeping-snowglobe-agent-a41d8da.md +179 -0
- package/templates/default/docs/plans/generic-sleeping-snowglobe.md +108 -0
- package/templates/default/docs/plans/generic-snuggling-pudding.md +57 -0
- package/templates/default/docs/plans/glistening-conjuring-cascade.md +42 -0
- package/templates/default/docs/plans/idempotent-wiggling-cherny.md +122 -0
- package/templates/default/docs/plans/linear-gathering-hejlsberg.md +596 -0
- package/templates/default/docs/plans/recursive-fluttering-mitten.md +176 -0
- package/templates/default/docs/plans/todo-create-einja-app-ux-fix.md +16 -0
- package/templates/default/docs/plans/todo-direnv-hang-fix.md +12 -0
- package/templates/default/docs/plans/todo-github-actions-release-workflow.md +34 -0
- package/templates/default/docs/plans/todo-glistening-conjuring-cascade.md +20 -0
- package/templates/default/docs/plans/todo-issue-spec-rename.md +24 -0
- package/templates/default/docs/plans/todo-skill-creator-upgrade.md +18 -0
- package/templates/default/docs/plans/todo-unified-crafting-valiant.md +23 -0
- package/templates/default/docs/plans/unified-crafting-valiant.md +60 -0
- package/templates/default/docs/plans/velvety-chasing-spark.md +28 -0
- package/templates/default/docs/plans/wondrous-strolling-crystal-agent-a0615fc.md +215 -0
- package/templates/default/docs/plans/wondrous-strolling-crystal.md +182 -0
- package/templates/default/docs/plans/zesty-roaming-steele.md +74 -0
- package/templates/default/gitignore +6 -2
- package/templates/default/package.json +6 -2
- package/templates/default/pnpm-lock.yaml +547 -0
- package/templates/default/scripts/ensure-serena.sh +28 -9
- package/templates/default/scripts/env-rotate-secrets.ts +66 -6
- package/templates/default/scripts/init-github.ts +363 -0
- package/templates/default/scripts/init.sh +11 -5
- package/templates/default/scripts/setup-dev.ts +16 -1
- package/templates/default/.claude/hooks/einja/validate-git-commit.sh +0 -239
- package/templates/default/.claude/skills/create-einja-app-release/SKILL.md +0 -186
- package/templates/default/.claude/skills/dev-cli-release/SKILL.md +0 -173
- package/templates/default/.cursor/commands/spec-create.md +0 -227
- package/templates/default/.cursor/commands/task-exec.md +0 -287
- package/templates/default/.cursor/commands/update-docs-by-task-specs.md +0 -448
- package/templates/default/packages/server-core/src/__generated__/fabbrica/index.d.ts +0 -270
- package/templates/default/packages/server-core/src/__generated__/fabbrica/index.js +0 -484
|
@@ -1,239 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# validate-git-commit.sh - git commitコマンドのメッセージ形式を検証
|
|
3
|
-
#
|
|
4
|
-
# 目的:
|
|
5
|
-
# - git commit実行前にコミットメッセージの形式を検証
|
|
6
|
-
# - 不適切なメッセージ(---、Markdown形式等)をブロック
|
|
7
|
-
# - コミットルール(docs/einja/steering/commit-rules.md)に準拠を強制
|
|
8
|
-
#
|
|
9
|
-
# 使用方法:
|
|
10
|
-
# - PreToolUse hookとして設定
|
|
11
|
-
# - exit code 0: 許可
|
|
12
|
-
# - exit code 2: ブロック(stderrがClaudeに送信される)
|
|
13
|
-
|
|
14
|
-
set -uo pipefail
|
|
15
|
-
|
|
16
|
-
# 標準入力からJSON入力を読み取る
|
|
17
|
-
input=$(cat)
|
|
18
|
-
|
|
19
|
-
# ツール名を取得
|
|
20
|
-
tool_name=$(echo "$input" | jq -r '.tool_name // empty')
|
|
21
|
-
|
|
22
|
-
# Bashツール以外は無視
|
|
23
|
-
if [[ "$tool_name" != "Bash" ]]; then
|
|
24
|
-
exit 0
|
|
25
|
-
fi
|
|
26
|
-
|
|
27
|
-
# コマンドを取得
|
|
28
|
-
command=$(echo "$input" | jq -r '.tool_input.command // empty')
|
|
29
|
-
|
|
30
|
-
# git commitコマンドでない場合はスキップ(volta unset対応で部分マッチ)
|
|
31
|
-
if [[ ! "$command" =~ git[[:space:]]+commit ]]; then
|
|
32
|
-
exit 0
|
|
33
|
-
fi
|
|
34
|
-
|
|
35
|
-
# --amend のみの場合はスキップ(メッセージ変更なし)
|
|
36
|
-
# -m / --message がない場合のみスキップ
|
|
37
|
-
if [[ "$command" =~ --amend ]]; then
|
|
38
|
-
if [[ ! "$command" =~ -m ]] && [[ ! "$command" =~ --message ]]; then
|
|
39
|
-
exit 0
|
|
40
|
-
fi
|
|
41
|
-
fi
|
|
42
|
-
|
|
43
|
-
# -m / --message オプションがない場合はスキップ(インタラクティブエディタ使用)
|
|
44
|
-
if [[ ! "$command" =~ -m ]] && [[ ! "$command" =~ --message ]]; then
|
|
45
|
-
exit 0
|
|
46
|
-
fi
|
|
47
|
-
|
|
48
|
-
# コミットメッセージを抽出
|
|
49
|
-
commit_message=""
|
|
50
|
-
|
|
51
|
-
# パターン1: -m "message" / -m 'message' (スペースあり)
|
|
52
|
-
if [[ "$command" =~ -m[[:space:]]+\"([^\"]+)\" ]]; then
|
|
53
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
54
|
-
elif [[ "$command" =~ -m[[:space:]]+\'([^\']+)\' ]]; then
|
|
55
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
56
|
-
# パターン2: -m"message" / -m'message' (スペースなし)
|
|
57
|
-
elif [[ "$command" =~ -m\"([^\"]+)\" ]]; then
|
|
58
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
59
|
-
elif [[ "$command" =~ -m\'([^\']+)\' ]]; then
|
|
60
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
61
|
-
# パターン3: --message="message" / --message='message'
|
|
62
|
-
elif [[ "$command" =~ --message=\"([^\"]+)\" ]]; then
|
|
63
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
64
|
-
elif [[ "$command" =~ --message=\'([^\']+)\' ]]; then
|
|
65
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
66
|
-
# パターン4: --message "message" / --message 'message' (スペースあり)
|
|
67
|
-
elif [[ "$command" =~ --message[[:space:]]+\"([^\"]+)\" ]]; then
|
|
68
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
69
|
-
elif [[ "$command" =~ --message[[:space:]]+\'([^\']+)\' ]]; then
|
|
70
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
71
|
-
# パターン5: -m="message" / -m='message'
|
|
72
|
-
elif [[ "$command" =~ -m=\"([^\"]+)\" ]]; then
|
|
73
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
74
|
-
elif [[ "$command" =~ -m=\'([^\']+)\' ]]; then
|
|
75
|
-
commit_message="${BASH_REMATCH[1]}"
|
|
76
|
-
# パターン6: HEREDOC形式 -m "$(cat <<'EOF'...EOF)"
|
|
77
|
-
elif [[ "$command" =~ -m[[:space:]]*\"\$\(cat ]]; then
|
|
78
|
-
# HEREDOCからメッセージの最初の行を抽出
|
|
79
|
-
commit_message=$(echo "$command" | sed -n "/<<.*EOF/,/^EOF/p" | sed '1d;$d' | head -1)
|
|
80
|
-
fi
|
|
81
|
-
|
|
82
|
-
# メッセージが取得できない場合は許可(予期しないパターン)
|
|
83
|
-
if [[ -z "$commit_message" ]]; then
|
|
84
|
-
exit 0
|
|
85
|
-
fi
|
|
86
|
-
|
|
87
|
-
# 変数参照の場合はスキップ(実行時まで値が確定しない)
|
|
88
|
-
if [[ "$commit_message" =~ ^\$ ]]; then
|
|
89
|
-
exit 0
|
|
90
|
-
fi
|
|
91
|
-
|
|
92
|
-
# 最初の行(概要行)を取得
|
|
93
|
-
first_line=$(echo "$commit_message" | head -1)
|
|
94
|
-
|
|
95
|
-
# === 検証ルール ===
|
|
96
|
-
|
|
97
|
-
# 有効なプレフィックス一覧
|
|
98
|
-
VALID_PREFIXES="^(feat|fix|docs|style|refactor|test|chore):"
|
|
99
|
-
|
|
100
|
-
# ルール1: プレフィックスの存在確認
|
|
101
|
-
if ! echo "$first_line" | grep -qE "$VALID_PREFIXES"; then
|
|
102
|
-
cat >&2 <<ERRMSG
|
|
103
|
-
|
|
104
|
-
❌ コミットメッセージ形式エラー
|
|
105
|
-
|
|
106
|
-
検出されたメッセージ:
|
|
107
|
-
"$first_line"
|
|
108
|
-
|
|
109
|
-
問題:
|
|
110
|
-
有効なプレフィックスがありません。
|
|
111
|
-
|
|
112
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
113
|
-
⚡ 対処方法: /task-commit Skillを使用してください
|
|
114
|
-
|
|
115
|
-
このSkillはコミットルールに従って:
|
|
116
|
-
- 適切なプレフィックス(feat/fix/docs等)を付与
|
|
117
|
-
- 変更内容に応じたコミット分割を提案
|
|
118
|
-
- 日本語で明確なメッセージを生成
|
|
119
|
-
|
|
120
|
-
実行: Skill("task-commit") を呼び出す
|
|
121
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
122
|
-
|
|
123
|
-
参照: docs/einja/steering/commit-rules.md
|
|
124
|
-
|
|
125
|
-
ERRMSG
|
|
126
|
-
exit 2
|
|
127
|
-
fi
|
|
128
|
-
|
|
129
|
-
# プレフィックス後の説明部分を抽出(禁止パターン検出に使用)
|
|
130
|
-
description=$(echo "$first_line" | sed -E 's/^(feat|fix|docs|style|refactor|test|chore):[[:space:]]*//')
|
|
131
|
-
|
|
132
|
-
# ルール2: プレフィックス後のメッセージが空でないか(3文字以上)
|
|
133
|
-
if [[ -z "$description" ]] || [[ ${#description} -lt 3 ]]; then
|
|
134
|
-
cat >&2 <<ERRMSG
|
|
135
|
-
|
|
136
|
-
❌ コミットメッセージ形式エラー
|
|
137
|
-
|
|
138
|
-
検出されたメッセージ:
|
|
139
|
-
"$first_line"
|
|
140
|
-
|
|
141
|
-
問題:
|
|
142
|
-
プレフィックス後の説明が不足しています。
|
|
143
|
-
具体的な変更内容を記述してください(3文字以上)。
|
|
144
|
-
|
|
145
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
146
|
-
⚡ 対処方法: /task-commit Skillを使用してください
|
|
147
|
-
|
|
148
|
-
このSkillはコミットルールに従って:
|
|
149
|
-
- 適切なプレフィックス(feat/fix/docs等)を付与
|
|
150
|
-
- 変更内容に応じたコミット分割を提案
|
|
151
|
-
- 日本語で明確なメッセージを生成
|
|
152
|
-
|
|
153
|
-
実行: Skill("task-commit") を呼び出す
|
|
154
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
155
|
-
|
|
156
|
-
参照: docs/einja/steering/commit-rules.md
|
|
157
|
-
|
|
158
|
-
ERRMSG
|
|
159
|
-
exit 2
|
|
160
|
-
fi
|
|
161
|
-
|
|
162
|
-
# ルール3: 明らかに不適切なメッセージのパターン検出(説明部分に対して適用)
|
|
163
|
-
INVALID_PATTERNS=(
|
|
164
|
-
"^---$"
|
|
165
|
-
"^\*\*.*\*\*$"
|
|
166
|
-
"^完了しました"
|
|
167
|
-
"^実装完了"
|
|
168
|
-
"^修正完了"
|
|
169
|
-
"^update$"
|
|
170
|
-
"^fix$"
|
|
171
|
-
"^changes$"
|
|
172
|
-
"^wip$"
|
|
173
|
-
)
|
|
174
|
-
|
|
175
|
-
for pattern in "${INVALID_PATTERNS[@]}"; do
|
|
176
|
-
if echo "$description" | grep -qiE "$pattern"; then
|
|
177
|
-
cat >&2 <<ERRMSG
|
|
178
|
-
|
|
179
|
-
❌ コミットメッセージ形式エラー
|
|
180
|
-
|
|
181
|
-
検出されたメッセージ:
|
|
182
|
-
"$first_line"
|
|
183
|
-
|
|
184
|
-
問題:
|
|
185
|
-
コミットメッセージの説明部分が不適切な形式です。
|
|
186
|
-
具体的な変更内容を記述してください。
|
|
187
|
-
|
|
188
|
-
禁止されたパターン: $pattern
|
|
189
|
-
|
|
190
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
191
|
-
⚡ 対処方法: /task-commit Skillを使用してください
|
|
192
|
-
|
|
193
|
-
このSkillはコミットルールに従って:
|
|
194
|
-
- 適切なプレフィックス(feat/fix/docs等)を付与
|
|
195
|
-
- 変更内容に応じたコミット分割を提案
|
|
196
|
-
- 日本語で明確なメッセージを生成
|
|
197
|
-
|
|
198
|
-
実行: Skill("task-commit") を呼び出す
|
|
199
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
200
|
-
|
|
201
|
-
参照: docs/einja/steering/commit-rules.md
|
|
202
|
-
|
|
203
|
-
ERRMSG
|
|
204
|
-
exit 2
|
|
205
|
-
fi
|
|
206
|
-
done
|
|
207
|
-
|
|
208
|
-
# ルール4: メッセージがMarkdown見出し形式でないか
|
|
209
|
-
if echo "$first_line" | grep -qE "^#{1,6}[[:space:]]"; then
|
|
210
|
-
cat >&2 <<ERRMSG
|
|
211
|
-
|
|
212
|
-
❌ コミットメッセージ形式エラー
|
|
213
|
-
|
|
214
|
-
検出されたメッセージ:
|
|
215
|
-
"$first_line"
|
|
216
|
-
|
|
217
|
-
問題:
|
|
218
|
-
Markdownの見出し形式(#)は使用できません。
|
|
219
|
-
プレフィックス形式で記述してください。
|
|
220
|
-
|
|
221
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
222
|
-
⚡ 対処方法: /task-commit Skillを使用してください
|
|
223
|
-
|
|
224
|
-
このSkillはコミットルールに従って:
|
|
225
|
-
- 適切なプレフィックス(feat/fix/docs等)を付与
|
|
226
|
-
- 変更内容に応じたコミット分割を提案
|
|
227
|
-
- 日本語で明確なメッセージを生成
|
|
228
|
-
|
|
229
|
-
実行: Skill("task-commit") を呼び出す
|
|
230
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
231
|
-
|
|
232
|
-
参照: docs/einja/steering/commit-rules.md
|
|
233
|
-
|
|
234
|
-
ERRMSG
|
|
235
|
-
exit 2
|
|
236
|
-
fi
|
|
237
|
-
|
|
238
|
-
# 全ての検証をパス
|
|
239
|
-
exit 0
|
|
@@ -1,186 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: create-einja-app-release
|
|
3
|
-
description: "create-einja-app パッケージをビルド・テストし、NPMに公開するSkill。create-einja-appの公開、リリース、publishが必要な場合に使用。"
|
|
4
|
-
user-invocable: true
|
|
5
|
-
allowed-tools:
|
|
6
|
-
- Bash
|
|
7
|
-
- Read
|
|
8
|
-
- Glob
|
|
9
|
-
- Grep
|
|
10
|
-
- AskUserQuestion
|
|
11
|
-
- TodoWrite
|
|
12
|
-
- TodoRead
|
|
13
|
-
- Task
|
|
14
|
-
- MCPSearch
|
|
15
|
-
---
|
|
16
|
-
|
|
17
|
-
# create-einja-app-release Skill: create-einja-app パッケージ公開エンジン
|
|
18
|
-
|
|
19
|
-
## 役割
|
|
20
|
-
|
|
21
|
-
`create-einja-app` パッケージをビルド・テストし、NPMに公開します。
|
|
22
|
-
|
|
23
|
-
## 参照ドキュメント
|
|
24
|
-
|
|
25
|
-
- `packages/create-einja-app/RELEASING.md` - 詳細なリリース手順、トラブルシューティング、NPM_TOKEN設定方法
|
|
26
|
-
|
|
27
|
-
## 実行手順
|
|
28
|
-
|
|
29
|
-
### 1. 前提条件の確認
|
|
30
|
-
|
|
31
|
-
```bash
|
|
32
|
-
git branch --show-current # mainブランチであること
|
|
33
|
-
git status --porcelain # 未コミット変更の確認
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
#### 未コミット変更がある場合
|
|
37
|
-
|
|
38
|
-
**AskUserQuestion**で対処方法を確認:
|
|
39
|
-
|
|
40
|
-
- **コミットしてからリリース**: 全ての変更をコミット・プッシュ後にリリース
|
|
41
|
-
- **スタッシュしてリリース**: 変更を一時退避してリリース後に復元
|
|
42
|
-
- **そのままリリース**: 未コミット変更は放置し、**package.jsonのバージョン更新のみ**コミットしてリリース
|
|
43
|
-
|
|
44
|
-
### 2. バージョン種別の決定
|
|
45
|
-
|
|
46
|
-
現在のバージョンと最近の変更を表示後、**AskUserQuestion**で確認:
|
|
47
|
-
|
|
48
|
-
- patch(推奨): バグ修正・軽微な改善
|
|
49
|
-
- minor: 後方互換性のある機能追加
|
|
50
|
-
- major: 破壊的変更
|
|
51
|
-
|
|
52
|
-
### 3. ビルド・テスト
|
|
53
|
-
|
|
54
|
-
```bash
|
|
55
|
-
pnpm -F create-einja-app build
|
|
56
|
-
pnpm -F create-einja-app test
|
|
57
|
-
pnpm -F create-einja-app typecheck
|
|
58
|
-
pnpm -F create-einja-app lint
|
|
59
|
-
```
|
|
60
|
-
|
|
61
|
-
### 4. バージョン更新・コミット・プッシュ
|
|
62
|
-
|
|
63
|
-
**注意**: `npm version` はデフォルトで `v{version}` タグを生成しますが、このワークフローでは `create-einja-app-v{version}` タグが必要です。そのため、タグは手動で作成します。
|
|
64
|
-
|
|
65
|
-
#### 通常パターン(未コミット変更なし)
|
|
66
|
-
|
|
67
|
-
```bash
|
|
68
|
-
# 1. バージョンのみ更新(タグは作成しない)
|
|
69
|
-
npm version {patch|minor|major} --no-git-tag-version --prefix packages/create-einja-app
|
|
70
|
-
|
|
71
|
-
# 2. package.jsonの変更をコミット
|
|
72
|
-
git add packages/create-einja-app/package.json
|
|
73
|
-
git commit -m "chore(create-einja-app): v{version}にバージョンアップ"
|
|
74
|
-
|
|
75
|
-
# 3. 正しい形式のタグを手動作成
|
|
76
|
-
git tag create-einja-app-v{version}
|
|
77
|
-
|
|
78
|
-
# 4. プッシュ
|
|
79
|
-
git push origin main
|
|
80
|
-
git push origin create-einja-app-v{version}
|
|
81
|
-
```
|
|
82
|
-
|
|
83
|
-
#### 未コミット変更ありでそのままリリースする場合
|
|
84
|
-
|
|
85
|
-
```bash
|
|
86
|
-
npm version {patch|minor|major} --no-git-tag-version --prefix packages/create-einja-app
|
|
87
|
-
```
|
|
88
|
-
|
|
89
|
-
**重要**: 未コミット変更は放置し、**package.jsonのみ**をコミット:
|
|
90
|
-
|
|
91
|
-
```bash
|
|
92
|
-
# package.jsonのみステージング
|
|
93
|
-
git add packages/create-einja-app/package.json
|
|
94
|
-
|
|
95
|
-
# バージョン更新のみコミット
|
|
96
|
-
git commit -m "chore(create-einja-app): v{version}にバージョンアップ"
|
|
97
|
-
|
|
98
|
-
# タグ作成(create-einja-app-v形式)
|
|
99
|
-
git tag create-einja-app-v{version}
|
|
100
|
-
|
|
101
|
-
# プッシュ
|
|
102
|
-
git push origin main
|
|
103
|
-
git push origin create-einja-app-v{version}
|
|
104
|
-
```
|
|
105
|
-
|
|
106
|
-
task-committer には委託しない(全変更をコミットしてしまうため)。
|
|
107
|
-
|
|
108
|
-
### 5. GitHub Actions 監視・自律修正
|
|
109
|
-
|
|
110
|
-
タグプッシュ後、GitHub Actions の完了を監視する。
|
|
111
|
-
|
|
112
|
-
#### 5.1 監視ループ
|
|
113
|
-
|
|
114
|
-
```bash
|
|
115
|
-
# 最新のワークフロー実行を取得
|
|
116
|
-
gh run list --workflow=create-einja-app.yml --limit=1 --json databaseId,status,conclusion
|
|
117
|
-
|
|
118
|
-
# 出力例: [{"databaseId":123,"status":"in_progress","conclusion":null}]
|
|
119
|
-
```
|
|
120
|
-
|
|
121
|
-
- `status: in_progress` → 30秒待機して再確認
|
|
122
|
-
- `status: completed, conclusion: success` → 成功、ステップ6へ
|
|
123
|
-
- `status: completed, conclusion: failure` → 失敗、5.2へ
|
|
124
|
-
|
|
125
|
-
#### 5.2 失敗時の原因特定
|
|
126
|
-
|
|
127
|
-
```bash
|
|
128
|
-
gh run view {run_id} --log-failed
|
|
129
|
-
```
|
|
130
|
-
|
|
131
|
-
#### 5.3 原因別の自律修正
|
|
132
|
-
|
|
133
|
-
| 原因 | 対処 |
|
|
134
|
-
|------|------|
|
|
135
|
-
| ビルドエラー | コードを修正 |
|
|
136
|
-
| テストエラー | テストを修正 |
|
|
137
|
-
| NPM_TOKEN エラー | ユーザーに設定確認を依頼して終了 |
|
|
138
|
-
| バージョン重複 | 次のpatchバージョンで再実行 |
|
|
139
|
-
|
|
140
|
-
#### 5.4 修正後の再リリース
|
|
141
|
-
|
|
142
|
-
**重要**: 同じタグ名は使えないため、バージョンを上げて再リリース
|
|
143
|
-
|
|
144
|
-
```bash
|
|
145
|
-
# 1. 修正をコミット
|
|
146
|
-
git add -A
|
|
147
|
-
git commit -m "fix(create-einja-app): CIエラーを修正"
|
|
148
|
-
|
|
149
|
-
# 2. 新しいバージョンに更新
|
|
150
|
-
npm version patch --no-git-tag-version --prefix packages/create-einja-app
|
|
151
|
-
|
|
152
|
-
# 3. バージョン更新をコミット
|
|
153
|
-
git add packages/create-einja-app/package.json
|
|
154
|
-
git commit -m "chore(create-einja-app): v{new_version}にバージョンアップ"
|
|
155
|
-
|
|
156
|
-
# 4. 新しいタグを作成・プッシュ
|
|
157
|
-
git tag create-einja-app-v{new_version}
|
|
158
|
-
git push origin main
|
|
159
|
-
git push origin create-einja-app-v{new_version}
|
|
160
|
-
```
|
|
161
|
-
|
|
162
|
-
#### 5.5 リトライ制限
|
|
163
|
-
|
|
164
|
-
最大3回まで自動リトライ。3回失敗したらユーザーに報告して終了。
|
|
165
|
-
|
|
166
|
-
### 6. 完了報告
|
|
167
|
-
|
|
168
|
-
```markdown
|
|
169
|
-
## 📦 create-einja-app リリース完了
|
|
170
|
-
|
|
171
|
-
### リリース情報
|
|
172
|
-
- **バージョン**: {old} → {new}
|
|
173
|
-
- **タグ**: create-einja-app-v{version}
|
|
174
|
-
|
|
175
|
-
### GitHub Actions
|
|
176
|
-
- **ステータス**: ✅ SUCCESS
|
|
177
|
-
- **URL**: https://github.com/einja-inc/einja-management-template/actions/runs/{run_id}
|
|
178
|
-
|
|
179
|
-
### 確認コマンド
|
|
180
|
-
npm view create-einja-app
|
|
181
|
-
npx create-einja-app --version
|
|
182
|
-
```
|
|
183
|
-
|
|
184
|
-
---
|
|
185
|
-
|
|
186
|
-
**最終更新**: 2025-01-10
|
|
@@ -1,173 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: cli-release
|
|
3
|
-
description: "@einja/cli パッケージをビルド・テストし、NPMに公開するSkill"
|
|
4
|
-
allowed-tools:
|
|
5
|
-
- Bash
|
|
6
|
-
- Read
|
|
7
|
-
- Glob
|
|
8
|
-
- Grep
|
|
9
|
-
- AskUserQuestion
|
|
10
|
-
- TodoWrite
|
|
11
|
-
- TodoRead
|
|
12
|
-
- Task
|
|
13
|
-
- MCPSearch
|
|
14
|
-
---
|
|
15
|
-
|
|
16
|
-
# cli-release Skill: @einja/cli パッケージ公開エンジン
|
|
17
|
-
|
|
18
|
-
## 役割
|
|
19
|
-
|
|
20
|
-
`@einja/cli` パッケージをビルド・テストし、NPMに公開します。
|
|
21
|
-
|
|
22
|
-
## 参照ドキュメント
|
|
23
|
-
|
|
24
|
-
- `packages/cli/RELEASING.md` - 詳細なリリース手順、トラブルシューティング、NPM_TOKEN設定方法
|
|
25
|
-
|
|
26
|
-
## 実行手順
|
|
27
|
-
|
|
28
|
-
### 1. 前提条件の確認
|
|
29
|
-
|
|
30
|
-
```bash
|
|
31
|
-
git branch --show-current # mainブランチであること
|
|
32
|
-
git status --porcelain # 未コミット変更の確認
|
|
33
|
-
```
|
|
34
|
-
|
|
35
|
-
#### 未コミット変更がある場合
|
|
36
|
-
|
|
37
|
-
**AskUserQuestion**で対処方法を確認:
|
|
38
|
-
|
|
39
|
-
- **コミットしてからリリース**: 全ての変更をコミット・プッシュ後にリリース
|
|
40
|
-
- **スタッシュしてリリース**: 変更を一時退避してリリース後に復元
|
|
41
|
-
- **そのままリリース**: 未コミット変更は放置し、**package.jsonのバージョン更新のみ**コミットしてリリース
|
|
42
|
-
|
|
43
|
-
### 2. バージョン種別の決定
|
|
44
|
-
|
|
45
|
-
現在のバージョンと最近の変更を表示後、**AskUserQuestion**で確認:
|
|
46
|
-
|
|
47
|
-
- patch(推奨): バグ修正・軽微な改善
|
|
48
|
-
- minor: 後方互換性のある機能追加
|
|
49
|
-
- major: 破壊的変更
|
|
50
|
-
|
|
51
|
-
### 3. ビルド・テスト
|
|
52
|
-
|
|
53
|
-
```bash
|
|
54
|
-
pnpm --filter @einja/cli build
|
|
55
|
-
pnpm --filter @einja/cli test
|
|
56
|
-
pnpm --filter @einja/cli typecheck
|
|
57
|
-
```
|
|
58
|
-
|
|
59
|
-
### 4. バージョン更新・コミット・プッシュ
|
|
60
|
-
|
|
61
|
-
#### 通常パターン(未コミット変更なし)
|
|
62
|
-
|
|
63
|
-
```bash
|
|
64
|
-
cd packages/cli
|
|
65
|
-
npm version {patch|minor|major}
|
|
66
|
-
git push origin main
|
|
67
|
-
git push origin cli-v{version}
|
|
68
|
-
```
|
|
69
|
-
|
|
70
|
-
#### 未コミット変更ありでそのままリリースする場合
|
|
71
|
-
|
|
72
|
-
```bash
|
|
73
|
-
npm version {patch|minor|major} --no-git-tag-version --prefix packages/cli
|
|
74
|
-
```
|
|
75
|
-
|
|
76
|
-
**重要**: 未コミット変更は放置し、**package.jsonのみ**をコミット:
|
|
77
|
-
|
|
78
|
-
```bash
|
|
79
|
-
# package.jsonのみステージング
|
|
80
|
-
git add packages/cli/package.json
|
|
81
|
-
|
|
82
|
-
# バージョン更新のみコミット
|
|
83
|
-
git commit -m "chore(cli): v{version}にバージョンアップ"
|
|
84
|
-
|
|
85
|
-
# タグ作成
|
|
86
|
-
git tag cli-v{version}
|
|
87
|
-
|
|
88
|
-
# プッシュ
|
|
89
|
-
git push origin main
|
|
90
|
-
git push origin cli-v{version}
|
|
91
|
-
```
|
|
92
|
-
|
|
93
|
-
task-committer には委託しない(全変更をコミットしてしまうため)。
|
|
94
|
-
|
|
95
|
-
### 5. GitHub Actions 監視・自律修正
|
|
96
|
-
|
|
97
|
-
タグプッシュ後、GitHub Actions の完了を監視する。
|
|
98
|
-
|
|
99
|
-
#### 5.1 監視ループ
|
|
100
|
-
|
|
101
|
-
```bash
|
|
102
|
-
# 最新のワークフロー実行を取得
|
|
103
|
-
gh run list --workflow=release-cli.yml --limit=1 --json databaseId,status,conclusion
|
|
104
|
-
|
|
105
|
-
# 出力例: [{"databaseId":123,"status":"in_progress","conclusion":null}]
|
|
106
|
-
```
|
|
107
|
-
|
|
108
|
-
- `status: in_progress` → 30秒待機して再確認
|
|
109
|
-
- `status: completed, conclusion: success` → 成功、ステップ6へ
|
|
110
|
-
- `status: completed, conclusion: failure` → 失敗、5.2へ
|
|
111
|
-
|
|
112
|
-
#### 5.2 失敗時の原因特定
|
|
113
|
-
|
|
114
|
-
```bash
|
|
115
|
-
gh run view {run_id} --log-failed
|
|
116
|
-
```
|
|
117
|
-
|
|
118
|
-
#### 5.3 原因別の自律修正
|
|
119
|
-
|
|
120
|
-
| 原因 | 対処 |
|
|
121
|
-
|------|------|
|
|
122
|
-
| ビルドエラー | コードを修正 |
|
|
123
|
-
| テストエラー | テストを修正 |
|
|
124
|
-
| NPM_TOKEN エラー | ユーザーに設定確認を依頼して終了 |
|
|
125
|
-
| バージョン重複 | 次のpatchバージョンで再実行 |
|
|
126
|
-
|
|
127
|
-
#### 5.4 修正後の再リリース
|
|
128
|
-
|
|
129
|
-
**重要**: 同じタグ名は使えないため、バージョンを上げて再リリース
|
|
130
|
-
|
|
131
|
-
```bash
|
|
132
|
-
# 1. 修正をコミット
|
|
133
|
-
git add -A
|
|
134
|
-
git commit -m "fix(cli): CIエラーを修正"
|
|
135
|
-
|
|
136
|
-
# 2. 新しいバージョンに更新
|
|
137
|
-
npm version patch --no-git-tag-version --prefix packages/cli
|
|
138
|
-
|
|
139
|
-
# 3. バージョン更新をコミット
|
|
140
|
-
git add packages/cli/package.json
|
|
141
|
-
git commit -m "chore(cli): v{new_version}にバージョンアップ"
|
|
142
|
-
|
|
143
|
-
# 4. 新しいタグを作成・プッシュ
|
|
144
|
-
git tag cli-v{new_version}
|
|
145
|
-
git push origin main
|
|
146
|
-
git push origin cli-v{new_version}
|
|
147
|
-
```
|
|
148
|
-
|
|
149
|
-
#### 5.5 リトライ制限
|
|
150
|
-
|
|
151
|
-
最大3回まで自動リトライ。3回失敗したらユーザーに報告して終了。
|
|
152
|
-
|
|
153
|
-
### 6. 完了報告
|
|
154
|
-
|
|
155
|
-
```markdown
|
|
156
|
-
## 📦 @einja/cli リリース完了
|
|
157
|
-
|
|
158
|
-
### リリース情報
|
|
159
|
-
- **バージョン**: {old} → {new}
|
|
160
|
-
- **タグ**: cli-v{version}
|
|
161
|
-
|
|
162
|
-
### GitHub Actions
|
|
163
|
-
- **ステータス**: ✅ SUCCESS
|
|
164
|
-
- **URL**: https://github.com/einja-inc/einja-management-template/actions/runs/{run_id}
|
|
165
|
-
|
|
166
|
-
### 確認コマンド
|
|
167
|
-
npm view @einja/cli
|
|
168
|
-
npx @einja/cli --version
|
|
169
|
-
```
|
|
170
|
-
|
|
171
|
-
---
|
|
172
|
-
|
|
173
|
-
**最終更新**: 2025-01-10
|