简体   繁体   中英

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

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: 在此处输入图像描述

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.

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

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.

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.

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

These are the steps to fix the problem

  1. Open git change
  2. From branch dropdown, found your destination repo.. But don't click it yet在此处输入图像描述
  3. On your destination repo, right click and select 'merge into current branch'
  4. When 'merge into current branch' has done, you will see list of files that having conflict. Stage them or delete it when you don't need it or fix the problem causing conflict then stage it.
  5. When all files with conflict has been staged, sync.
  6. Your problem should be fixed at this point

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM