www.travis-ci.com Open in urlscan Pro
2606:4700:20::681a:614  Public Scan

Submitted URL: http://travis-ci.org/
Effective URL: https://www.travis-ci.com/
Submission: On September 02 via api from US — Scanned from DE

Form analysis 3 forms found in the DOM

<form id="contact-form263" class="breakdance-form breakdance-form--horizontal "
  data-options="{&quot;slug&quot;:&quot;custom&quot;,&quot;name&quot;:&quot;Contact Form&quot;,&quot;ajaxUrl&quot;:&quot;https:\/\/www.travis-ci.com\/wp-admin\/admin-ajax.php&quot;,&quot;clearOnSuccess&quot;:true,&quot;hideOnSuccess&quot;:false,&quot;successMessage&quot;:&quot;Your message has been received!&quot;,&quot;errorMessage&quot;:&quot;Something went wrong&quot;,&quot;redirect&quot;:true,&quot;redirectUrl&quot;:&quot;https:\/\/www.travis-ci.com\/newsletter\/&quot;,&quot;customJavaScript&quot;:&quot;&quot;,&quot;recaptcha&quot;:{&quot;key&quot;:&quot;&quot;,&quot;enabled&quot;:false},&quot;honeypot_enabled&quot;:false,&quot;popupsOnSuccess&quot;:[],&quot;popupsOnError&quot;:[]}"
  data-steps="0">
  <div class="breakdance-form-field breakdance-form-field--email">
    <input class="breakdance-form-field__input" id="email" aria-describedby="email" type="email" name="fields[email]" placeholder="Enter email address..." value="" required="">
  </div>
  <div class="breakdance-form-field breakdance-form-footer">
    <button type="submit" class="button-atom button-atom--primary breakdance-form-button breakdance-form-button__submit">
      <span class="button-atom__text">Subscribe</span>
    </button>
    <input type="hidden" name="form_id" value="263">
    <input type="hidden" name="post_id" value="105">
  </div>
</form>

<form id="contact-form383" class="breakdance-form breakdance-form--vertical "
  data-options="{&quot;slug&quot;:&quot;custom&quot;,&quot;name&quot;:&quot;Contact Form&quot;,&quot;ajaxUrl&quot;:&quot;https:\/\/www.travis-ci.com\/wp-admin\/admin-ajax.php&quot;,&quot;clearOnSuccess&quot;:true,&quot;hideOnSuccess&quot;:false,&quot;successMessage&quot;:&quot;Your message has been received!&quot;,&quot;errorMessage&quot;:&quot;Something went wrong&quot;,&quot;redirect&quot;:true,&quot;redirectUrl&quot;:&quot;https:\/\/www.travis-ci.com\/newsletter\/&quot;,&quot;customJavaScript&quot;:&quot;&quot;,&quot;recaptcha&quot;:{&quot;key&quot;:&quot;&quot;,&quot;enabled&quot;:false},&quot;honeypot_enabled&quot;:false,&quot;popupsOnSuccess&quot;:[],&quot;popupsOnError&quot;:[]}"
  data-steps="0">
  <div class="breakdance-form-field breakdance-form-field--email">
    <input class="breakdance-form-field__input" id="email" aria-describedby="email" type="email" name="fields[email]" placeholder="Enter email address..." value="" required="">
  </div>
  <div class="breakdance-form-field breakdance-form-footer">
    <button type="submit" class="button-atom button-atom--primary breakdance-form-button breakdance-form-button__submit">
      <span class="button-atom__text">Subscribe</span>
    </button>
    <input type="hidden" name="form_id" value="383">
    <input type="hidden" name="post_id" value="105">
  </div>
</form>

