Jenkinsfile Runner is an experiment to package Jenkins pipeline execution as a command line tool. The intend use cases include:
- Use Jenkins in Function-as-a-Service context
- Assist editing
Jenkinsfile
locally - Integration test shared libraries
Jenkinsfile Runner can be run in command line or in Docker. In case you want to run it in command line just follow these steps:
- Download the jar file available in artifactory or build the source code from this repository (see contributing guidelines)
- Prepare the execution environment
- Run the command
Find jenkins.war
that represents the version of Jenkins that you'd like to use,
then unzip it somewhere.
wget http://mirrors.jenkins.io/war-stable/latest/jenkins.war
unzip jenkins.war -d /tmp/jenkins
Next, create a directory and assemble all the plugins that you'd like to use with the build. One way to do this is to run Jenkins setup wizard and install the default set of plugins. This is a gap intended to be filled with configuration as code
JENKINS_HOME=/tmp/jenkins_home java -jar jenkins.war
# go to http://localhost:8080/, follow the installation step
# and install the recommended set of plugins
Say you have your Git repository checked out at ~/foo
that contains Jenkinsfile
and your source code.
You can now run Jenkinsfile Runner like this:
jenkinsfile-runner -w <path to war> -p <path to plugins> -f <path to Jenkinsfile> [-a "param1=Hello" -a "param2=value2"]
Sample Jenkinsfile:
$ cat ~/foo/Jenkinsfile
pipeline {
agent any
parameters {
string(name: 'param1', defaultValue: '', description: 'Greeting message')
string(name: 'param2', defaultValue: '', description: '2nd parameter')
}
stages {
stage('Build') {
steps {
echo 'Hello world!'
echo "message: ${params.param1}"
echo "param2: ${params.param2}"
sh 'ls -la'
}
}
}
}
Output:
$ ./app/target/appassembler/bin/jenkinsfile-runner -w /tmp/jenkins -p /tmp/jenkins_home/plugins -f ~/foo/ -a "param1=Hello¶m2=value2"
Started
Running in Durability level: PERFORMANCE_OPTIMIZED
Running on Jenkins in /tmp/jenkinsTests.tmp/jenkins8090792616816810094test/workspace/job
[Pipeline] node
[Pipeline] {
[Pipeline] // stage
[Pipeline] stage
[Pipeline] { (Build)
[Pipeline] echo
Hello world!
[Pipeline] echo
message: Hello
[Pipeline] echo
param2: value2
[Pipeline] sh
[job] Running shell script
+ ls -la
total 12
drwxrwxr-x 2 kohsuke kohsuke 4096 Feb 24 15:36 .
drwxrwxr-x 4 kohsuke kohsuke 4096 Feb 24 15:36 ..
-rw-rw-r-- 1 kohsuke kohsuke 0 Feb 24 15:36 abc
-rw-rw-r-- 1 kohsuke kohsuke 179 Feb 24 15:36 Jenkinsfile
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
[Pipeline] End of Pipeline
Finished: SUCCESS
The exit code reflects the result of the build. The test
directory of this workspace includes a very simple
example of Jenkinsfile that can be used to demo Jenkinsfile Runner.
The executable of Jenkinsfile Runner allows its invocation with these cli options:
# Usage: jenkinsfile-runner -w [warPath] -p [pluginsDirPath] -f [jenkinsfilePath] [other options]
--runHome FILE : Path to the empty Jenkins Home directory to use for
this run. If not specified a temporary directory
will be created. Note that the folder specified via
--runHome will not be disposed after the run.
--runWorkspace FILE : Path to the workspace of the run to be used within
the node{} context. It applies to both Jenkins
master and agents (or side containers) if any.
Requires Jenkins 2.119 or above
-a (--arg) : Parameters to be passed to workflow job. Use
multiple -a switches for multiple params
-u (--keep-undefined-parameters) : Keep undefined parameters if set, defaults
to false.
-f (--file) FILE : Path to Jenkinsfile (or directory containing a
Jenkinsfile) to run, default to ./Jenkinsfile.
-ns (--no-sandbox) : Disable workflow job execution within sandbox
environment
-p (--plugins) FILE : plugins required to run pipeline. Either a
plugins.txt file or a /plugins installation
directory. Defaults to plugins.txt.
-n (--job-name) VAL : Name of the job the run belongs to, defaults to 'job'
-b (--build-number) N : Build number of the run, defaults to 1.
-c (--cause) VAL : A string describing the cause of the run.
It will be attached to the build so that it appears in the
build log and becomes available to plug-ins and pipeline steps.
-jv (--jenkins-version) VAL : jenkins version to use (only in case 'warDir' is not
specified). Defaults to latest LTS.
-w (--jenkins-war) FILE : path to exploded jenkins war directory.
-v (--version) : Display the current version
-h (--help) : Print this help
where `-a`, `-ns`, `--runHome`, `--runWorkspace` and `-jv` are optional.
Any parameter values, for parameters defined on workflow job within parameters
statement
can be passed to the Jenkinsfile Runner using -a
or --arg
switches in key=value format.
$ ./app/target/appassembler/bin/jenkinsfile-runner \
-w /tmp/jenkins \
-p /tmp/jenkins_home/plugins \
-f ~/foo/ \
# pipeline has two parameters param1 and param2
-a "param1=Hello" \
-a "param2=value2"
See the demos and the Packaging into Docker image page for further detail.
You can build your customized Jenkinsfile Runner image using the Vanilla Dockerfile included in this repository or with Custom WAR Packager
Once the Docker image is built, Jenkinsfile Runner can be launched simply as...
docker run --rm -v $(shell pwd)/Jenkinsfile:/workspace/Jenkinsfile ${JENKINSFILE_RUNNER_IMAGE}
Advanced options:
-
JAVA_OPTS
environment variable can be passed to pass extra options to the image -
In the Vanilla
Dockerfile
the master workspace is mapped to/build
. This directory can be exposed as a volume. The docker image generated with Custom War Packager maps the workspace to/build
by default and it can be exposed as well. However it is possible to override that directory if both the-v
docker option and the--runWorkspace
Jenkinsfile Runner option are specified. -
By default the JENKINS_HOME folder is randomly created and disposed afterwards. With the
--runHome
parameter in combination with the-v
docker option it is possible to specify a folder.
e.g.docker run -v /local/Jenkinsfile:/workspace/Jenkinsfile -v /local/jenkinsHome:/jenkinsHome ${JENKINSFILE_RUNNER_IMAGE} --runHome /jenkinsHome
This way you can access the build metadata in
<jenkinsHome>/jobs/job/builds/1
, like the build.xml, logs, and workflow data, even after the container finished. -
The
-ns
and-a
options can be specified and passed to the image in the same way as the command line execution.
docker build -t jenkins/jenkinsfile-runner .
During development you can reuse the local machine build instead of doing a full build from scratch
docker build -t jenkins/jenkinsfile-runner:dev -f Dockerfile-dev .
Jenkinsfile Runner Jenkins JIRA for tracking of tasks and defects
(project=JENKINS
, component=jenkinsfile-runner
).
GitHub issues can be also used to report issues, but it is not recommended.
For JIRA please follow these guidelines when reporting issues.
If you see a security issue in the component, please follow the vulnerability reporting guidelines.