A simple command-line tool for running a Jenkins test job before pushing code to a remote repo
$ gem install test-drive
$ test-drive -h
Usage: test-drive [options]
A simple command-line tool for running a Jenkins test job before pushing code to a remote repo
v0.0.3
Options:
-h, --help Show command line help
-s, --server JENKINS_URL URL for the Jenkins server
-u, --user USER Jenkins user ID
-p, --password API_KEY Jenkins password or API token
-j, --job TARGET_JOB Jenkins job to be triggered
-n, --[no-]push Option to enable (or suppress) pushing to the remote repo
--version Show help/version info
--log-level LEVEL Set the logging level
(debug|info|warn|error|fatal)
(Default: info)
Default values can be placed in ~/.test-drive.yml
This app assumes that you have a Jenkins job already configured as follows:
- It takes a file parameter called 'patch'
- It pulls your source code from origin/master and executes a shell command that runs
echo "" >> ${WORKSPACE}/patch
git apply ${WORKSPACE}/patch
- It then executes your desired test suite and runs
git apply --reverse ${WORKSPACE}/patch
to teardown (optional but recommended)
On first run, you will have the option of saving your Jenkins credentials to a config
file at ~/.test-drive.yml
. This file may be edited to include any of the allowed
options as defaults.
---
server: https://jenkins.your_org.com/
user: user@your_org.com
password: xxxxxxxxxxxxxxxxxxxxxxxxx
job: YourDefaultJob
push: false
- Fork it ( https://github.com/[my-github-username]/test-drive/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request