AgentSkillsCN

create-einja-app-release

负责构建并测试 create-einja-app 软件包,随后将其发布至 NPM 的技能。适用于需要发布、上线并公开 create-einja-app 时使用。

SKILL.md
--- frontmatter
name: create-einja-app-release
description: "create-einja-app パッケージをビルド・テストし、NPMに公開するSkill。create-einja-appの公開、リリース、publishが必要な場合に使用。"
user-invocable: true
allowed-tools:
  - Bash
  - Read
  - Glob
  - Grep
  - AskUserQuestion
  - TodoWrite
  - TodoRead
  - Task
  - MCPSearch

create-einja-app-release Skill: create-einja-app パッケージ公開エンジン

役割

create-einja-app パッケージをビルド・テストし、NPMに公開します。

参照ドキュメント

  • packages/create-einja-app/RELEASING.md - 詳細なリリース手順、トラブルシューティング、NPM_TOKEN設定方法

実行手順

1. 前提条件の確認

bash
git branch --show-current    # mainブランチであること
git status --porcelain       # 未コミット変更の確認

未コミット変更がある場合

AskUserQuestionで対処方法を確認:

  • コミットしてからリリース: 全ての変更をコミット・プッシュ後にリリース
  • スタッシュしてリリース: 変更を一時退避してリリース後に復元
  • そのままリリース: 未コミット変更は放置し、package.jsonのバージョン更新のみコミットしてリリース

2. バージョン種別の決定

現在のバージョンと最近の変更を表示後、AskUserQuestionで確認:

  • patch(推奨): バグ修正・軽微な改善
  • minor: 後方互換性のある機能追加
  • major: 破壊的変更

3. ビルド・テスト

bash
pnpm -F create-einja-app build
pnpm -F create-einja-app test
pnpm -F create-einja-app typecheck
pnpm -F create-einja-app lint

4. バージョン更新・コミット・プッシュ

注意: npm version はデフォルトで v{version} タグを生成しますが、このワークフローでは create-einja-app-v{version} タグが必要です。そのため、タグは手動で作成します。

通常パターン(未コミット変更なし)

bash
# 1. バージョンのみ更新(タグは作成しない)
npm version {patch|minor|major} --no-git-tag-version --prefix packages/create-einja-app

# 2. package.jsonの変更をコミット
git add packages/create-einja-app/package.json
git commit -m "chore(create-einja-app): v{version}にバージョンアップ"

# 3. 正しい形式のタグを手動作成
git tag create-einja-app-v{version}

# 4. プッシュ
git push origin main
git push origin create-einja-app-v{version}

未コミット変更ありでそのままリリースする場合

bash
npm version {patch|minor|major} --no-git-tag-version --prefix packages/create-einja-app

重要: 未コミット変更は放置し、package.jsonのみをコミット:

bash
# package.jsonのみステージング
git add packages/create-einja-app/package.json

# バージョン更新のみコミット
git commit -m "chore(create-einja-app): v{version}にバージョンアップ"

# タグ作成(create-einja-app-v形式)
git tag create-einja-app-v{version}

# プッシュ
git push origin main
git push origin create-einja-app-v{version}

task-committer には委託しない(全変更をコミットしてしまうため)。

5. GitHub Actions 監視・自律修正

タグプッシュ後、GitHub Actions の完了を監視する。

5.1 監視ループ

bash
# 最新のワークフロー実行を取得
gh run list --workflow=create-einja-app.yml --limit=1 --json databaseId,status,conclusion

# 出力例: [{"databaseId":123,"status":"in_progress","conclusion":null}]
  • status: in_progress → 30秒待機して再確認
  • status: completed, conclusion: success → 成功、ステップ6へ
  • status: completed, conclusion: failure → 失敗、5.2へ

5.2 失敗時の原因特定

bash
gh run view {run_id} --log-failed

5.3 原因別の自律修正

原因対処
ビルドエラーコードを修正
テストエラーテストを修正
NPM_TOKEN エラーユーザーに設定確認を依頼して終了
バージョン重複次のpatchバージョンで再実行

5.4 修正後の再リリース

重要: 同じタグ名は使えないため、バージョンを上げて再リリース

bash
# 1. 修正をコミット
git add -A
git commit -m "fix(create-einja-app): CIエラーを修正"

# 2. 新しいバージョンに更新
npm version patch --no-git-tag-version --prefix packages/create-einja-app

# 3. バージョン更新をコミット
git add packages/create-einja-app/package.json
git commit -m "chore(create-einja-app): v{new_version}にバージョンアップ"

# 4. 新しいタグを作成・プッシュ
git tag create-einja-app-v{new_version}
git push origin main
git push origin create-einja-app-v{new_version}

5.5 リトライ制限

最大3回まで自動リトライ。3回失敗したらユーザーに報告して終了。

6. 完了報告

markdown
## 📦 create-einja-app リリース完了

### リリース情報
- **バージョン**: {old} → {new}
- **タグ**: create-einja-app-v{version}

### GitHub Actions
- **ステータス**: ✅ SUCCESS
- **URL**: https://github.com/einja-inc/einja-management-template/actions/runs/{run_id}

### 確認コマンド
npm view create-einja-app
npx create-einja-app --version

最終更新: 2025-01-10