<form id="contact-form339" class="breakdance-form breakdance-form--horizontal "
  data-options="{&quot;slug&quot;:&quot;custom&quot;,&quot;name&quot;:&quot;Contact Form&quot;,&quot;ajaxUrl&quot;:&quot;https:\/\/www.travis-ci.com\/wp-admin\/admin-ajax.php&quot;,&quot;clearOnSuccess&quot;:true,&quot;hideOnSuccess&quot;:false,&quot;successMessage&quot;:&quot;Your message has been received!&quot;,&quot;errorMessage&quot;:&quot;Something went wrong&quot;,&quot;redirect&quot;:true,&quot;redirectUrl&quot;:&quot;https:\/\/www.travis-ci.com\/newsletter\/&quot;,&quot;customJavaScript&quot;:&quot;&quot;,&quot;recaptcha&quot;:{&quot;key&quot;:&quot;&quot;,&quot;enabled&quot;:false},&quot;honeypot_enabled&quot;:false,&quot;popupsOnSuccess&quot;:[],&quot;popupsOnError&quot;:[]}"
  data-steps="0">
  <div class="breakdance-form-field breakdance-form-field--email">
    <input class="breakdance-form-field__input" id="email" aria-describedby="email" type="email" name="fields[email]" placeholder="Enter email address..." value="" required="">
  </div>
  <div class="breakdance-form-field breakdance-form-footer">
    <button type="submit" class="button-atom button-atom--primary breakdance-form-button breakdance-form-button__submit">
      <span class="button-atom__text">Subscribe</span>
    </button>
    <input type="hidden" name="form_id" value="339">
    <input type="hidden" name="post_id" value="105">
  </div>
</form>

Text Content

 * Why Travis CI
    * Overview
    * Why Travis CI
    * Self-Hosted

 * Pricing
 * Developers
    * Quickstart
    * Documentation
    * Support
    * Blog
    * Community

 * Contact Sales

Get Free Trial
Sign In
 * Why Travis CI
    * Overview
    * Why Travis CI
    * Self-Hosted

 * Pricing
 * Developers
    * Quickstart
    * Documentation
    * Support
    * Blog
    * Community

 * Contact Sales

Get Free Trial
Sign In


HOW DEVELOPERS BUILD SIMPLE, TRUSTWORTHY CI/CD PIPELINES

Join hundreds of thousands who define tests and deployments in minutes, then
scale up simply with parallel or multi-environment builds using Travis CI’s
precision syntax—all designed with the developer experience in mind.
Get Free Trial
Contact Sales



WHERE DEVELOPERS TRUST TRAVIS CI WITH TESTING AND AUTOMATION




BUILD YOUR NEW CI/CD PIPELINE IN 20 MINUTES OR LESS

Whether starting from scratch or rebuilding a rich ecosystem, get pipelines
flowing with preconfigured environments for your language and a minimal syntax
with up to 50% less YAML or JSON.
Python JavaScript (Node.js) Java C/C++ PHP Rust Go C# Ruby 30+ Others Supported
Python JavaScript (Node.js) Java C/C++ PHP Rust Go C# Ruby 30+ Others Supported

language: python
python:
  - "3.7"
  - "3.8"
  - "3.9"

# Command to install dependencies
install:
  - pip install -r requirements.txt
  - pip install pytest pytest-cov

# Command to run tests
script:
  - pytest --cov=./ tests/

# Specify branches to build
branches:
  only:
    - main
    - develop

# Cache pip dependencies
cache: pip

# Run jobs in parallel
jobs:
  include:
    - name: "Lint"
      python: "3.9"
      before_script:
        - pip install flake8
      script:
        - flake8 .

    - name: "Docs"
      python: "3.9"
      before_script:
        - pip install sphinx
      script:
        - sphinx-build -b html docs docs/_build

after_success:
  - pip install coveralls
  - coveralls

notifications:
  email:
    on_success: never
    on_failure: always

language: node_js
node_js:
  - "12"
  - "14"
  - "16"
# Specify the operating system
os:
  - linux
  - osx
# Cache dependencies
cache:
  directories:
    - node_modules

# Install dependencies
install:
  - npm ci

# Run tests
script:
  - npm run test
  - npm run build

# Run jobs in parallel
jobs:
  include:
    - stage: lint
      node_js: "16"
      script: npm run lint

    - stage: coverage
      node_js: "16"
      script: npm run test:coverage
