У меня есть следующий сценарий:
3 филиала:
- Мастер
- MyBranch получил ответвление от Master с целью разработки новой функции системы
- MyBranchLocal разветвил MyBranch как мою локальную копию ветви
MyBranch перебирается и подталкивается другими разработчиками (которые работают над той же функцией, что и я).
Как владелец ветки MyBranch, я хочу синхронизировать ее с Master, выполняя ребазинг. Мне также нужно объединить изменения, которые я делаю, с MyBranchLocal с MyBranch.
Какой хороший способ сделать это?
Пара возможных сценариев, которые я пробовал до сих пор:
I.
1. Подтвердите изменение в MyBranchLocal
2. Перепроверьте MyBranch против Master
3. Перепроверьте MyBranchLocal против MyBranch
4. Объедините MyBranch с MyBranchLocal
II.
1. Подтвердите изменение в MyBranchLocal
2. Объедините MyBranch с MyBranchLocal
3. Перепроверьте MyBranch против Master
4. Перебазируйте MyBranchLocal против MyBranch
III.
1. Подтвердите изменение в MyBranchLocal
2. Перепроверьте MyBranch против Master
3. Объедините MyBranch с MyBranchLocal
4. Перебазируйте MyBranchLocal против MyBranch
Я уже знаю, что сценарий III, похоже, сильно портит историю коммитов, потенциально дублируя коммиты.
Какой у вас опыт? Какие сценарии вы рекомендуете минимизировать слияние и сохранить историю в чистоте?