A devs life could be so easy…
Developing a feature in Salesforce is easy, right?
- Log into your org
- Use (mostly) some point &bmp; click methods to enhance logic, user interface or the data model
- Done
Sounds like it is developed.
But it is not delivered.
Although the feature is technically done, it is not available for end users in the production environment. Also, nobody tested if it fits the business requirements or if it breaks existing functionality.
In addition, maybe someone should take a look at your feature, if it is aligned with the overall solution design.
Oh, and in order to minimize business impact, deployments to production may be restricted to specific time windows per week.
Sounds like we as a team should follow a process to release features in a controlled way.
This is how we roll
There are a variety of processes for release management out there as each team is individual, but usually they structure a series of quality gates in a flow.
Taking the example from above, the high-level process would probably look like this:
So far so good, but now we have a challenge.
Production deployments can only be done at certain moments so what happens, if one feature is tested and ready to go and another one is still being reworked, and both share components such as an Account Layout?
Oh, and we want to have a backup of our metadata (not only classes) to be able to roll back, in case we have an issue after deployment?
It would be great, if we could work in a way that tracks changes over time and allows to release specific versions of our metadata.
Git for the save.
As described above, developing on the Force.com platform can be very straight forward. But apart from Flows and Process Builder, old versions are lost, once you save your changes, e.g. Classes, Formulas, Validation Rules or Layouts.
To avoid that, you can store local copies of your metadata by retrieving it (e.g. through Workbench or ANT Migration Tool). You can also deploy the retrieved items. So we could use that to account for our prod deployment, but that sounds like a lot of effort to manage those local files and versions.
Here is where a Version Control Solution (VCS) comes in handy. And by the frequency VCS is being mentioned, it has become an important pillar for working with Salesforce. There are several solutions out there (SVN, Mercurial), but as of now Git can be considered industry standard.
So instead of storing retrieved items on our hard drive using different names and folders for tracking versions, we can simply store them in our Git repository, which will track changes. This will allow us to go back to an earlier moment for rolling back changes or deploy a specific version from the past.
That escalated quickly. Can it be easy again?
Let’s take a step back.
What started out as an easy way to build valuable business features, suddenly sounds somewhat complex. Being able to roll back, having quality gates in place, all those are valid points, but now as a developer apart from creating functionality and work peer and QA feedback, you also need to do something with ANT or Workbench then storing it in Git and then deploy it?
Is there an easy way to do this?
Yes, Copado.
To get started, you need to download it from the AppExchange or the Copa.do website. Also, as the goal is to work with version control, get a free Git repo from GitHub or Atlassian/Bitbucket.
Next you need to connect Copado to your Salesforce environments (Dev, QA and Prod in this case) and set it up with the Git repository. There is a quick-start guide you can follow with links to additional documentation. While you set up Copado, you notice that it is natively build on the force.com platform. So your knowledge about Salesforce is all you need to modify it (This will be important later, so keep it in mind).
Once the setup is done, the process described out above using Git version control as source of truth would be the following with Copado:
Define feature in Copado
Assuming most Salesforce implementations are done in some form of Agile, it can be done in Copado directly, including all required information, such as Sprints, Epics, Acceptance Criteria or Story Points (click here for more details).
Scrum Masters and Analysts can use the Work Manager and Kanban Board to manage stories, roadmaps and sprints.
Develop feature in your environment
Let’s get to the part we like: get creative on how to solve the business issue in Salesforce. This one is easy indeed.
Perform a peer review in your environment
This is done between developers, however, we would like to document the results with a flag to mark the story as “Review Passed”.
Here is when the catchphrase “native force.com” turns into a benefit.
Just create a Checkbox on the Copado User Story object called “Peer Review Passed”, make it available for the required User Profiles and put it on the User story layout. Done*.
*: Wait, you work in Production directly? You can use Copado to deploy this modification.
Deploy to QA
So far so good, let’s go ahead and deploy. Scared?
Just click on “Commit Changes” on the Copado User Story, select your items (use column search and sorting to make your life easy), provide a message and finish your commit.
Back on the User Story page, check “Promote & Deploy”* and the following will be done by Copado**:
- Create a feature branch
- Retrieve the items you selected
- Commit the items you selected on the feature branch
- Create an intermediate Promotion Branch merge your feature branch on it (more info on the branching strategy can be found here)
- Perform the deployment using Git as source
- You’ll never work alone, so how to improve releases by working as a team?
- Deploying with a simple click is maybe too easy. Can we implement quality gates?
- Those are too many clicks. Can we automate this?
You can review your selections on the story, and click on the “View in Git” links to quickly navigate to your repository.
** bonus points if you click on “Validate” to make sure you can deploy
Test user story
Once the story is deployed to the next environment, it will be visible on the User Story page and we can change the status to “Ready for testing” and notify the Test Team through chatter.
If you are thinking “Wait, this just a record update in Salesforce and it could be automated easily”, you are completely right! Wait for the upcoming blog posts.
As soon as the test team approves the story, they can set the status to “Complete”.
Deploy to Production
Testing is done, and we can move to Prod. But wasn’t there something about other stories modifying the same component and them not being ready?
Well, this is the beauty of version control. Copado will pick the feature branch contents for deployment and those did not change. Your story is independent and you can work in a true Agile way.
Check “Promote & Deploy” again.
Done.
That’s it. That’s all?
Well, not exactly. The tool offers tons of functionality which can make your life easy, such as the way profiles are trimmed and deployed with Git, an engine to remove (or replace) unwanted tags from xml files, modules for recording and automating testing, and the easiest way to handle Salesforce DX you have ever seen. You can even launch internal Copado logic through Process Builder!
Check out on their demos or browse a little the documentation to get an overview of what is possible.
We, however, will leave technical feature descriptions aside and focus at improving our process, as there are elements which will need to be tackled to get your team closer to smooth releases.
Look out for the next post, where we will take a closer look at the involved team members and how Business Analysts can play a key role reducing the time required to release a feature.