This documentation assumes it is already known the company deployment workflow, and extends it to cover the continuous delivery as it should work for all source{d} web applications:
repo | Prod | Staging |
---|---|---|
src-d/landing | sourced.tech | landing-staging.srcd.run |
src-d/blog | blog.sourced.tech | blog-staging.srcd.run |
src-d/talks | talks.sourced.tech | talks-staging.srcd.run |
This document does not pretend to be exhaustive but a guide, and there can be special cases that will be defined in the README.md and CONTRIBUTING.md of each web application repository.
This document is based on the agreements of the 2017-10-23 CD workflow and 2017-10-26 Enforcing the CD workflow meetings.
Here are the technical details of when CI or CD runs, but it is needed you know and understand the guides and conventions explained below this section.
master
branch must be always production ready and will reflect the code deployed into Production.- there are no long-term branches but
master
, staging
branch must not be merged into other branches,staging
branch should be kept as close to master as possible,
CI and CD is controlled by drone
- It is automatically deployed into Production when something is tagged,
- it is automatically deployed into Staging when the
src-d:staging
branch is updated, - CI automatically runs when a PR against
master
or arelease/*
branch is created or updated with new commits.
master
branch must be "always" production ready.
master
branch will contain only approved commits through a PR.
master
branch is the starting point for feature branches (considering some special cases)
Since the workflow in the source{d} web applications use to be closely guided by Product, it is quite likely that it is needed to obtain its approval before merging into master
; the repository Maintainers will decide if any PR must be reviewed by Product, by themselves or by any other person.
The deployment of the source{d} web applications is done by drone when a commit is tagged.
To tag something –and deploy– something, we follow the following conventions:
- All tags must follow Semantic Versioning 2,
- All tags must be reachable from
master
branch, - Tags must be done from a merge commit into
master
branch, - Every time something is merged into master, there must be a tag pointing to that merge;
When it is needed to merge many PRs and deploy only the last one (for example during a redesign), the feature branches will be created from a release branch, and merged into that same branch.
The release branches will be named with the pattern release/__TAG_NAME__
being __TAG_NAME__
the expected tag name that will be given when the release branch has been approved and merged into master.
There can be some special exceptions that would require merging into master some PRs consecutively, and only to tag the last one; when it is needed to proceed that way, it should elapse only a few minutes between the first commit –not being tagged–, and the last one –being tagged–.
Whenever staging
branch is updated, drone automatically deploys it to Staging environment.
staging
branch is not a long-term branch, so it should be kept as closer to master
as possible.
The project maintainer and team members working with that project will decide when staging
should be reset to master
or a release/*
branch, considering its current state and other features that could be tested in Staging.
Since the staging
branch contains commits not approved, it is needed to keep those ones outside from master
or any other branch that could be merged against master
–like release or feature branches–. Due to the necessity of keeping that risk as low as possible, it can be taken as a general rule that staging
branch must not be merged into any branch –neither into the remote src-d:staging
–