0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【GitHub】GitHubのプルリクエストテンプレートを作ってくれと言われる前に知っておくべきこと

Last updated at Posted at 2025-01-27

※2025年1月27日にアドベントカレンダーとして登録

この記事のポイント

  • プルリクエストとは何かについて説明しているよ
  • GitHubのプルリクエストテンプレートについて書いているよ
  • GitHubのプルリクエストテンプレートにはさまざまな作り方があるよ

はじめに

この記事では以下の記事を参考に基本的なプルリクエストテンプレートの作り方について説明しています。

参考:リポジトリ用のプルリクエストテンプレートの作成 - GitHub Docs

さまざまな作り方があるため、その中でも基本となる作り方についてついて見ていきます。ひょっとすると「そこから解説するのか」と記事を読み始めると思いますが、入門みたいなところがあるのでご容赦ください。

そもそもプルリクエスト(プルリク)とは

本題の前にプルリクエストとはなんでしょうか。よくエンジニア同士の会話で「それ、プルリク送っといて」あるいは「プルリク作っておいて」という感じで言葉が飛び交います。このプルリクという言葉は簡単に説明すると変更要望または修正提案のことです。

由来はきっと諸説あるとは思いますが、実際のところ言葉通りではあると思います。
成果物をPull(引用)して変更をRequest(要求)するというニュアンスが個人的にはしっくりきます。(Forkというアクションを考慮しても)

ちなみに実務においてはPRと訳されることが多いです。(多いってかもはやそれが普通ですらあります。)
なお、GitHub以外でもプルリクという言葉は使われることがあります。

余談:マージリクエスト(マジリクと言ってる人もいる)

GitHubにおいては変更要望または修正提案のことをプルリクエストと呼称しますが、GitLabではマージリクエスト(マジリク)と読んだりします。少なくともGitHubを使っている場合においてはマージリクエストという言葉は使いません。

もっと詳しく知りたい方は以下のリンクをチェックしていただければと思います。

マージリクエスト | GitLab

ちなみにお気づきの人もいるとは思いますが、略称はMRです。GitLab公式でもMRと省略されています。

プルリク、どういうときに使う

たとえば、以下のようなときに使います。

  • バグを修正する(バグフィックス)
  • 機能を追加・削除

他にもリポジトリによってはサービスのロードマップ管理として使われることがあります。
私がQiitaでよく紹介しているAWSはサービスの追加要望をGitHubで管理していたりします。
※たとえば、AWS AmplifyなどはGitHubで管理されています。

ともかくプルリクは主に機能の管理に使われることが多いです。

プルリクエストテンプレートとは

ではプルリクエストテンプレートとはなんでしょうか。
プルリクは変更要望を送るものなので文面で自身の要求を伝える必要がありますが、自由に記載されてもリポジトリのオーナーあるいはプルリクをレビューする人が困ってしまいます。

つまり、プルリクエストテンプレートとは簡単に説明すると変更要望を送るときのフォーマットです。

プルリクエストテンプレートはどう作ればいい

  • リポジトリのルートディレクトリにテンプレートをおく
  • リポジトリ内にdocsディレクトリを作ってテンプレートをおく
  • リポジトリ内に.githubディレクトリを作ってテンプレートをおく

他にも.githubdocsディレクトリ内でフォルダを作成してプルリクエストテンプレートを用途によって分けたり、クエリ文字列(URLの?から後ろの文字列、クエリパラメータ)で制御することもできます。

作り方の使い分け

作り方が複数あるとわかったところでどう使い分けていけば良いでしょうか。ここでは個人の見解レベルでそれぞれのプルリクエストテンプレートの作り方についてどういうときに利用できるかを見ていきます。

リポジトリのルートディレクトリにテンプレートをおく

一番最初に思いつく方法でもっともシンプルな方法です。pull_request_template.mdという名前でリポジトリに保存します。pull_request_template.mdという名前で保存するので複数のテンプレートを保存できません。

スクリーンショット 2025-01-17 6.51.27.png

リポジトリ内にdocsディレクトリを作ってテンプレートをおく

ルートディレクトリに置かず、docsフォルダにテンプレートを置きます。フォルダが変わっただけでこの方法においても置けるテンプレートは1つだけです。
pull_request_template.mdという名前で保存するため

スクリーンショット 2025-01-17 6.52.02.png

フォルダを切っておくことでだいぶ整理された形になると思います。

リポジトリ内に.githubディレクトリを作ってテンプレートをおく

この方法はプルリクエストテンプレートを隠しフォルダに保存します。docsフォルダと異なるのは隠すところであり、この場合においてもpull_request_template.mdという名前で保存するため、置けるテンプレートは1つだけです。

(とはいえ、実際のところ隠しフォルダを表示する設定にしている人にはだいだいが見えているので隠しきれていない)

スクリーンショット 2025-01-17 6.51.19.png

この方法においてはクエリパラメータを使ってテンプレートを変えることも可能です。

まとめ

今回はGitHubのプルリクエストテンプレートを作る方法について確認しました。
ISSUEテンプレートにさまざまな作り方があることは知っていたんですが、プルリクエストテンプレートの作り方は知りませんでした。

(とはいえ、有名なOSSのソースコードを読んでいると複数の作り方があることに気づく。)

他にもプルリクエストを送るためのURLに対して決まった形式でクエリ文字列を送ると
決まった形でテンプレートが作成できます。うまく活用していきましょう。

0
2
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
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?