Deployment
This page documents deployments using dpl v1 which is the default version. The next major version dpl v2 will be released soon. Please see the announcement blog post on details about the release process. Documentation for dpl v2 can be found here.
Supported Providers #
Continuous Deployment to the following providers is supported:
- anynines
- Atlas
- AWS CodeDeploy
- AWS Elastic Beanstalk
- AWS Lambda
- AWS OpsWorks
- AWS S3
- Azure Web Apps
- bintray
- BitBalloon
- Bluemix CloudFoundry
- Boxfuse
- Catalyze
- Chef Supermarket
- Cloud 66
- CloudFoundry
- Cargo
- Engine Yard
- GitHub Pages
- GitHub Releases
- Google App Engine
- Google Cloud Storage
- Google Firebase
- Hackage
- Hephy
- Heroku
- Launchpad
- npm
- OpenShift
- packagecloud.io
- Puppet Forge
- PyPI
- Rackspace Cloud Files
- RubyGems
- Scalingo
- Script
- Snap Store
- Surge.sh
- TestFairy
- Transifex
To deploy to a custom or unsupported provider, use the after-success build stage or script provider.
Uploading Files and skip_cleanup #
When deploying files to a provider, prevent Travis CI from resetting your
working directory and deleting all changes made during the build ( git stash
--all
) by adding skip_cleanup
to your .travis.yml
:
deploy:
skip_cleanup: true
Deploying to Multiple Providers #
Deploying to multiple providers is possible by adding the different providers
to the deploy
section as a list. For example, if you want to deploy to both
cloudControl and Heroku, your deploy
section would look something like this:
deploy:
- provider: cloudcontrol
email: "YOUR CLOUDCONTROL EMAIL"
password: "YOUR CLOUDCONTROL PASSWORD"
deployment: "APP_NAME/DEP_NAME"
- provider: heroku
api_key: "YOUR HEROKU API KEY"
Conditional Releases with on:
#
Set your build to deploy only in specific circumstances by configuring the on:
key for any deployment provider.
deploy:
provider: s3
access_key_id: "YOUR AWS ACCESS KEY"
secret_access_key: "YOUR AWS SECRET KEY"
bucket: "S3 Bucket"
skip_cleanup: true
on:
branch: release
condition: $MY_ENV = super_awesome
When all conditions specified in the on:
section are met, your build will deploy.
Use the following options to configure conditional deployment:
-
repo
: in the formowner_name/repo_name
. Deploy only when the build occurs on a particular repository. For exampledeploy: provider: s3 on: repo: travis-ci/dpl
-
branch
: name of the branch. If omitted, this defaults to theapp
-specific branch, ormaster
. If the branch name is not known ahead of time, you can specifyall_branches: true
instead ofbranch:
and use other conditions to control your deployment. -
jdk
,node
,perl
,php
,python
,ruby
,scala
,go
: for language runtimes that support multiple versions, you can limit the deployment to happen only on the job that matches a specific version. -
condition
: deploy when a single bash condition evaluates totrue
. This must be a string value, and is equivalent toif [[ <condition> ]]; then <deploy>; fi
. For example,$CC = gcc
. -
tags
can betrue
,false
or any other string:tags: true
: deployment is triggered if and only if$TRAVIS_TAG
is set. Depending on your workflow, you may set$TRAVIS_TAG
explicitly, even if this is a non-tag build when it was initiated. This causes thebranch
condition to be ignored.tags: false
: deployment is triggered if and only if$TRAVIS_TAG
is empty. This also causes thebranch
condition to be ignored.- When
tags
is not set, or set to any other value,$TRAVIS_TAG
is ignored, and thebranch
condition is considered, if it is set.
Examples of Conditional Deployment #
This example deploys to Appfog only from the staging
branch when the test has run on Node.js version 0.11.
language: node_js
deploy:
provider: appfog
user: ...
api_key: ...
on:
branch: staging
node_js: '0.11' # this should be quoted; otherwise, 0.10 would not work
The next example deploys using a custom script deploy.sh
, only for builds on the branches staging
and production
.
deploy:
provider: script
script: deploy.sh
on:
all_branches: true
condition: $TRAVIS_BRANCH =~ ^(staging|production)$
The next example deploys using custom scripts deploy_production.sh
and deploy_staging.sh
depending on the branch that triggered the job.
deploy:
- provider: script
script: deploy_production.sh
on:
branch: production
- provider: script
script: deploy_staging.sh
on:
branch: staging
The next example deploys to S3 only when $CC
is set to gcc
.
deploy:
provider: s3
access_key_id: "YOUR AWS ACCESS KEY"
secret_access_key: "YOUR AWS SECRET KEY"
skip_cleanup: true
bucket: "S3 Bucket"
on:
condition: "$CC = gcc"
This example deploys to GitHub Releases when a tag is set and the Ruby version is 2.0.0.
deploy:
provider: releases
api_key: "GITHUB OAUTH TOKEN"
file: "FILE TO UPLOAD"
skip_cleanup: true
on:
tags: true
rvm: 2.0.0
Adding a deployment provider #
We are working on adding support for other PaaS providers. If you host your application with a provider not listed here and you would like to have Travis CI automatically deploy your application, please get in touch.
If you contribute to or experiment with the deploy tool make sure you use the edge version from GitHub:
deploy:
provider: awesome-experimental-provider
edge: true
Pull Requests #
Note that pull request builds skip the deployment step altogether.