LoginSignup
0
0

More than 1 year has passed since last update.

最初のcommitでテンプレートに沿ってPull Requestのコメントをほぼ一発で書き上げるには

Last updated at Posted at 2021-08-21

:warning: はじめに

記事を書きましたが、同じことはhubのpull-requestコマンドでできます (あとから知った)
なので「あえて手動でやってみるなら」というのに興味がある方は見て下さい。


概要

GitHubの仕様で「マージ先との差が1commitの場合に限りPull Requestのタイトルとコメントをcommitメッセージから自動入力してくれる」というものがあります。
commitメッセージの1行目がタイトルに、3行目移行がコメントにそれぞれ対応しています。
これを利用し「ブランチ作成時に空commitを作ってGitHubへpushしそのままPull Requestを作成する」という運用をしている方は多いかと思います。

COMMIT_EDITMSG
1行目はPull Requestのタイトルになる

3行目以降は
Pull Requestのコメントになるので
ここをPull Request Templateで埋めたい

一方commitメッセージの1行目は書いても、3行目以降でコメントまで書いてからpushするという方はあまり多くないのではないでしょうか。
そこで今回、少しだけgitに設定を加えることで、ローカルでテンプレートに沿ってPull Requestを書き上げ、Web上ではボタンクリック1発でほぼ完成させられるようにしてみました。 (「ほぼ」の理由は最後に記載してます)
個人的にはそれなりに便利になったと思ったのでやり方を紹介します。

設定方法

今回設定で使用したのは以下の機能です、順を追って説明します。

  • commit template
  • git config alias
  • git config core.commentchar

gitのcommit template機能

gitでは、commit時にテンプレートファイルを指定することができます。
指定の方法にはgit configに書き込む方法と、commit時に -t オプションを渡す方法があります。
それぞれの違いは下記の通りで、前者だとテンプレートはグローバルまたはリポジトリ内で固定、後者はcommit毎にテンプレートを指定できます。

設定方法 有効範囲 指定タイミング
git config —global commit.template 全リポジトリ 固定
git config —local commit.template 現在のリポジトリ 固定
git commit -t path/to/template 現在のリポジトリ commit毎

今回の要件は「初回のcommitのみ」テンプレートが必要なので git commit -t を使うことにします。
オプションの引数にテンプレートファイルのパスを指定すると、内容がcommitメッセージに反映されます。
もしGitHubに PULL_REQUEST_TEMPLATE.md が存在するならそれを指定すればよいわけです。

git commit -t path/to/repo/.github/PULL_REQUEST_TEMPLATE.md

こうするとGitHubと同じテンプレートでcommitメッセージに書き込むことができます。

git aliasで楽にする

とはいえ、このパスを含めたコマンドを毎回手入力するのは大変です。
そこでgit aliasで新しいコマンドを設定します。
今回は git ct というコマンドでできるよう .gitconfig に追記します。

ctコマンドを設定
[alias]
  ct = !"git commit -t ./.github/PULL_REQUEST_TEMPLATE.md"

これでも動作はしますが、さらに以下を加えてみます。

  • 現在のリポジトリのルートを git rev-parse --show-toplevel で動的に取得し、任意のリポジトリかつルート以外でも実行可能にする。
  • テンプレートファイルの存在を判定し、存在しない場合はエラーメッセージを表示。
判定も加えたバージョン
[alias]
  ct = !"TEMPLATE_PATH=$(git rev-parse --show-toplevel)/.github/PULL_REQUEST_TEMPLATE.md; if [ -e ${TEMPLATE_PATH} ]; then git commit -t ${TEMPLATE_PATH} ; else echo "PULL_REQUEST_TEMPLATE.md is not defined so commit aborted."; fi"

commitメッセージでmarkdownを使えるようにする

これでテンプレートをcommitメッセージに流し込めるようになりましたが、commitメッセージで # はコメントを表す識別子になるため、markdownのヘッダーはコメントとして扱われてしまいます。
例えばPull Request Templateが以下のようになっている場合、TODOやMEMOの行はコメントと認識されて消えてしまいます :sweat:

PULL_REQUEST_TEMPLATE.md
# 概要

## TODO <- コメントとしてメッセージから消える

- [ ]

## MEMO <- コメントとしてメッセージから消える

- 

そこで再びgit configで、コメント識別子を # 以外(今回は ; )に変更してみます。
これは git config core.commentchar で変更することができます。

[core]
  commentchar       = ";"

こうすることでmarkdown記法とバッティングしなくなるので、これで無事テンプレートを使ってcommitメッセージを書くことができるようになりました!
ただテンプレートは1行目から始まってしまうので頭で改行は必要です 💦

COMMIT_EDITMSG
# 概要

## TODO

- [ ]

## MEMO

- 
; Please enter the commit message for your changes. Lines starting
; with ';' will be ignored, and an empty message aborts the commit.
;
; On branch master
; Your branch is up to date with 'origin/master'.
;
; Changes to be committed:
;   modified:   Brewfile
;

デモ

最後に実際のデモです。
さすがにファイルアップロードはローカルではできませんが、テキストであればローカルで書き上げることができますね!
コミットメッセージにこのような情報を書くということ自体が良いことかという議論はありますが、秘匿情報等が入っていなければ問題ないのかなと個人的には思います。

output.gif

こうしてPull Requestを作ると

image.png

うまく行った :exclamation:

惜しいところ

... と言いたいところですが、よく見ると残念ながら元のPull Request Templateが二重に入ってしまいます :sob:
こちらはPRを作成するときにクエリパラメータで template=null のような無効なテンプレート指定をすると弾くこともできますが、ひとまずは手動でコメントを消しています。

ローカルでPull Requestを書き上げた方は、ぜひやってみてください :exclamation:

参考資料

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0