This document details the process we use to deploy Test Pilot to our stage and production environments.
(you can read more below)
- Thursday at 1pm PST the train is cut, all code is in.
- Thursday at 4pm PST we tag and push stage, and send email out.
- Friday is a buffer day.
- Monday at regular stand-up we review anything that Softvision found and fix it.
- Tuesday at 8am PST we push and Softvision verifies.
Softvision is our embedded QA team. Their main functions are to write test plans and verify deployments.
During the checkin before the end of the current milestone, we will inform the team that we will be building a release against master
.
Note: we auto deploy the master branch to our development environment: http://testpilot.dev.mozaws.net
This will happen on Thursday at the end of sprint.
- https://github.com/mozilla/testpilot/releases/new
- Tag Version: YYYY-MM-DD (append -N if more than one release is tagged on a given day: 2016-04-08-1)
- Release Title: YYYY-MM-DD
- Click
Publish
Please be as detailed as possible in the release notes. Examples - 2016-07-05, 2016-06-06
This will happen on Thursday at the end of sprint.
git checkout stage-static
git reset --hard YYYY-MM-DD
# whatever your tag name isgit push mozilla stage-static -f
# Replacemozilla
with whatever you name your upstream. The-f
is only necessary if we cherry-picked patches when we pushed last time.
Notifications of successful deployment will appear on IRC.
This will happen on Thursday at the end of sprint after we've pushed to stage.
Create a deployment issue to track status and potential blockers. Example. Give it a needs:qa
label.
Send out an email notification to [email protected]
to please test the staging environment. Example.
Include Softvision and the issue link in the email notification.
Follow the steps in the "Test Pilot Deployment Verification Test Plan" doc to verify that the site works as expected. Along with testing any major features in the release.
Any issues should be reported in the deployment bug.
If no issues are found, Softvision will note in the bug.
Test Pilot team is still responsible for final approval for push to production.
On the following Monday, during our checkin, Softvision will give us an update on status of stage.
Once we are comfortable that the site has been tested:
git checkout production-static
git reset --hard YYYY-MM-DD
# whatever your tag name isgit push mozilla production-static -f
# Replacemozilla
with whatever you name your upstream. The-f
is only necessary if we cherry-picked patches when we pushed last time.
Notifications of successful deployment will appear on IRC.
We'll target Tuesday 8AM PST for deployment.
Softvision will verify production for us, and report any bugs on Tuesday.
Once we have verified production, update the "testpilot.firefox.com (production)" GA account with an annotation including sprint information. Example: "Sprint-12 Pushed to Prod" Oct. 25th.
Close deployment issue, and give it a qa:verified
label.
If something is found that requires an immediate change to production (or staging) code, please follow the below guidelines.
In all cases, engineering will have the final approval on the roll back.
Ideally, we should "roll forward" with git revert
to undo problematic commits and push a new release. Of course, that's also problematic if we don't know what commits caused a problem. Or if the problematic commits also included the database migrations - in which case, we also need to pair the git revert
with a commit that undoes the migration.
From a fresh check-out, producing a static build can be done like so:
git clone https://github.com/mozilla/testpilot.git
cd addon
npm install
npm run sign # Requires AMO credentials in AMO_USER and AMO_SECRET env vars
npm run package # No AMO credentials required, but the add-on is unsigned
cd ..
npm install
NODE_ENV=production ENABLE_PONTOON=0 npm run static
After all the above commands, you should have an optimized static build of the
site in the dist
directory.
The NODE_ENV
variable in the last command can be set to development
to
produce a build that's easier to debug, at the expense of JS bundle size and
performance.
The ENABLE_PONTOON
variable can be set to 1
if you want to include a
<script>
tag that loads JS from the Pontoon localization
service - something we generally do not want to
do in production environments (see #1356).