# Deploy to npm
deploy:
  provider: npm
  email: "your-npm-email@example.com"
  api_key: $NPM_TOKEN
  on:
    tags: true
    branch: main
# Notifications
notifications:
  email:
    on_success: never
    on_failure: always
  slack:
    rooms:
      - secure: "encrypted-slack-webhook-url"

language: java
jdk:
  - openjdk11
  - openjdk14

# Cache dependencies
cache:
  directories:
    - $HOME/.m2

# Build stages
stages:
  - test
  - name: deploy
    if: branch = main

jobs:
  include:
    - stage: test
      name: "Unit Tests"
      script: mvn test

    - stage: test
      name: "Integration Tests"
      script: mvn verify -Pintegration-tests

    - stage: deploy
      name: "Deploy to Staging"
      script: mvn deploy -Pstaging

# Notifications
notifications:
  email:
    recipients:
      - team@example.com
    on_success: change
    on_failure: always

# Before install steps
before_install:
  - chmod +x mvnw

# Main build script
script:
  - ./mvnw clean install

# After success steps
after_success:
  - bash <(curl -s https://codecov.io/bash)

# Only build these branches
branches:
  only:
    - main
    - develop

language: cpp
compiler:
  - gcc
  - clang
before_install:
  - sudo apt-get update
  - sudo apt-get install -y cmake
script:
  - mkdir build
  - cd build
  - cmake ..
  - make
  - make test
notifications:
  email: false

language: php

php:
  - 7.4
  - 8.0
  - 8.1

before_script:
  - composer self-update
  - composer install --no-interaction

script:
  - vendor/bin/phpunit
  - vendor/bin/phpcs

cache:
  directories:
    - $HOME/.composer/cache

notifications:
  email: false

language: rust

rust:
  - stable
  - beta
  - nightly

matrix:
  allow_failures:
    - rust: nightly
  fast_finish: true

cache: cargo

before_script:
  - rustup component add clippy

script:
  - cargo build --verbose
  - cargo test --verbose
  - cargo clippy -- -D warnings

notifications:
  email: false

language: go

go:
  - 1.16.x
  - 1.17.x
  - 1.18.x
  - tip

matrix:
  allow_failures:
    - go: tip
  fast_finish: true

before_install:
  - go get -t -v ./...

script:
  - go test -race -coverprofile=coverage.txt -covermode=atomic
  - go vet ./...
  - diff -u <(echo -n) <(gofmt -d .)

after_success:
  - bash <(curl -s https://codecov.io/bash)

notifications:
  email: false

language: csharp
mono: none
dotnet: 6.0.100

install:
  - dotnet restore

script:
  - dotnet build
  - dotnet test

notifications:
  email: false

branches:
  only:
    - main
    - develop

cache:
  directories:
    - $HOME/.nuget/packages


language: ruby
rvm:
  - 2.6
  - 2.7
  - 3.0
install:
  - bundle install
script:
  - bundle exec rake test
after_success:
  - bundle exec rake coveralls:push
notifications:
  email:
    recipients:
      - your-email@example.com
    on_success: always
    on_failure: always


EXPLORE MORE WITH TRAVIS CI'S QUICKSTART 


A PRECISION TOOL FOR EVERY CI/CD DEMAND

Travis CI elegantly compacts all your testing automation into one minimal
Configuration as Code file for a true developer experience. Simple syntax and
effortless extensibility.
Build matrix Parallel builds Integrations Notifications Build Stages and
Conditionals Multiple OSs and Architectures
Build matrix Parallel builds Integrations Notifications Build Stages and
Conditionals Multiple OSs and Architectures

language: python
python:
  - "3.7"
  - "3.8"
  - "3.9"
env:
  - DJANGO_VERSION=2.2
  - DJANGO_VERSION=3.0
  - DJANGO_VERSION=3.1
matrix:
  include:
    - python: "3.9"
      env: DJANGO_VERSION=3.2
  exclude:
    - python: "3.7"
      env: DJANGO_VERSION=3.1
  allow_failures:
    - python: "3.9"
      env: DJANGO_VERSION=3.2
before_install:
  - pip install -U pip
  - pip install -U setuptools
  - pip install -q Django==$DJANGO_VERSION
install:
  - pip install -r requirements.txt
script:
  - python manage.py test
after_success:
  - coveralls
notifications:
  email: false

Run tests against different versions of your runtimes or dependencies—or even
multiple languages—for comprehensive automation and absolute quality guarantees
on your way to production.

Learn more

language: python
python:
  - "3.8"

services:
  - mongodb
  - redis
  - mysql

env:
  - DB=mongodb
  - DB=redis
  - DB=mysql

before_script:
  - if [[ "$DB" == "mongodb" ]]; then mongo mydb_test 
--eval 'db.createUser({user:"travis",pwd:"test",roles:
["readWrite"]});'; fi - if [[ "$DB" == "mysql" ]]; 
then mysql -e 'CREATE DATABASE IF NOT EXISTS mydb_test;
'; fi

