How Blue Canvas enables feature branches with our Virtual Packaging concept.
This article will introduce you to the concept "User Story" applied to Salesforce development, in order to streamline release management for admins, BAs, and developers. We'll discuss how it works, its lifecycle, and how it ties into your existing workflows, enhancing organization and speed without introducing complicated overhead.
Here are our 5 Key Takeaways:
"Stories" by Blue Canvas act as tickets or work items, offering a unified system connecting version control, code changes, code reviews, and releases. A Story includes a title, description, and various components, creating a self-documenting context over time in your Salesforce org. Changes made in Salesforce are auto-committed by Blue Canvas to a Git branch, simplifying deployment between orgs. Stories can be submitted for validation and code review, enhancing quality control while documenting the business process. Multiple Stories can be bundled into a release, promoting better organization, faster release cycles, and safer rollbacks if needed. Salesforce teams are busy. At any given time there are multiple projects from multiple stakeholders across the business. And every project is complex and has multiple moving pieces. Business moves at an unpredictable pace so it can be hard to bring predictability to your Salesforce release management process.
To help with predictability, velocity, and measurement, most Agile software teams leverage source control and in particular feature branches . Feature branches allow teams to work on multiple work items or tickets in parallel. With feature branches you can stash your changes and switch contexts throughout your day. They are designed to make project management simpler and more effective.
However, as we’ve written at length, getting a proper Git flow to work with Salesforce can be a pain . And when you bring admins and BAs into the picture it gets even muddier. This means that getting to feature branching in the traditional Git flow is nearly impossible for most teams.
But it’s not necessary - there are other branching paradigms that work as powerful tools for complex project management. Blue Canvas has developed a new branching concept that actually works for Salesforce admins, BAs and developers without introducing complicated and expensive overhead like training to use new command-line based tools.
We do this with our concept of “Stories” which allow you to bundle changes into virtual packages that can be shipped around in multiple directions to multiple environments.
What is a User Story in Salesforce development? A story is many things. But you can basically think of it as a ticket or a work item in an ALM tool like JIRA or VSTS. It starts with a Title and Description of the work involved.
Because Blue Canvas also operates as a version control tool you can also leverage Git to pin various components to the ticket as you work. This allows you to create and maintain context in your org over time in a self-documenting way.
The story also has a lot of other associated metadata for organization and tracking such as a trail of comments and actions (great for Salesforce metadata code reviews and SOX auditing). It also includes information about where it was deployed from and to, when it was deployed, who made the deployment and who approved it.
The Lifecycle of a User Story Stories become the basic building block of changes to your Salesforce org.
For each change, you create a Story and give context about the work it will contain. This includes a Title and Description. Often, you’ll want to paste the URL to any tickets you have in external management systems (JIRA integration is on the roadmap let us know if you have requests!). The smaller the units of change the better because it allows you to be extra granular about changes.
Sometimes, developers or admins will create a single ticket and work on it end to end. Other times, they will create several at once for their sprint.
Blue Canvas allows you to create and manage these tickets as well as to save tickets as Drafts so that you can come back to it over time.
.ap3w-embeddable-form-6491c5ce2060226781d5c909{box-sizing:content-box;width:100%;font-size:16px;max-width:850px;max-height:100%;overflow:auto;background-color:#f4f6fb;border:2px solid transparent;box-shadow:0 0 10px 3px rgba(0,0,0,0);z-index:unset}.ap3w-embeddable-form-6491c5ce2060226781d5c909:before{content:' ';display:block;position:absolute;pointer-events:none;left:0;top:0;width:100%;height:100%;opacity:0%;background-image:url();background-position:center center;background-size:cover;background-repeat:no-repeat}.ap3w-embeddable-form-content{margin:auto;padding:32px}.ap3w-embeddable-form-6491c5ce2060226781d5c909-rounded{border-radius:12px}.ap3w-embeddable-form-6491c5ce2060226781d5c909 .ap3w-text{margin-bottom:16px}.ap3w-embeddable-form-6491c5ce2060226781d5c909 .ap3w-text *{padding-bottom:5px}.ap3w-text-6491c5ce2060226781d5c909{position:relative;margin:0;margin-bottom:16px;word-wrap:break-word}.ap3w-text-6491c5ce2060226781d5c909 *{margin:0;padding-bottom:8px}.ap3w-text-6491c5ce2060226781d5c909 p{text-transform:unset;text-decoration:unset;text-indent:unset}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h1"]{font-family:Hind,Helvetica;font-size:30px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h2"]{font-family:Hind,Helvetica;font-size:20px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h3"]{font-family:Hind,Helvetica;font-size:20px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h4"]{font-family:Hind,Helvetica;font-size:16px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h5"]{font-family:Hind,Helvetica;font-size:14px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h6"]{font-family:Hind,Helvetica;font-size:14px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p{font-family:Hind,Helvetica;font-size:16px;line-height:1.2;color:#333333;font-weight:400;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="large"]{font-family:Hind,Helvetica;font-size:20px;line-height:1.2;color:#333333;font-weight:400;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="small"]{font-family:Hind,Helvetica;font-size:14px;line-height:1.2;color:#333333;font-weight:400;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909{position:relative;margin:0;margin-bottom:16px;word-wrap:break-word}.ap3w-text-6491c5ce2060226781d5c909 *{margin:0;padding-bottom:8px}.ap3w-text-6491c5ce2060226781d5c909 p{text-transform:unset;text-decoration:unset;text-indent:unset}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h1"]{font-family:Hind,Helvetica;font-size:30px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h2"]{font-family:Hind,Helvetica;font-size:20px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h3"]{font-family:Hind,Helvetica;font-size:20px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h4"]{font-family:Hind,Helvetica;font-size:16px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h5"]{font-family:Hind,Helvetica;font-size:14px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="h6"]{font-family:Hind,Helvetica;font-size:14px;line-height:1.2;color:#433efe;font-weight:700;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p{font-family:Hind,Helvetica;font-size:16px;line-height:1.2;color:#333333;font-weight:400;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="large"]{font-family:Hind,Helvetica;font-size:20px;line-height:1.2;color:#333333;font-weight:400;font-style:normal}.ap3w-text-6491c5ce2060226781d5c909 p[data-size="small"]{font-family:Hind,Helvetica;font-size:14px;line-height:1.2;color:#333333;font-weight:400;font-style:normal}.ap3w-form-input-6491c5ce2060226781d5c909{position:relative;margin-bottom:20px}.ap3w-form-input-6491c5ce2060226781d5c909 input{margin-top:8px;box-sizing:border-box;width:100%;background-color:#FFFFFF;border:1px solid #000000;color:#000000;outline:none;font-family:Hind,Helvetica;font-weight:400;font-style:normal;font-size:16px;line-height:1.2;padding:10px 16px;resize:none;border-radius:4px}.ap3w-form-input-6491c5ce2060226781d5c909 .ap3w-form-input-label{font-weight:bold;color:#000000;font-family:Hind,Helvetica;font-size:16px;line-height:1.2}.ap3w-form-button-6491c5ce2060226781d5c909 button{position:relative;cursor:pointer;padding:10px;font-weight:bold;outline:none;border:2px solid transparent;color:#ffffff;background-color:#01b272;font-family:Hind,Helvetica;font-size:16px;line-height:1.2;border-radius:4px;flex:1}
Adding Changes to Story As you make changes in Salesforce as you normally would, Blue Canvas is listening in the background and committing those changes into a Git branch on your behalf. Each change is logged as a commit which can be viewed as a diff between other orgs. This makes deployment between orgs as simple as comparing Git diffs and issuing Pull Requests.
When a change to a component is ready to move up the deployment pipeline, you can quickly return to your Draft Story and pin the changes like so:
You can filter for components and search on various different levels.
Pinning changes to your Stories is a core value prop of Blue Canvas as it allows you to associate the what with the why. The Story contains the reasoning for the change as well as the code review associated with it. It also contains the actual code that was update which allows you to document your business process in real time. So in two years if you want to understand why a Class was created or altered, you can see the logic behind it. This can reduce technical debt and keep your Salesforce org in good health.
Submitting for Code Review and Validation When you are ready you can submit your story for validation and code review. At this point you can set the level of tests you want to run, and can even specify which tests you want to include .
The Story can now be found on your list of Open Stories with its status. The Story now has a list of components pinned to it, a build status (i.e. did it validate successfully), a test report if you elected to run tests, and a comments section. Other team members can look at the test reports and Git diffs included in this virtual package of sorts and give their feedback.
If it passes code review and validation, it can be Deployed. Blue Canvas offers multiple permission types to customize who is allowed to approve deployments and to where .
Once it’s been deployed you’ll see it on your list of previous Deployments.
Promoting Multiple Stories as Part of a Release For any given release you may have multiple stories. Again, this is where the concept of feature branching or virtual packaging comes in. When it’s time to do a larger release to production at the end of a sprint, Blue Canvas allows you to select multiple stories and pin them to a release just as you did with components for your individual stories.
You can bundle the stories and move them other environments like Production or UAT:
You can even clone stories and deploy them to other sandboxes or downstream after a production release to ensure that your sandbox metadata is synced with production.
Stories Promote Speed and Better Organization Leveraging Blue Canvas for release management makes organization of releases much simpler. Instead of juggling spreadsheets you can now connect your version control, code changes, code reviews, releases and ticketing system into a single unified system based on Agile best practices. This also creates an audit trail that you can use for compliance or just general system audits and reducing technical debt.
You can also release faster as you spend less time debugging deployments and creating change sets.
Finally, you can trust that your releases are safe because you can rollback these Stories as needed.