に依存しています。アリスと私はリポジトリをクローンして変更を加えました。アリスは彼女の変更をコミットし、リモートにプッシュします。私はその変更を取り出して、それを私のものとマージします。 Aliceは最新のコミットで、Vehicleというクラスを削除したと想像してください。私は順番に、Vehicleクラスを拡張したCarという新しいクラスを追加しました。今、私が自分のコミットを私のものに合併するとき、明らかに問題になるでしょう。 これは、マージする前にコードを調べてテストする必要があるということですか? (おそらくそうだ)。この状況での一般的な慣習は何ですか?コードを削除したコミットをマージするとどうなりますか?私の新しい機能は
1
A
答えて
1
これは、コードを調べてマージする前にテストする必要があるということですか? (おそらくそうだ)。
マージの後にコードを調べる必要があります。 は、マージする前に他の開発者のブランチを調べてください。 しかしそれはあまり便利ではありません。
この状況での一般的な対応は何ですか?
マージ後、プロジェクトを再構築してすべてのテストを再実行する必要があります。 マージ中に依存するクラスが削除された場合は、 コンパイル済みの言語でコンパイルエラーが発生します。 翻訳された言語では、影響を受けるコードをカバーするテストケースがあることが望ましいので、自動テストを再実行すると問題が明らかになります。 問題が検出されたら、 がマージされたものを調べて、他の開発者とその理由を質問することができます。
コミュニケーションが良好で、タスクが良好に分かれているチームで、 実装の変更にこのような論理的な競合があってはならないことを望みます。
関連する問題
- 1. Git - 機能ブランチをマージする方法はありますが、コミットをいくつか除外しますか?
- 2. メインブランチにマージされたコミットを削除します
- 3. 後でコミットしたままで、悪いコミットを削除するにはどうすればよいですか?
- 4. 要素値に基づいて重複したペアレントを削除しようとするXSLTの新機能です。しかし、子をマージしたい
- 5. SVNのマージと更新はどのように機能しますか?
- 6. 「無料/削除」はどのように機能しますか?
- 7. 「削除」はどのようにjavascriptで機能しますか?
- 8. リストをマージした後に機能を構成するコミット
- 9. Github - ユーザーが削除された場合のコミットはどうなりますか?
- 10. 私のレポのgithubからコミットを削除するにはどうしたらいいですか?
- 11. TableAdapterの更新と削除コマンドはどうなりましたか?
- 12. gitから切り離されたコミットを削除するにはどうしたらいいですか?
- 13. RecyclerViewから項目を削除するとうまく機能しない
- 14. どのようにPHPで新しい行コード( )を削除しますか?
- 15. は、私はこれを自動的に行い機能を実装しようとした削除機能
- 16. GitHubは私の前のコミットを削除しました
- 17. Git - マージされたブランチで新しいコミット - これらの新しいコミットをマージする方法?
- 18. PHPの更新と削除の機能が動作しない
- 19. 削除、機能の削除は動作していないようです
- 20. コミット署名はどのように機能しますか?
- 21. 古いコミット(つまり、すでにマージされたコミット)を確認することは可能ですか?
- 22. Gitが削除されました/削除コミットなしですでにマージされたファイルを削除しました
- 23. SourceTree - プッシュされたマージされたコミットを削除する
- 24. Hbaseテーブルを削除したときのデータはどうなりますか?
- 25. エントリを削除するとPHPのarray_searchが機能しない
- 26. vector.layerの機能を削除または削除する
- 27. プッシュされたコミットを削除して古いコミットに戻すにはどうすればよいですか?
- 28. アプリを削除するとPendingIntentsはどうなりますか?
- 29. TFS:ファイルを移動したのではなく、削除して再追加した後にマージ機能を復元する方法はありますか
- 30. UITabBar行が機能しないのを削除します。
ストーリーのバージョンが保持されている場合、マージ後に 'Vehicle'クラスが削除されないことに注意してください。しかし、「Vehicle」_Does_が削除されていると仮定すると、問題が発生します。これに対する解決策は、あなたとアリスが開発プロセス中にお互いにコミュニケーションすることです。 Gitがあなたのために設計上の意思決定をする必要があるときには、私はすでにそれが遅すぎると考えます。 –
@TimBiegeleisen、 "物語のバージョンが保持されるものであれば、Vehicleクラスはマージ後に削除されないことに注意してください。"しかし、変更は常に追加に関するものではありません。それは時々不必要なものを取り除くことです、そうではありませんか? Gitは、Vehicleクラスが必要か冗長かどうかをどのように決定しますか? –
Gitが使用する正確なルールは実際には分かりませんが、私はそれが両方向に進むことを見ました。つまり、「Vehicle」が削除されて保持されているのを見たことがあります。私の要点は、Gitに頼ってこのようなソフトウェア設計の決定を下すべきではないということでした。アリスとちょうど話してください。 –