Hopefully you have some tests or just lint checks that you want to run in a continuous manner, whenever new commits are pushed or on code from pull requests.
We currently use Travis CI and thus prefer it for consistency, but other CIs are ok given reasonable consideration.
A very first step to setup an integration with Travis CI is to visit https://github.com/organizations/ysoftwareab/settings/installations,
press Configure
next to Travis CI
and make sure that Travis
has access to your repo in the Repository access
section dropdown.
Then go to https://travis-ci.com/profile/ysoftwareab and find your repo in the list to open its settings.
It is recommended that on the repository's Travis CI settings page you
- if you have long-running builds such as deployment to AWS CloudFormation,
enable
Limit concurrent jobs: 1
- enable
Auto cancel branch builds
- enable
Auto cancel pull request builds
- add cronjob
master - daily - Always run
- if this is an internal/private repository,
- replace the default SSH key of the Travis CI project with
svc-pro-github
user's SSH key (can be found in the designated safe location) - on github.com, to the repository's
Settings
tab ->Collaborators & Teams
, and add thezz-svc-pro-github
team with a levelWrite
(Read
is not enough if you want to enable artifacts or github releases)
- replace the default SSH key of the Travis CI project with
Link to the repository's page on Travis CI
and embed a status image for the master
branch (or more) in README.md
, in short add:
# <software product> [![Build Status][2]][1]
...
[1]: https://travis-ci.com/ysoftwareab/<repo>
[2]: https://travis-ci.com/ysoftwareab/<repo>.svg?branch=master
NOTE for internal/private repositories, you'll want to go https://travis-ci.com/ysoftwareab/, click the status image, select 'Image URL' and copy the SVG URL (the link has a unique token).
Reference: https://docs.travis-ci.com/user/status-images/
Don't forget to commit the most important thing: a .travis.yml
(template) file which configures your Travis CI build.
If your job has artifacts, like logs that you'd like to access outside of the Travis CI job log, then you need to
- Add a
YP_GH_TOKEN_DEPLOY
, alternativelyYP_GH_TOKEN
, secure environment variable in the Travis CI web UI. Use the Github API token of thesvc-pro-github
user (can be found in the designated safe location). This Github API token should have enough permissions to push to the repository. - Give access to the repo to
ysoftwareab/zz-svc-pro-github
team with a levelWrite
. - Create a
.artifacts
file
The .artifacts
file is a .gitignore
-like file that matches paths to artifacts e.g.
some.log
some/folder/*.log
/root.log
Once you do, your artifacts would be uploaded to a refs/jobs/<job_id>
git ref,
making it possible to browse the artifacts via Github's UI,
or checking them out via git fetch refs/jobs/<job_id> && git log -p FETCH_HEAD
(or even git checkout FETCH_HEAD
) from a local repo.
In order to speed up builds and increase stability and predictability, we try to run the Travis pipeline in a Docker container running the same OS as host, and having the same user and home folder contents as the host.
NOTE This means that Travis directives like addons
in .travis.yml
are redundant,
because they will only affect the host machine, and not the Docker container where the pipeline runs.
The Docker image is by default ysoftwareab/yp-<os>-<os_version>-common
,
but it can be specified via an environment variable YP_DOCKER_CI_IMAGE
in the Travis UI.
Alternatively, you can disable running the pipeline in a Docker container, via YP_DOCKER_CI_IMAGE=false
.
Starting 2020-11-01, Docker will impose rate limits for pulling public images from hub.docker.com. In order to not risk getting rate-limited, one should authenticate the calls. Credentials can be passed via environment variables:
YP_DOCKER_CI_USERNAME
, defaults to another environment variableDOCKER_USERNAME
YP_DOCKER_CI_TOKEN
, defaults to another environment variableDOCKER_TOKEN
YP_DOCKER_CI_SERVER
, defaults tohub.docker.com
If you experience failures and you want to debug inside a Travis worker,
you can press the Debug build
button in the top-right corner, and, after some minutes,
you should get an ssh
command to execute in the output log, like
For official info, see how to debug.
If you debug often, you can speed up the process,
by running yplatform/bin/travis-debug --token X --job Y
, where
- X is the token that you see at https://travis-ci.com/profile/
- you can omit
--token X
if you have an environment variableTRAVIS_API_TOKEN
- you can omit
- Y can be a numeric job ID or a job URL or even a build URL (most useful)
NOTE Remember that you can almost always run --help
,
so yplatform/bin/travis-debug --help
, to get proper info.
Once you SSH via the tmate session, you will be welcomed by the message:
Run individual commands; or execute configured build phases with
travis_run_*
functions (e.g.,travis_run_before_install
).
So run travis_run_before_install
in order to bootstrap the machine.
Once that command finishes, you will be welcome by the message:
Please run
./.travis.sh debug
to activate your debug session !!!
So run ./.travis.sh debug
in order to setup the shell session (e.g. environment variables like PATH
).
NOTE If travis_run_before_install
fails and crashes the tmate session, you can try running ./.travis.sh before-install
(equivalent but safer).
NOTE See related docs on how to manage secrets.
If you have Travis-specific values to encrypt,
then you can add encrypted values via the web UI of Travis CI:
project -> More Options -> Settings -> Environment Variables
.
By default, all environment variables added like this are encrypted (secret; not displayed in the logs).
Two exceptions from adding secret variables through web UI
and using instead .travis.yml
file (that only Travis CI can decrypt):
- configuration for Slack notifications
- Githib Releases provider API key
You'll need to use the official (and Ruby heavy) Travis CI client for that.
On MacOS run brew install travis
to install it.
travis encrypt --com something_super_secret
Now you can add the secret: "..."
text to your .travis.yml
file.
For more info, see:
- https://docs.travis-ci.com/user/encryption-keys/
- https://docs.travis-ci.com/user/best-practices-security/
If your repository is transcrypt
-ed, and you want to access the secrets in Travis CI,
you need to add YP_TRANSCRYPT_PASSWORD
variable in Travis Web UI.
The decryption of the repository will happen automatically in non-pull-request builds,
if .travis.yml
runs ./travis.sh before_install
in before_install
(default in the .travis.yml
template; see actual command).
To make the setup faster and avoid looking for secrets all over different places, you can manually get all the secrets in existing repo.
To do so, start a debugging session as described in debugging section.
After logging in, run command(s) to get your var values.
printenv | grep MY_SECRET_VAR_PREFIX_
- Go to https://some-org-name.slack.com/apps/manage, find "Travis CI" and there existing integration between Travis and your Slack
- Click "pencil" button ("Edit configuration") and note down
Token
- Open terminal in the repository folder
- Generate new Travis secret as mentioned in Secrets.
Assuming that you want notifications in #cloud-ci channel command will look like:
- in a case of a public repository
yplatform/bin/travis-encrypt "ysoftwareab:<token>#cloud-ci"
- in a case of an internal/private repository
travis encrypt --pro "ysoftwareab:<token>#cloud-ci"
(you will need to runtravis login --pro
before that)
- in a case of a public repository
- Add secret in the
.travis.yml
and configure other options
notifications:
email: true
slack:
rooms:
# cloud-ci
- secure: "<your encrypted token here>"
on_success: change
on_pull_requests: false
If you are using another CI that supports Slack webhooks instead, or if you use a tool like slack-echo to send Slack messages, you can find the webhook URL like this:
- Go to https://some-org-name.slack.com/apps/manage/custom-integrations
- Click "Incoming Webhooks" and find "cloud-ci"
- Click "pencil" button ("Edit configuration") and note down
Webhook URL
under "Integration Settings" - Add an environment variable (e.g. via the Travis UI) named
SLACK_WEBHOOK
with the value ofWebhook URL
If you are planning to release via Travis CI (primarily for high-level packages):
- give access to the repo to
zz-svc-pro-github
team with a levelWrite
, so it will be able to push releases - see how to release.