質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

マージ

複数のデータベースやファイル、プログラムなどを決まった手順や規則に従って一つに結合すること。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

解決済

1回答

1005閲覧

GitHubチーム開発 プルリクエスト間の依存性がある場合、どうするのが良いのか。

Kchan_01

総合スコア110

Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

マージ

複数のデータベースやファイル、プログラムなどを決まった手順や規則に従って一つに結合すること。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

2クリップ

投稿2021/08/28 04:06

編集2021/08/28 04:10

チーム開発で、GitHubを使い始めました。

主な開発手法

2人で開発しており、mainブランチに対して、issueごとにブランチを切って、プルリクエストを投げ、お互いのコードをレビューしあって、コードの品質を保証するというやり方をしています。

プルリクエストが承認された場合、各開発ブランチはmainをrebaseで取り込むということを行い、mainとの差分を適切なものに維持します。

起きている問題

プルリクエスト間の依存性

mainへのマージにはレビューが必須なため、片方がレビューが遅れるとプルリクエストが溜まってしまい、以前投げたプルリクエストの変更に依存性があるプルリクエストが発生することになりました。

試した方法

この場合、依存性のあるブランチに対して、プルリクエストを投げるというやり方で、直接mainに対してプルリクエストを投げないようにし、1つめのブランチと差分もGitHub上で見れるようするという解決方法を取りました。

しかし、そうすると、1つ目のプルリクエストで修正があった場合、後ろに続くプルリクエストでコンフリクトが多発するようになり、レビューの効率が大きく下がりました。

質問内容

このような状況では、プルリクエスト間で依存性があるものを開発する場合、手前のプルリクエストが承認されるのを待つ。というのが正しいのでしょうか。

他によい管理方法があれば教えていただきたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Zuishin

2021/08/28 04:12

ボトルネックがあるのであればそこのレビューを最優先で終わらせる他ないと思いますが、開発する人を一人レビューに回せばいいのではないでしょうか。
Kchan_01

2021/08/28 04:28

自分で投げたプルリクエストに対して、自分でレビューをするということでしょうか。セルフレビューはプルリクエストを投げる際に行っているので、その方法を取ってしまうと、レビューを挟んでいる意味がなくなります。
Zuishin

2021/08/28 04:31

一人が開発をやめてレビューに専念するということです。
Kchan_01

2021/08/28 04:33

プルリクエストを優先していますが、それでも多忙でこのような状況が起きているという前提です。 つまりレビューが開発スピードのボトルネックになっているという状況です。
Zuishin

2021/08/28 04:37

一人が暇で開発しすぎて忙しい方のレビューが追いつかないということですか? どちらもレビューできるのであれば、速い方がレビュー専門になれば片付くと思います。 人を増やすのが根本な解決になるとは思いますが。
guest

回答1

0

ベストアンサー

、1つ目のプルリクエストで修正があった場合、後ろに続くプルリクエストでコンフリクトが多発するようになり

それは案件の切り分け方が適切ではないからです。同じファイルをいじらないようにするのがベストですが、それも難しい場合は極めて細かい単位(数commitごと)で後ろに続くプルリクエストをmergeし続けることで緩和できます。この場合は大本のPRのレビューを関係者全員でレビューし直してmergeしたほうがいいでしょう。

投稿2021/08/28 07:44

yumetodo

総合スコア5850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問