travis-build

.travis.yml => build.sh converter

  • 所有者: travis-ci/travis-build
  • 平台:
  • 许可证: MIT License
  • 分类:
  • 主题:
  • 喜欢:
    0
      比较:

Github星跟踪图

Travis Build Build Status

Travis Build exposes an API that Travis
Workers
and Job
Board
use to generate a bash script
which is then copied to the job execution environment and executed, with the
resulting output streamed back to Travis.

This code base has gone through several iterations of development, and was
originally extracted from the legacy Travis
Worker
, before taking its current
form.

Running test suites

Run

bundle exec rake spec

Use as addon for Travis CLI

You can set travis-build up as a plugin for the command line
client
:

git clone https://github.com/travis-ci/travis-build
cd travis-build
mkdir -p ~/.travis
ln -s $PWD ~/.travis/travis-build
gem install bundler
bundle install --gemfile ~/.travis/travis-build/Gemfile
bundler binstubs travis

You will now be able to run travis compile, which produces the bash script
that runs the specified job, except that the secure environment variables are
not defined, and that the build matrix expansion is not considered, e.g:

~/.travis/travis-build/bin/travis compile

Important

The bash script generated by the compile command contains commands that make changes
to the system on which it is executed (e.g., edit /etc/resolv.conf, install software).
Some require sudo privileges and they are not easily undone.

It is highly recommended that you run this in a container or other virtualized
environment.

Invocation

The command can be invoked in 3 ways:

Without an argument, it produces and prints a bash script from the actions in
the local .travis.yml without considering env and matrix values
(travis-build is unable to expand these keys correctly).

~/.travis/travis-build/bin/travis compile

With a single integer, it produces the script for the given build (or the first
job of that build matrix).

~/.travis/travis-build/bin/travis compile 8

With an argument of the form M.N, it produces the bash script for the job
M.N.

~/.travis/travis-build/bin/travis compile 351.2

The generated script can be used in a container or virtualized environment that
closely mimics Travis CI's build environment to aid you in debugging the build
failures. Instructions for running such a container are available
in the Travis CI docs.

Raw CLI script

In addition to the travis CLI plugin you can also run the standalone CLI script:

bundle exec script/compile < payload.json > build.sh

Docker container

If you want to run travis-build locally on your machine (e.g. to interact with
worker), you can also run it as a docker
container with docker-compose:

First, build the image:

docker-compose build web

Second, run the image:

docker-compose run web

You may wish to run with a different setup for local development.
The following shows running travis-build in the development
environment, forwarding the Docker image's port 4000 to the host's
port 4000:

docker-compose run -e RACK_ENV=development -p 4000:4000 web

to build and run it. This will create a container with the contents of the travis-build
repository in the /usr/src/app directory, and start you off in that directory.
From there, you can run the commands listed in the Use as addon for Travis CLI
section to make the compile command available to Travis CLI within the container.

See LICENSE file.

Copyright (c) 2011-2016 Travis CI development
team
.

主要指标

概览
名称与所有者travis-ci/travis-build
主编程语言Ruby
编程语言Ruby (语言数: 5)
平台
许可证MIT License
所有者活动
创建于2011-10-03 21:46:00
推送于2025-07-04 07:13:30
最后一次提交2025-07-04 09:13:28
发布数23
最新版本名称deploy_2025.05.19 (发布于 )
第一版名称v0.1.0 (发布于 )
用户参与
星数655
关注者数44
派生数429
提交数7.1k
已启用问题?
问题数0
打开的问题数0
拉请求数1650
打开的拉请求数85
关闭的拉请求数333
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?