99 Dealing with conflicts
Written by Matthew Wankiewicz and last updated on 7 October 2021.
99.1 Introduction
In this lesson, you will learn how to:
- Deal with conflicts that arise when working with GitHub.
- Deal with merge conflicts in GitHub.
Prerequisite skills include:
- Familiarity with GitHub.
- Git installed on your computer.
- Having a GitHub account.
Highlights:
- Merge conflicts occur when a user with a non-updated branch attempts to make a change to the main repository, causing there to be two different versions of the same repository.
- When merge conflicts occur, the owner of the repository must review the error and make a proper change to the main branch.
- Always pull before you push.
99.2 The content
When you begin to work with GitHub, whether it is on personal projects or group assignments for school, you must always be careful of conflicts with GitHub. Conflicts usually arise when different version of the same file are being pushed into the main repository and GitHub does not know which one to use.
The two main conflicts that can arise when using GitHub are conflicts with updating your personal GitHub repo (not pulling for pushing) or having multiple people change the same file in their pull requests when working in groups.
99.2.1 Conflicts from Pushing before Pulling
If you decide to change something quickly on the GitHub website while you’re also working on the project using R, you run the risk of creating a conflict. This conflict could be as simple as changing a typo in your README and you forgot to update that change in your R project. This is where pulling before pushing comes in handy because if you pull, your R project will be updated with the changes present on the website and if you don’t, GitHub will have record of two different changes and will be unsure of which one to use.
99.2.2 Conflicts from Having an Issue with a Pull Request
Sometimes, you may make a change on the main repository that someone else may have made in their branch/forked repository and when they make a pull request, GitHub will notice that there is an issue. Again, this could be something as simple as two people updating the README in different ways, causing GitHub to flag that there is an issue. When these conflicts occur, the owner of the GitHub repo will have to decide how to fix the conflict.
99.2.3 Solving Conflicts
Sometimes, the easiest thing to do when there is a conflict is just delete the file (or even the repo) but save all of the important information. Then, you can create a new repo and add back in all of the files. Obviously you don’t want to do this because it is time consuming and fairly simple to fix. These fixes will be described below.
Pushing before pulling
When you make a change on your GitHub repo and there is a conflict, when you commit your change, R will tell you that your version is ahead of the main repository. When you see this, it means that there is a difference between the files. If you attempt to pull and there is an issue, GitHub will tell you something along the lines of “Updates were rejected because the remote contains work that you do not have locally. This is usually caused by another repository pushing to the same ref.” If that message appears, GitHub will recommend that you pull from your main repo to find the error. When you pull, GitHub will give an error saying "CONFLICT (content): Merge conflict in [File]. Automatic merge failed; fix conflicts and then commit the result.
The file with the issue will then be opened up on you RStudio and will show you the error that it found. It will show you what the change you made is and what the difference is on the main branch (your changes will be shown under “<<<<<<< HEAD,” the main branch’s content will be shown below). What you will have to do is fix the error between the two versions, either keep what GitHub has already or make the change to fit what you wanted to do. Once you are satisfied with your change, go to the Terminal (this is located in R, a tab over from the console). In the terminal type “git add [filename],” press enter and then head back over to the Git tab on the top right of your RStudio window. Select the file that had the error and then commit and push and your error will be fixed. There will be a video explaining this on the next page.
Merge conflicts
If you have multiple people working on the same GitHub repo or you are just using a branch, there is the possibility that a merge conflict will occur. Merge conflicts occur when there are changes made to the main repo and a branch which do not match. Once a pull request is made, the owner of the repo will have to manually look over the issue instead of automatically merging the changes. When using branches, before the pull request is made, GitHub will say that it “Can’t automatically merge” but it will still allow you to send the pull request (giving the option for you or the repo owner to do more work). If you decide to send the pull request, the owner of the repo won’t be able to press the green button saying merge, instead they will see something saying “This branch has conflicts that must be resolved.” To the right of that message there is a button saying “Resolve conflicts.”
Once you click on the “Resolve conflicts” button, it brings you to a page which looks similar to when you have an error with Pushing and Pulling. It will show the proposed changes from the branch and what that change looks like in the main repo. At this point, the owner can make their changes and then click on “Mark as resolved” and then “commit merge.” Finally, the owner will have to click “Merge pull request” and then “commit merge” to solidify the change into the main repo.
99.3 Questions
Link to video explaining how to fix pull/push issues: https://youtu.be/hNmZ81poNkQ
Link to video explaining how to fix merge conflicts: https://youtu.be/SjjqBnmRP64
99.5 Next Steps
For further information on how to deal with conflicts in GitHub, check out:
- GitHub documents about merge conflicts: https://docs.github.com/en/free-pro-team@latest/github/collaborating-with-issues-and-pull-requests/addressing-merge-conflicts
99.6 Questions
- What causes a merge conflict?
- A user with a non-updated branch attempts to make a change to the main repository
- A user with updated branches attempts to make a change to the main repository
- When merge conflicts occur, who usually needs to fix the issue?
- You
- The owner of the repo
- A GitHub employee
- None of the above
- True or False, you should push before you pull?
- True
- False
- Which of these is not a case where conflicts occur?
- An update occurs from not pulling/pushing
- Two people update the same file and send it to the main repo
- One person is using a different operating system than other users.
- These are all ways in which conflicts occur
- What causes the “CONFLICT (content): Merge conflict in [File]. Automatic merge failed; fix conflicts and then commit the result” conflict?
- Pulling before pushing
- Pushing before pulling
- It happens randomly
- The file size was too large to upload
- True or False, in the case of an automatic merge conflict you must either change your file to match the main repo or delete any changes?
- True
- False
- True or False, if you cannot automatically merge a pull request, GitHub will not allow you to send it to the owner?
- True
- False
- True or False, you may need to use git commands in the terminal if you run into a conflict?
- True
- False
- What button do repo owners need to press to solve any conflicts?
- “Resolve conflicts”
- “Fix conflicts”
- “Edit conflicts”
- “Edit issues”
- True or False, GitHub conflicts can be solved automatically?
- True
- False