2019-11-22 13:50:19 +00:00
|
|
|
pipeline{
|
2019-12-11 13:55:40 +00:00
|
|
|
agent none
|
2019-11-22 13:50:19 +00:00
|
|
|
stages {
|
2019-12-11 13:55:40 +00:00
|
|
|
stage ('Master build') {
|
|
|
|
agent { node { label 'master' } }
|
|
|
|
stages {
|
2019-12-11 16:49:32 +00:00
|
|
|
stage ('Check for RFC/WIP builds') {
|
|
|
|
when {
|
|
|
|
changeRequest comparator: 'REGEXP', title: '.*(rfc|RFC|wip|WIP).*'
|
|
|
|
beforeAgent true
|
|
|
|
}
|
|
|
|
steps {
|
|
|
|
error("Failing as this is marked as a WIP or RFC PR.")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Cancel older builds') {
|
2019-12-11 13:55:40 +00:00
|
|
|
steps {
|
|
|
|
cancelPreviousBuilds()
|
|
|
|
}
|
|
|
|
}
|
2019-11-22 13:50:19 +00:00
|
|
|
}
|
2019-05-23 16:45:13 +01:00
|
|
|
}
|
2019-12-11 13:55:40 +00:00
|
|
|
stage ('Worker build') {
|
|
|
|
agent { node { label 'bionic' } }
|
|
|
|
options {
|
|
|
|
timeout(time: 1, unit: 'HOURS')
|
2019-11-22 13:50:19 +00:00
|
|
|
}
|
2019-12-11 13:55:40 +00:00
|
|
|
stages {
|
|
|
|
stage ('Checkout') {
|
|
|
|
steps {
|
|
|
|
checkout scm
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Install system packages') {
|
|
|
|
steps {
|
|
|
|
sh "sudo DEBIAN_FRONTEND=noninteractive apt-get install -yq build-essential mtools libssl-dev pkg-config"
|
2019-12-12 09:56:41 +01:00
|
|
|
sh "sudo apt-get install -yq flex bison libelf-dev qemu-utils qemu-system libglib2.0-dev libpixman-1-dev libseccomp-dev libcap-ng-dev socat"
|
2019-12-11 13:55:40 +00:00
|
|
|
sh "sudo snap install docker"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Install Rust') {
|
|
|
|
steps {
|
|
|
|
sh "nohup curl https://sh.rustup.rs -sSf | sh -s -- -y"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Run Cargo tests') {
|
|
|
|
steps {
|
|
|
|
sh "scripts/run_cargo_tests.sh"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Run OpenAPI tests') {
|
|
|
|
steps {
|
|
|
|
sh "scripts/run_openapi_tests.sh"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Run unit tests') {
|
|
|
|
steps {
|
|
|
|
sh "scripts/run_unit_tests.sh"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Run integration tests') {
|
|
|
|
steps {
|
|
|
|
sh "sudo mount -t tmpfs tmpfs /tmp"
|
|
|
|
sh "scripts/run_integration_tests.sh"
|
|
|
|
}
|
|
|
|
}
|
2019-12-11 08:49:06 +01:00
|
|
|
}
|
|
|
|
}
|
2019-12-11 13:55:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
def cancelPreviousBuilds() {
|
|
|
|
// Check for other instances of this particular build, cancel any that are older than the current one
|
|
|
|
def jobName = env.JOB_NAME
|
|
|
|
def currentBuildNumber = env.BUILD_NUMBER.toInteger()
|
|
|
|
def currentJob = Jenkins.instance.getItemByFullName(jobName)
|
|
|
|
|
|
|
|
// Loop through all instances of this particular job/branch
|
|
|
|
for (def build : currentJob.builds) {
|
|
|
|
if (build.isBuilding() && (build.number.toInteger() < currentBuildNumber)) {
|
|
|
|
echo "Older build still queued. Sending kill signal to build number: ${build.number}"
|
|
|
|
build.doStop()
|
2019-11-22 13:50:19 +00:00
|
|
|
}
|
2019-05-23 16:45:13 +01:00
|
|
|
}
|
|
|
|
}
|