script:
  - if [[ "$DB" == "mongodb" ]]; then python 
test_mongodb.py; fi
  - if [[ "$DB" == "redis" ]]; then python 
test_redis.py; fi
  - if [[ "$DB" == "mysql" ]]; then python 
test_mysql.py; fi

Quickly split complex operations, like unit and integration tests, into multiple
jobs that give you faster visual feedback on code quality and results—stop
waiting on your pipeline to finish and get back to your IDE.

Learn more

language: python
python:
  - "3.8"

# Install dependencies
install:
  - pip install -r requirements.txt

# Run tests
script:
  - pytest

# Integration with Slack for notifications
notifications:
  slack: your-slack-workspace:your-slack-token

# Integration with Codecov for code coverage reports
after_success:
  - pip install codecov
  - codecov

# Integration with GitHub Pages for documentation deployment
deploy:
  provider: pages
  skip_cleanup: true
  github_token: $GITHUB_TOKEN
  on:
    branch: main

Enable the must-haves, like build status images, static code analysis, and key
management without wasting time on needlessly complex glue. For everything else,
the Travis CI API has your back.

Learn more

language: python
python:
  - "3.8"

script:
  - python -m pytest tests/

notifications:
  email:
    recipients:
      - dev-team@example.com
    on_success: change
    on_failure: always

  slack:
    rooms:
      - secure: "encrypted-slack-webhook-url"
    on_success: always
    on_failure: always
    template:
      - "Build <%{build_url}|#%{build_number}>
 (<%{compare_url}|%{commit}>) of %{repository_slug}
@%{branch} by %{author} %{result} in %{duration}"

  webhooks:
    urls:
      - https://webhook.site/your-unique-id
    on_success: change
    on_failure: always

  irc:
    channels:
      - "irc.freenode.org#myproject"
    template:
      - "%{repository} (%{commit}) : %{message}"
      - "Build details: %{build_url}"

  pushover:
    api_key: "pushover-api-key"
    users:
      - "pushover-user-key"
    template: "%{repository} (%{commit}) : 
%{message} - %{duration}"

after_failure:
  - cat /home/travis/build/your-github-username/
your-repo-name/tests/test-suite.log

Switch on highly customizable notifications to email, Slack, Opsgenie, any
webhook destination, and many more. All you need to bring is your API token and
as little as two fresh lines of YAML.

Learn more

language: python
python:
  - "3.8"

stages:
  - test
  - name: deploy
    if: branch = main

jobs:
  include:
    - stage: test
      name: "Unit Tests"
      script: python -m unittest discover tests/unit

    - stage: test
      name: "Integration Tests"
      script: python -m unittest discover tests/integration

    - stage: deploy
      name: "Deploy to Production"
      script: 
        - pip install awscli
        - aws s3 sync . s3://my-bucket/ --delete

env:
  global:
    - PYTHONPATH=$PYTHONPATH:$TRAVIS_BUILD_DIR

before_install:
  - pip install -r requirements.txt

branches:
  only:
    - main
    - develop

notifications:
  email:
    on_success: never
    on_failure: always

Infinitely organize complex CI/CD pipelines into groups that only run if other
parallel jobs have been completed successfully. Catch failures faster or layer
in smart conditionals to catch edge cases other CI/CD tools lose track of.

