Git - Do you know how to avoid large PRs?
Last updated by Brady Stroud [SSW] 7 months ago.See historyNobody wants to review a PR with 100s of files, nor is it nice to have a lot of work that is committed (a PR may even be waiting), but not approved. This is merge debt. Part of getting work complete is getting the PR approved by another developer so you don’t have it sitting around for a long time.
The default option is to use a feature branch strategy which is awesome for small chunks of work. However, if you know that your work involves 2+ devs working on different tasks and they cannot work in isolation, then it can be tricky. For example, if you need to migrate from Gatsby to Next.js or if you have to upgrade from Xamarin to .NET MAUI then a feature branch strategy might not be appropriate. In that case choose from the below options:
Option 1 - Create a new repository
This is a good option if you are concerned with legacy technical decisions impacting the future application.
✅ Pros
- Clean snapshot of legacy application
- No risk of the legacy application being used or referenced
- Isolated backlog – keep issues about the new project separated
❌ Cons
- Loss of history in one mono repo
- Isolated backlog – cannot see old feature or bug requests
- Have to migrate important issues later
Option 2 – Create a new folder and keep merging using small PRs
In this scenario you will be replacing the old project (folder) at the end for a final rubber stamp PR
This is a good option if you are not worried about the legacy application influencing the new application.
✅ Pros
- Keeps history of previous iteration in one repo
- Sharing the same backlog – can see both old and new PBIs
- Can clearly see the difference after the final PR
❌ Cons
- Potential to reference or use old code/models
- Must implement bug fixes for the new + the old project
- Easier to be influenced by past legacy decisions
- Sharing the same backlog – can see both old and new PBIs