スキル一覧に戻る

create-github-issues

pjt222
更新日 Yesterday
1 閲覧
17
2
17
GitHubで表示
メタdesign

について

このスキルは、コードレビューの指摘事項やタスクリストから構造化されたGitHubイシューを自動生成します。関連する項目をグループ化し、ラベルを適用し、要約・指摘事項・受け入れ基準を含むフォーマットでイシューを作成します。`review-codebase`のようなレビュースキルの出力を処理し、イシュートラッキングを効率化するように設計されています。

クイックインストール

Claude Code

推奨
メイン
npx skills add pjt222/agent-almanac -a claude-code
プラグインコマンド代替
/plugin add https://github.com/pjt222/agent-almanac
Git クローン代替
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/create-github-issues

このコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします

ドキュメント

Create GitHub Issues

Structured GitHub issue creation from review findings or task breakdowns. Converts a list of findings (from review-codebase, security-audit-codebase, or manual analysis) into well-formed GitHub issues with labels, acceptance criteria, and cross-references.

When to Use

  • After a codebase review produces a findings table that needs tracking
  • After a planning session identifies work items that should become issues
  • When converting a TODO list or backlog into trackable GitHub issues
  • When batch-creating related issues that need consistent formatting and labeling

Inputs

  • Required: findings — a list of items, each with at minimum a title and description. Ideally also includes: severity, affected files, and suggested labels
  • Optional:
    • group_by — how to batch findings into issues: severity, file, theme (default: theme)
    • label_prefix — prefix for auto-created labels (default: none)
    • create_labels — whether to create missing labels (default: true)
    • dry_run — preview issues without creating them (default: false)

Procedure

Step 1: Prepare Labels

Ensure all needed labels exist in the repository.

  1. List existing labels: gh label list --limit 100
  2. Identify labels needed by the findings (from severity, phase, or explicit label fields)
  3. Map severities to labels if not already mapped: critical, high-priority, medium-priority, low-priority
  4. Map phases/themes to labels: security, architecture, code-quality, accessibility, testing, performance
  5. If create_labels is true, create missing labels: gh label create "name" --color "hex" --description "desc"
  6. Use consistent colors: red for critical/security, orange for high, yellow for medium, blue for architecture, green for testing

Got: All labels referenced by findings exist in the repository. No duplicate labels created.

If fail: If gh CLI is not authenticated, instruct the user to run gh auth login. If label creation is denied (insufficient permissions), proceed without creating labels and note which labels are missing.

Step 2: Group Findings

Batch related findings into logical issues to avoid issue sprawl.

  1. If group_by is theme: group findings by their phase or category (all security findings → 1-2 issues, all a11y → 1 issue)
  2. If group_by is severity: group findings by severity level (all CRITICAL → 1 issue, all HIGH → 1 issue)
  3. If group_by is file: group findings by primary affected file
  4. Within each group, order findings by severity (CRITICAL first)
  5. If a group has more than 8 findings, split into sub-groups by sub-theme
  6. Each group becomes one GitHub issue

Got: A set of issue groups, each containing 1-8 related findings. The total number of issues should be manageable (typically 5-15 for a full codebase review).

If fail: If findings have no grouping metadata, fall back to one issue per finding. This is acceptable for small finding sets (< 10) but produces too many issues for larger sets.

Step 3: Compose Issues

Build each issue using a standard template.

  1. Title: [Severity] Theme: Brief description — e.g., [HIGH] Security: Eliminate innerHTML injection in panel.js
  2. Body structure:
    ## Summary
    One-paragraph overview of what this issue addresses and why it matters.
    
    ## Findings
    1. **[SEVERITY]** Finding description (`file.js:line`) — brief explanation
    2. **[SEVERITY]** Finding description (`file.js:line`) — brief explanation
    
    ## Acceptance Criteria
    - [ ] Criterion derived from finding 1
    - [ ] Criterion derived from finding 2
    - [ ] All changes pass existing tests
    
    ## Context
    Generated from codebase review on YYYY-MM-DD.
    Related: #issue_numbers (if applicable)
    
  3. Apply labels: severity label + theme label + any custom labels
  4. If findings reference specific files, mention them in the body (not as assignees)

Got: Each issue has a clear title, numbered findings with severity badges, checkbox acceptance criteria, and appropriate labels.

