This test harness has an abstraction called JenkinsController
that allows you to use different logic for starting/stopping Jenkins.
We use this to so that the same set of tests can be run against many different ways of launching Jenkins,
such as java -jar jenkins.war
, Jenkins on JBoss, Jenkins via debian package, etc.
To select a controller, run the test with the TYPE
environment variable set to the controller ID, such as:
TYPE=remote_sysv mvn test
.
Common configuration of Controllers can be done through environment variables, and the following controller-specific section describes them.
For more sophisticated customization, see WIRING.md.
All local controllers run both test harness and Jenkins under test on local machine. Common environment variables for local controllers:
JENKINS_JAVA_HOME
the JVM home to use for running Jenkins. If not specified, the first ofJAVA_HOME
, or the JVM used to launch the tests will be used.JENKINS_JAVA_OPTS
Adds additional options to the java process like-Xms=XXm -Xmx=XXXm
.INTERACTIVE
keep browser session opened after failed scenario for interactive investigation.
You can disable the logging output of Jenkins by setting the system property quite
on
the command line.
This controller runs Jenkins via java -jar jenkins.war
on the same host where the test is run. This is the default controller.
This controller runs Jenkins via java -jar jenkins.war
much like the Winstone controller, except
that it launches Winstone inside a docker container. This allows users to better control the environment
in which Jenkins runs in, without incurring the overhead of Vagrant.
DOCKER_IMAGE
the docker container image name (or image ID) to run Jenkins in.
The ability to specify the docker image is particularly useful to ensure that tests are run against the consistent version of JDK and build tools.
This controller deploys Jenkins inside Tomcat and run the test with it. This controller requires a functioning Tomcat installation listening on port 8080, on the same system that the tests run. During the test, Jenkins is deployed here, and Tomcat gets started/stopped.
The behaviour of this controller can be customized through the following environment variables.
CATALINA_HOME
The directory in which Tomcat is already installed. If this is not specified, the first existing directory from the following list will be used: atomcat
directory as a sibling to the resolvedjenkins.war
,WORKSPACE/tomcat
and$(pwd)/tomcat
.
Similar to the above Tomcat controller except it uses JBoss.
The behaviour of this controller can be customized through the following environment variables.
JBOSS_HOME
The directory in which JBoss is already installed. If this is not specified, the first existing directory from the following list will be used: ajboss
directory as a sibling to the resolvedjenkins.war
,WORKSPACE/jboss
and$(pwd)/jboss
.
This controller assumes that you already have a Jenkins instance somewhere that you want the tests to run in.
Note that tests mutate this Jenkins instance, so this is not meant to be used with your production Jenkins instance.
Instead, run java -jar jenkins.war
somewhere, and use this controller.
The behaviour of this controller can be customized through the following environment variables.
JENKINS_URL
the URL to the running Jenkins. Defaults tohttp://localhost:8080/
This controller is useful when you want to debug Jenkins while you run a test. It can be also used during iterative test development to execute tests quickly.
There's a family of controllers who uses Vagrant to launch a virtual machine, then launch jenkins.war inside.
When run for the first time, this test harness will create a virtual machine. To make repeated tests fast, the VM won't get shut down automatically at the end of a run, so the VM will keep running.
To do shut it down, cd vagrant/*
and run vagrant halt
. You can run any other vagrant commands
in this manner, which is useful for debugging.
You can also create pre-configure.sh
and/or post-configure.sh
in the current directory as needed
to customize how the Vagrant VM is initialized. These scripts are copied into the VM and then executed:
pre-configure.sh
runs before the controller attempts to install Jenkinspost-configure.sh
runs after the controller finished installing Jenkins
This controller uses Vagrant to run Ubuntu, then deploy Jenkins from an APT repository as a debian package. (This controller is not yet capable of testing individual *.deb
file.)
REPO_URL
The location of APT repository in the format of/etc/apt/sources.list
, such ashttp://pkg.jenkins-ci.org/debian binary/
This controller uses Vagrant to run CentOS, then deploy Jenkins from an RPM repository.
This controller is not yet capable of testing individual *.rpm
file.
REPO_URL
The location of RPM repository, such ashttp://pkg.jenkins-ci.org/opensuse/
This controller uses Vagrant to run CentOS, then deploy Jenkins from an RPM repository.
This controller is not yet capable of testing individual *.rpm
file.
REPO_URL
The location of RPM repository, such ashttp://pkg.jenkins-ci.org/opensuse/