Azure DevOps - Pull Request Git "Next steps: Manually resolve these conflicts and push new changes to the source branch."

GitAzure Devops

Git Problem Overview


I have created a branch named dev.

I have done a pull request to send dev code to master, when I do this pull request it tell me: enter image description here

50+ conflicts prevent automatic merging "Next steps: Manually resolve these conflicts and push new changes to the source branch."

Where do I go from here? I just want all the dev branch to replace whatever is in master. I see no options to resolve these conflicts.

Git Solutions


Solution 1 - Git

You will have to do the following on your PC

On branch dev

$ git pull --no-rebase origin master - This will create a merge commit and you will have to resolve the conflicts in the files which are changed both on dev and master. git status will show the list of files with conflicting changes.

After resolving conflicts, commit all the changes and push your branch. After that you should be able to complete the PR.

FYI: --no-rebase makes sure that a merge is done even if the pull behavior is overwritten to default to rebase.

Help link for more details

Solution 2 - Git

Since you need to keep the files version on dev branch (keep the source branch while changing files in target branch master), so you should make changes on master branch to resolve the conflict files, and be sure you have permission to push changes to master branch.

You can use below options:

Option 1: merge directly

In your local repo, you can execute below commands to merge dev into master branch while keeping the conflict files version as the dev branch:

git checkout master
git merge dev -X theirs
git push origin master

And in the existing pull request you created, it will shows the branch has been merged. So you can abandon the pull request.

Option 2: still merge via pull request (resolve conflicts on master branch)

You can use below commands to resolve conflicts in master branch:

# In yout local repo
git checkout master
git checkout dev -- .
git commit -m 'replace master branch version by dev for the conflict files'
git push origin master 

While the changes in existing pull request won’t be updated if new commit(s) pushs to the target branch (master). And you can find the similar report Pull request diff does not update when a commit from the PR is merged to the target via another branch.

That means, the pull request in the web page still show the conflicts. You should abandon the existing pull request and reactivate (or create a new one) to merge dev into master branch.

Solution 3 - Git

I had to do a rebase. Had to walk through all the commits and apply my changes - they were pretty extensive, renaming namespaces & method names, etc. This then let me continue to do a Pull Request in the Azure DevOps portal. Actually, I could just Refresh changes for the existing Pull Request and the auto merge conflicts were resolved.

Merging the code did not resolve the issue, only rebase worked.

Solution 4 - Git

I had a merge conflict on a feature branch.

1. switched to the development branch and I completed a pull getting the current code base
2. git pull --no-rebase origin /feature/2 
3. from team resolved the merge conflict by manually selecting code between 
the conflicting file then pressing "accept merge"

4. push the changes to the git repository
5. complete a pull request into development

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionCBBSpikeView Question on Stackoverflow
Solution 1 - GitHarshil LodhiView Answer on Stackoverflow
Solution 2 - GitMarina LiuView Answer on Stackoverflow
Solution 3 - GitScott KolandView Answer on Stackoverflow
Solution 4 - GitGolden LionView Answer on Stackoverflow