If fail: If the body exceeds GitHub's issue size limit (65536 chars), split the issue into parts and cross-reference them.

Step 4: Create Issues

Create the issues using gh CLI and report results.

  1. If dry_run is true, print each issue title and body without creating, then stop
  2. For each composed issue, create it:
    gh issue create --title "title" --body "$(cat <<'EOF'
    body content
    EOF
    )" --label "label1,label2"
    
  3. Record the URL of each created issue
  4. After all issues are created, print a summary table: #number | Title | Labels | Findings count
  5. If issues should be sequenced, add cross-references: edit the first issue to mention "Blocked by #X" or "See also #Y"

Got: All issues created successfully. A summary table with issue numbers and URLs is printed.

If fail: If an individual issue fails to create, log the error and continue with remaining issues. Report failures at the end. Common failures: authentication expired, label not found (if create_labels was false), network timeout.

Validation

  • All findings are represented in at least one issue
  • Each issue has at least one label
  • Each issue has checkbox acceptance criteria
  • No duplicate issues were created (check titles against existing open issues)
  • Issue count is reasonable for the finding count (not 1:1 for large sets)
  • Summary table was printed with all issue URLs

Pitfalls

  • Issue sprawl: Creating one issue per finding produces 20+ issues that are hard to manage. Group aggressively — 5-10 issues from a full review is ideal
  • Missing acceptance criteria: Issues without checkboxes cannot be verified as complete. Every finding should map to at least one checkbox
  • Label chaos: Creating too many labels makes filtering useless. Stick to severity + theme, not per-finding labels
  • Stale references: If creating issues from an old review, verify findings still apply before creating issues. Code may have changed
  • Forgetting dry run: For large finding sets, always preview with dry_run: true first. It is much easier to edit a plan than to close 15 incorrect issues

Related Skills

  • review-codebase — produces the findings table this skill consumes
  • review-pull-request — produces PR-scoped findings that can also be converted to issues
  • manage-backlog — organizes issues into sprints and priorities after creation
  • create-pull-request — creates PRs that reference and close the issues
  • commit-changes — commits the fixes that resolve the issues

GitHub リポジトリ

pjt222/agent-almanac
パス: i18n/caveman-lite/skills/create-github-issues
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

関連スキル

content-collections

メタ

このスキルは、Content Collections(Markdown/MDXファイルを型安全なデータコレクションに変換するTypeScriptファーストのツール)の本番環境でテストされた設定を提供します。Zodバリデーションによる型安全性を実現し、ブログ、ドキュメントサイト、コンテンツ重視のVite + Reactアプリケーション構築時にご利用ください。Viteプラグインの設定、MDXコンパイルから、デプロイ最適化、スキーマバリデーションまで、すべてを網羅しています。

スキルを見る

polymarket

メタ

このスキルは、開発者がPolymarket予測市場プラットフォームを活用したアプリケーション構築を可能にします。API統合による取引や市場データの取得に加え、WebSocketを介したリアルタイムデータストリーミングにより、ライブ取引や市場活動を監視できます。取引戦略の実装や、ライブ市場更新を処理するツールの作成にご利用ください。

スキルを見る

creating-opencode-plugins

メタ

このスキルは、開発者がコマンド、ファイル、LSP操作など25種類以上のイベントタイプにフックするOpenCodeプラグインを作成することを支援します。JavaScript/TypeScriptモジュール向けに、プラグイン構造、イベントAPI仕様、および実装パターンを提供します。カスタムイベント駆動ロジックでOpenCode AIアシスタントのライフサイクルをインターセプト、監視、または拡張する必要がある場合にご利用ください。

スキルを見る

sglang

メタ

SGLangは、高性能なLLMサービングフレームワークであり、RadixAttentionプレフィックスキャッシュを活用したJSON、正規表現、エージェントワークフロー向けの高速で構造化された生成を特長とします。特にプレフィックスが繰り返されるタスクにおいて、大幅に高速な推論を実現し、複雑な構造化出力やマルチターン対話に最適です。制約付きデコードが必要な場合や、広範なプレフィックス共有を伴うアプリケーションを構築する場合は、vLLMなどの代替案ではなくSGLangを選択してください。

スキルを見る