Merge Conflicts
About Merge Conflicts
When you work in a team, you may come across a situation when somebody commits changes to a file you are currently working on. If these changes do not overlap (i.e. changes were made to different lines of code), the conflicting files are merged automatically. However, if the same lines were affected, your version control system cannot randomly pick one side over the other and asks you to resolve the conflict.
Resolving Merge Conflicts
There are 2 ways to resolve the conflicted files:
Download conflicted files locally or
Using merge conflict Inline editor.
Download Conflicted Files Locally
ARM has given a provision to the user to download the conflicted files in their local machine, resolve them locally and upload the same.
To do so,
Go to the Commits screen.
Search for your merge label that has a conflict. Click on the Resolve Conflict button.
The list of conflicted files or merged files will display on the next screen.
The File Path view displays a dynamic, hierarchical list of conflicted/merged items. The Tree view displays the parent-child relationships of the conflicted/merged files.
Important Note: If there is a conflict related to file tree, then GIT shows that the file does not have any conflicts.
To proceed further, select the check box for the respective conflict, click on the 3 dots, and then select if you want to use the source changes or the destination changes. Then you can go ahead and proceed with the next step to resolve the conflict.
When you click on the Download icon, a confirmation message box to include .git or .svn folder with "Yes" and "No" buttons will be displayed. If you select the 'Yes' button only, then the conflicted files including the .git or .svn folder will be downloaded to your local machine in zip format.
Now, work on the conflicted files using your merge tool (example- TortoiseSVN, TortoiseGit) and make necessary changes to it.
Finally, click on Commit to commit the changes in the destination branch.
Merge Conflict Inline Editor
The Merge inline editor helps users to resolve more complex merging conflicts directly from the ARM merge interface.
Important Note: Files over 10 MB may not be resolved using Merge Inline Editor, therefore, in such a scenario, download the conflicted files on your local machine, resolve, and upload them again.
Go to the Commits screen and search for your merge label that has conflict. Click on the Resolve Conflict icon.
The list of conflicted files or merged files will display on the next screen.
There is an easier method to resolve the conflicted files in one go. Select all the files and click on the 3 dots as shown in the image below and choose either of the criteria to resolve the files.
Use Source: This option retains the revisions located in the source branch
Use Destination: This option retains the revisions located in the destination branch
Or, click on a conflicted file to see its related conflict blocks. This tab will display the number of insertions and deletions to each metadata file. The lines highlighted in GREEN color indicate those are updated (added/modified) in the source branch and for RED color indicates those are updated (added/modified) in the destination branch. The highlighted lines are the modified lines.
Navigate to other conflict blocks for the current conflict file by using the Prev Conflict or Next Conflict icon.
Now, select the criteria by which you want to resolve the merge conflicts:
Dest. file: This option retains the revisions located in the Destination Branch.
Src. file: This option retains the revisions located in the Source Branch.
Block: Select this option to resolve using either Source or Destination block. Here, two options will be auto-populated and you need to select either of the options mentioned below:
Destination: The changes in the destination block will be used in the resulting merged file.
Source: The changes in the source block will be used in the resulting merged file.
Block from âDest.â before âSrc.â: This allows you to use both the blocks; first changes in the destination block and later source block. The changes are used in the resulting Merged file.
Block from âSrc.â before âDest.â: This allows you to use both the blocks; first changes in the source block and later destination block. The changes are used in the resulting Merged file.
Troubleshooting: Do I have a provision to edit the inline code if the above merge criteria fail to resolve the merge conflicts?
In rare circumstances, your merge conflict may not be resolved by the merge criteria that ARM offers. Additionally, inline editing of the code is not supported by ARM. In such a case, we advise initiating the merge operation while keeping the checkbox for Review Artifacts enabled on the EZ-Merge screen.
Choose any of the merging criteria that ARM offers on the Resolve Conflicts screen. You will next be redirected to the Review Artifacts tab where you can see a list of the changed files staged for commit. Here, you have the ability to preview the changes, review them or edit the files before pushing them into your version control.
When starting a merge process in ARM, we recommend always enabling the Review Artifacts checkbox. It not only offers a workaround for manual code editing, but it also allows you to compare the code from the source branch and the destination branch before merging them.
Click on Next Conflict and repeat the steps until all the conflicts are resolved. The data for each conflict gets auto-saved once the user proceeds to either the Prev or Next conflict.
Scenarios when the conflict blocks may not be saved: The user is working on a conflict block and chooses the appropriate option to resolve it, but before clicking on either Prev or Next Conflict to autosave the data, the user selects another option, let's say the option to show 100/200/300/400/500 lines before and after the conflict. In such a case, the conflict block data will be automatically erased and the user will need to resolve such conflict block once again.
Click on the Resolve conflict option to resolve the conflicted file.
Repeat the steps for all other conflicted files in order to resolve them before you proceed to commit.
You can find the conflicted files moved to the Merged Files section. Here CR indicates Conflicted Resolved files, A indicates Added Files to the destination branch and M denotes Modified Files.
You will be directed to the next tab, Profile Duplicates.
Profile Duplicates
This tab will list all duplicate entries for your profile/permission sets and you want to resolve them before resolving the conflict. For multiple entries, you have a provision to delete the entry that you no longer require (using the X icon) or to keep all entries as they are by default.
Important Points to Note:
If you receive the following error as highlighted below for duplicate entry, we suggest you download the file locally in such a case and search for any duplicity. Or, you can continue to commit directly by resolving the conflicting files (using the Resolve Duplicates button).
There can also be a situation where the files are improperly solved while resolving the conflicted files. This can lead to the malformation of the conflicted files. To resolve those, you need to download the file locally, work on the conflicted files using your merge tool, and make necessary changes to it. Then upload the same.
Review Artifacts
The Review Artifacts tab will appear in the merge conflict screen only if you enabled the Review Artifacts checkbox while creating the merge operation.
Finally, click on the Commit button to commit the necessary changes to your target branch.
Important Note: If there are multiple revisions as part of the merge, and if the same metadata file exists in more than 2 revisions, then such metadata will be displayed under Review Artifact regardless of conflicts. This is expected behavior from ARM.
Last updated