Learn more

language: generic

jobs:
  include:
    # Linux builds
    - os: linux
      arch: amd64
    - os: linux
      arch: arm64
    
    # macOS builds
    - os: osx
      osx_image: xcode12.5
    
    # Windows builds
    - os: windows

script:
  - echo "Running tests on $TRAVIS_OS_NAME $TRAVIS_CPU_ARCH"
  - # Add your build and test commands here

notifications:
  email: false

Test your code in parallel on more flexible combinations than any other CI/CD
tool. Mix-and-match  amd64, ppc64le, s390x, arm64, and arm64-graviton2 CPUs with
Linux, macOS, and Windows environments to make your builds edge case-free.

Learn more
.travis.yaml

language: python
python:
- "3.8"
install:
- pip install -r requirements.txt
script:
- python3 pytest.py
.travis.yaml

language: python
python:
- "3.8"
install:
- pip install -r requirements.txt
script:
- python3 pytest.py
.travis.yaml

language: python
python:
- "3.8"
install:
- pip install -r requirements.txt
script:
- python3 pytest.py
.travis.yaml

language: python
python:
- "3.8"
install:
- pip install -r requirements.txt
script:
- python3 pytest.py


THE MOST RESILIENT NAME IN CI/CD


Others commodify CI/CD, building overly complex DevSecOps Platforms. We remain
steadfast in our original mission to help developers conquer their CI/CD
pipelines faster, more fluently, and, dare we say… with more fun?


WHY PAY FOR CI/CD

That’s a tough but fair question. We’re still delivering the simplest and most
extensible CI/CD for developers who want precision tools, not bloated
platforms. 

Travis CI uniquely helps you take ownership of code quality, collaborate better
with your peers, and take ownership of the results you create together.

Why Travis CI


OUR SECURITY-FORWARD PROMISES

GDPR and PrivacyShield compliance. Build isolation to prevent interference.
Clean VMs with every build. 

Plus, easy extensibility for you to protect your software supply chain with our
HashiCorp Vault integration, collaborator management, scoped credentials, signed
artifacts, and much more.

Read On


ENGINEERING-DRIVEN CUSTOMER SUPPORT

Our CI/CD experts are here to help. Have a question before you jump in, or want
to hear about Travis CI Enterprise?

Contact Sales


A GENUINE COMMUNITY

Whether you need tips on extending your pipeline or code examples building a
custom integration with the API, our community of CI/CD experts always steps up.

Join Your Peers


SIMPLE TO START. INTUITIVE TO EXTEND.
DEVELOPED UPON BY HUNDREDS OF THOUSANDS

Get Free Trial
Contact Sales
Product Why Travis CI Self-Hosted
Pricing
Tips, Promotions and Exclusive Offers: Get the Travis CI Newsletter
Subscribe
Developers Security Documentation API Reference Changelog Build Explorer
Resources Quickstart Support Blog FAQ Education Travis CI vs Jenkins
Company About Us Contact Sales Terms & Conditions Privacy
© Copyright 2024, All Rights Reserved
Product Why Travis CI Self-Hosted Pricing
Developers Security Documentation API Reference Changelog Build Explorer
Resources Quickstart Support Blog FAQ Education Travis CI vs Jenkins
Company About Us Contact Sales Terms & Conditions Privacy
Travis CI Newsletter
Get Tips, Promotions and Exclusive Offers
Subscribe
© Copyright 2024, All Rights Reserved
Product Why Travis Self-Hosted
Pricing
Developers Documentation API Reference Changelog Build Explorer
Resources Quickstart Support Blog FAQ Education Travis CI vs Jenkins
Company About Us Contact Sales Terms & Conditions Privacy
Tips, Promotions and Exclusive Offers: Get the Travis CI Newsletter
Subscribe
© Copyright 2024, All Rights Reserved
×
This website uses cookies
This website uses cookies to improve user experience. By using our website you
consent to all cookies in accordance with our Cookie Policy. Read more
Save & Close
Accept all
Decline all
Show details Hide details