What is EZ-Merge?
Merging is simply putting a forked history back together again. Say we have a new branch feature based on the master branch. We now want to merge this feature branch into the master. Using the merge process in AutoRABIT will merge the specified branch feature into the current branch...we'll assume the master.
Before you begin
Before a merge, several preparation steps must be taken to ensure the merge goes smoothly.
Register your Version Control Repository in AutoRABIT:An Admin can only perform this step. Register your Version Control Repositories, such as GIT, SVN, or TFS, in AutoRABIT.
Register your Salesforce Organization in AutoRABIT:AutoRABIT connects to your Salesforce Org using the secure OAuth method or username/password connections. An Admin can only perform this step.
Set Up a Branch:Instead of directly making changes to the code base, you can branch off from the mainline and work on a specific feature in an isolated branch. An Admin can only perform this step.
Mapping the users with the Version Control and Salesforce Orgs in the "My Profile" section:Set up the permissions to create a project in AutoRABIT.
Fetch the latest remote commits:Ensure the receiving branch and the merging branch are up to date with the latest remote changes.
How do I merge my changes to a branch?
The merge process is generally performed when a feature is ready for user testing in Salesforce Orgs and usually involves code review by other development team members.
- Hover your mouse over the
Version Controlmodule and select
- Click on the
New EZ-Mergescreen is best viewed when the zoom setting is set to 80% on your Chrome/Firefox browser.
- You can also reach the
New Mergescreen directly by selecting
Create New > New EZ-Mergefrom the top navigation bar.
- In the
New EZ-Mergescreen, select the
version control repositoryfrom where the metadata components will be fetched.
- Select your
source (base) branchand the
- Select the
Merge Typefrom the dropdown:
A. Entire Branch
This option will merge the entire change from one branch to another branch.
Different options for
"Entire Branch" merge type
Delete Source Branch:Once you have successfully merged the changes from the source branch to another, you can permanently delete the source branch. Select the
Delete Source Branchcheckbox to delete the source branch, which auto-populates whenever Entire Branch as a merge type is selected.
B. Single Revision
Merge a Single Revision from the Commits that you have performed. You can either enter the revision number (in case you remember it) or use the
Search () button next to the
Single Revision field to pull a list of revisions from which you can choose which revision to use in the deployment.
Get Latest HEADpoints out the last commit in the current checkout branch.
There could be a situation where you have entered an incorrect revision number and hit the
Search button. In this case, an error message indicates that the revision number entered is incorrect.
You can also use the
'Get All Revisions' button to try and get all the revisions and check for your revision from the list.
C. Commit Label
Select the commit labels created while committing to Version Control System. The commit labels created during the EZ-Commit or Merge process will be fetched in the
Commit Label field.
For example, DXTES-19_EZ-Commit, here DXTES-19 indicates the commit label name, and EZ-Commit denotes the label created during the EZ-Commit process.
Click on the
View Revisions link to view the list of revisions for the commit label. A new dialog box appears with the revisions, date/time stamp, comments, and author details. There is a provision to search for specific revisions using the
Revision Search filter on the top right corner of the dialog box.
D. Release Label
You can select the release labels created using the committed revisions and the labels.
- Select the
Release Labelsfield populates with all the available release labels in that repository/branch. If no release label is created for the above repository/ branch, an error notification states,
"No Release Labels found."
- Select your Release Label.
- Click on the
View Revisionslink to view the list of revisions for the release label. A new dialog box appears with the revisions, date/time stamp, comments, and author details. There is a provision to search for specific revisions using the
Revision Searchfilter on the top right corner of the dialog box.
E. ALM Label
This allows you to choose and promote the ALM user stories to a higher or lower branch.
- Select the
- The Work Item will gather all the user stories for which the ALM commits happened in the Source Branch of chosen Version Control Repository. Click on the
Search() icon to find the list of user stories or work items fetched.Note:You will not have the option to enter the work item details manually, you need to select the work item from the list fetched.
- Select one of the work items from the list fetched, and click OK.
- Conflict Resolution Strategy: This field allows you to select how to resolve the conflicts. If you and another user change the same file in different sandboxes or on different branches, a conflict arises when you try to commit your modified files. When the conflict occurs, AutoRABIT will use the below resolve method:
- Manually resolve conflicts: Resolve the conflicts manually.
- Choose the file from the source: Replaces the copy of the file in your workspace with the version in the repo, discarding your changes.
- Choose the file from the destination: Accept the file in your workspace, overwriting the version in the repo when you submit the file.
- Enter the Merge Label name and comment (if any).
- Enter the Email ID(s) to send an email notification of the merge reports.
- Create Commit Label: To create a commit label for the merge operation, select this checkbox.
- Create a GIT Tag: GIT tags are a simple and effective way to ensure you can keep track of the different versions of your code and the critical quality of Git's version control. GIT Tag operation allows meaningful names to a specific version in the repository.
- Skips Profile/ Perm. Set Access-Setting Duplicity Check: If you do not want AutoRABIT to list all duplicate entries for your profile/permission sets, please select this checkbox. (Learn More)
- Review Artifact: Select this checkbox to see the list of the changed files staged for commit (during merge conflicts). This allows you to preview the changes, review them or edit the files before pushing them into your version control. (Learn More)
In this section, you can assign certain pre-validation merge operations (such as deployment validation with another Salesforce Org, choosing the Apex test class to run, selecting the static code analysis tool, generating difference reports, etc) before merging it to your target branch.
Different Prevalidate Merge Criteria:
- Generate Diff Report: Select this option to auto-generate a code difference report on completion of the commit.
- Run Static code Analysis: Select this option if you want to run a static code analysis tool to identify potential software quality issues before the code moves to production. Similar to "Generate Diff Report," this option will also be auto-selected by default if the criteria are set globally (under the My Account > Commit Validation - Approval Settings section).
- For ApexPMD, Checkmarx, CodeScan, and SonarQube: AutoRABIT allows you to set the criteria for running the SCA tool, whether to run on all supported metadata types from the full source or to run on the newly added components.Important Note:Whenever a code analysis is triggered, ARM will wait up to 5 hours for a response. If the code analysis is not completed within 5 hours, ARM will throw a timeout exception error. This applies to all SCA tools.
- For ApexPMD, Checkmarx, CodeScan, and SonarQube: AutoRABIT allows you to set the criteria for running the SCA tool, whether to run on all supported metadata types from the full source or to run on the newly added components.
- Validate Deployment: Choose a Salesforce org to validate a future deployment. Further, there are different options to choose from:
- Run Destructive Changes: Here, you can specify whether to run pre or post-destructive changes while carrying out the merge process.
- Ignore Missing Visibility: With this option, differences in visibility settings between the source and destination branches will not cause the merge to fail. AutoRABIT will compare the source and destination branches and keep only the common settings between both branches.Important NoteStandard fields are not supported for Ignore Missing Visible Settings.
- Ignore installed components: When selected, AutoRABIT will scan for the components that are deployed, and if there are any managed package components located in the destination branch, these components will be excluded from the metadata.zip files while the remaining components are deployed.
- Apex Test Level: Choose your Apex Test level to validate your merge.
- Prevalidate Merge section will be visible only if the Admin has enabled the 'Merge Setting' checkbox under the My Account section.
- Users with the 'Merge Review Overridable' role has special permission to either check or uncheck the pre-validate option. However, each time they try to commit to the branch, a notification alert mail gets triggered to the email ID as specified in My Account > Merge Settings.
- Prevalidate Merge section will not be displayed for Version control repositories registered in the 'SFDX' structure.
- Suppose the meta-XML file does not exist in the Destination Branch and is available in the Source Branch. The meta-XML file is copied from the source branch to the destination branch before committing to the remote repository. The newly added meta-XML file will be added to the files list, committed to the remote repository, and added to the Validate Deployment package.
- Based on the permission assigned by your Admin, you will see the options in the active state. Suppose your Admin has assigned you permission to run a static code analysis tool only to review your code before merging them. In that case, the Run Static Code Analysis option will remain inactive, while other options will remain disabled or won't be seen.
- Based on the Approval Reviewer level set in 'Merge Settings' (under the My Account section), you need to specify the email address of the reviewers for a given proposed code change and to approve merge requests.
You can update the status of the ALM work item through the ALM Integration section (below the Pre-validate Merge section), and the same gets reflected in your ALM system.
- Select the ALM label.
- Select the Project and the sprint for which the commit is planned.
- Select the Work Item, and the Current Status for the work item gets auto-populated. This allows you to update the ALM for the Merge operation with or without changing the current work item status. Click on the + icon to add another work item and update its status.
Click on either Dry Run or Validate & Merge.
|Dry Run||Validate & Merge|
- A notification appears that the merge request has been submitted for Entire Branch and Single Revision merge types. Click OK, and you will be auto-redirected to the Commits screen, where you can find the status of the initiated merge.
- A confirmation dialog box will ask you to approve the requested operation for Release Label, Commit Label, and ALM Label merge types. Click OK, and you will be auto-redirected to the Commits screen, where you can find the status of the initiated merge.
For merge labels that are either in progress or have some conflicts, in such a scenario, you will find a popup that will appear as shown below when you press the Validate & Merge button. These merge conflict statuses will only be shown for the merges created within seven days.
Resolution: To prevent this, first, resolve current merge conflicts or allow the in-progress merge status to move to the completed state and then restart the merge process again.