2023-03-08 01:22:07 -05:00
import groovy.transform.Field
@Field
def shOutput = ""
def buildxPushTags = ""
2018-05-03 01:43:04 -04:00
pipeline {
2020-02-18 23:55:06 -05:00
agent {
label 'docker-multiarch'
}
options {
buildDiscarder(logRotator(numToKeepStr: '5'))
disableConcurrentBuilds()
2020-05-25 00:53:35 -04:00
ansiColor('xterm')
2020-02-18 23:55:06 -05:00
}
environment {
2023-03-21 03:11:16 -04:00
IMAGE = 'nginx-proxy-manager'
2020-02-18 23:55:06 -05:00
BUILD_VERSION = getVersion()
2023-03-21 03:11:16 -04:00
MAJOR_VERSION = '2'
2023-11-08 16:35:24 -05:00
BRANCH_LOWER = "${BRANCH_NAME.toLowerCase().replaceAll('\\\\', '-').replaceAll('/', '-').replaceAll('\\.', '-')}"
2024-05-20 22:53:07 -04:00
BUILDX_NAME = "npm_${BRANCH_LOWER}_${BUILD_NUMBER}"
2020-02-18 23:55:06 -05:00
COMPOSE_INTERACTIVE_NO_CLI = 1
}
stages {
stage('Environment') {
parallel {
stage('Master') {
when {
branch 'master'
}
steps {
script {
2023-03-08 01:22:07 -05:00
buildxPushTags = "-t docker.io/jc21/${IMAGE}:${BUILD_VERSION} -t docker.io/jc21/${IMAGE}:${MAJOR_VERSION} -t docker.io/jc21/${IMAGE}:latest"
2020-02-18 23:55:06 -05:00
}
}
}
2020-02-19 00:28:27 -05:00
stage('Other') {
when {
not {
branch 'master'
}
}
steps {
script {
// Defaults to the Branch name, which is applies to all branches AND pr's
2023-03-08 01:22:07 -05:00
buildxPushTags = "-t docker.io/jc21/${IMAGE}:github-${BRANCH_LOWER}"
2020-02-19 00:28:27 -05:00
}
}
}
2020-03-11 02:54:10 -04:00
stage('Versions') {
steps {
sh 'cat frontend/package.json | jq --arg BUILD_VERSION "${BUILD_VERSION}" \'.version = $BUILD_VERSION\' | sponge frontend/package.json'
sh 'echo -e "\\E[1;36mFrontend Version is:\\E[1;33m $(cat frontend/package.json | jq -r .version)\\E[0m"'
sh 'cat backend/package.json | jq --arg BUILD_VERSION "${BUILD_VERSION}" \'.version = $BUILD_VERSION\' | sponge backend/package.json'
sh 'echo -e "\\E[1;36mBackend Version is:\\E[1;33m $(cat backend/package.json | jq -r .version)\\E[0m"'
sh 'sed -i -E "s/(version-)[0-9]+\\.[0-9]+\\.[0-9]+(-green)/\\1${BUILD_VERSION}\\2/" README.md'
}
}
2024-10-10 22:56:29 -04:00
stage('Docker Login') {
steps {
withCredentials([usernamePassword(credentialsId: 'jc21-dockerhub', passwordVariable: 'dpass', usernameVariable: 'duser')]) {
sh 'docker login -u "${duser}" -p "${dpass}"'
}
}
}
2020-02-18 23:55:06 -05:00
}
}
2024-01-08 19:05:19 -05:00
stage('Builds') {
parallel {
stage('Project') {
steps {
script {
// Frontend and Backend
def shStatusCode = sh(label: 'Checking and Building', returnStatus: true, script: '''
set -e
./scripts/ci/frontend-build > ${WORKSPACE}/tmp-sh-build 2>&1
./scripts/ci/test-and-build > ${WORKSPACE}/tmp-sh-build 2>&1
''')
shOutput = readFile "${env.WORKSPACE}/tmp-sh-build"
if (shStatusCode != 0) {
error "${shOutput}"
}
}
}
post {
always {
sh 'rm -f ${WORKSPACE}/tmp-sh-build'
}
failure {
npmGithubPrComment("CI Error:\n\n```\n${shOutput}\n```", true)
}
2023-03-08 01:22:07 -05:00
}
}
2024-01-08 19:05:19 -05:00
stage('Docs') {
steps {
dir(path: 'docs') {
sh 'yarn install'
sh 'yarn build'
}
}
2023-03-08 01:22:07 -05:00
}
2024-05-20 22:53:07 -04:00
}
}
stage('Test Sqlite') {
environment {
COMPOSE_PROJECT_NAME = "npm_${BRANCH_LOWER}_${BUILD_NUMBER}_sqlite"
COMPOSE_FILE = 'docker/docker-compose.ci.yml:docker/docker-compose.ci.sqlite.yml'
}
when {
not {
equals expected: 'UNSTABLE', actual: currentBuild.result
}
}
steps {
sh 'rm -rf ./test/results/junit/*'
sh './scripts/ci/fulltest-cypress'
}
post {
always {
// Dumps to analyze later
sh 'mkdir -p debug/sqlite'
sh 'docker logs $(docker-compose ps --all -q fullstack) > debug/sqlite/docker_fullstack.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q stepca) > debug/sqlite/docker_stepca.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q pdns) > debug/sqlite/docker_pdns.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q pdns-db) > debug/sqlite/docker_pdns-db.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q dnsrouter) > debug/sqlite/docker_dnsrouter.log 2>&1'
junit 'test/results/junit/*'
sh 'docker-compose down --remove-orphans --volumes -t 30 || true'
2024-01-08 19:32:58 -05:00
}
2020-02-18 23:55:06 -05:00
}
}
2024-05-20 22:53:07 -04:00
stage('Test Mysql') {
environment {
COMPOSE_PROJECT_NAME = "npm_${BRANCH_LOWER}_${BUILD_NUMBER}_mysql"
COMPOSE_FILE = 'docker/docker-compose.ci.yml:docker/docker-compose.ci.mysql.yml'
}
when {
not {
equals expected: 'UNSTABLE', actual: currentBuild.result
2023-12-21 14:05:09 -05:00
}
2024-05-20 22:53:07 -04:00
}
steps {
sh 'rm -rf ./test/results/junit/*'
sh './scripts/ci/fulltest-cypress'
}
post {
always {
// Dumps to analyze later
sh 'mkdir -p debug/mysql'
sh 'docker logs $(docker-compose ps --all -q fullstack) > debug/mysql/docker_fullstack.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q stepca) > debug/mysql/docker_stepca.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q pdns) > debug/mysql/docker_pdns.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q pdns-db) > debug/mysql/docker_pdns-db.log 2>&1'
sh 'docker logs $(docker-compose ps --all -q dnsrouter) > debug/mysql/docker_dnsrouter.log 2>&1'
junit 'test/results/junit/*'
sh 'docker-compose down --remove-orphans --volumes -t 30 || true'
2020-02-18 23:55:06 -05:00
}
}
}
stage('MultiArch Build') {
when {
not {
equals expected: 'UNSTABLE', actual: currentBuild.result
}
}
steps {
2024-10-10 22:56:29 -04:00
sh "./scripts/buildx --push ${buildxPushTags}"
2020-02-18 23:55:06 -05:00
}
}
2024-01-08 19:05:19 -05:00
stage('Docs / Comment') {
2024-01-08 17:36:32 -05:00
parallel {
2024-05-10 10:12:38 -04:00
stage('Docs Job') {
2024-01-08 17:36:32 -05:00
when {
allOf {
2024-05-10 10:15:44 -04:00
branch pattern: "^(develop|master)\$", comparator: "REGEXP"
2024-01-08 17:36:32 -05:00
not {
equals expected: 'UNSTABLE', actual: currentBuild.result
}
}
}
steps {
2024-05-10 10:12:38 -04:00
build wait: false, job: 'nginx-proxy-manager-docs', parameters: [string(name: 'docs_branch', value: "$BRANCH_NAME")]
2020-03-11 02:54:10 -04:00
}
}
2024-01-08 19:05:19 -05:00
stage('PR Comment') {
when {
allOf {
changeRequest()
not {
equals expected: 'UNSTABLE', actual: currentBuild.result
}
}
}
steps {
script {
npmGithubPrComment("Docker Image for build ${BUILD_NUMBER} is available on [DockerHub](https://cloud.docker.com/repository/docker/jc21/${IMAGE}) as `jc21/${IMAGE}:github-${BRANCH_LOWER}`\n\n**Note:** ensure you backup your NPM instance before testing this PR image! Especially if this PR contains database changes.", true)
}
2020-02-18 23:55:06 -05:00
}
}
}
}
}
post {
always {
sh 'echo Reverting ownership'
2024-05-20 23:16:53 -04:00
sh 'docker run --rm -v "$(pwd):/data" jc21/ci-tools chown -R "$(id -u):$(id -g)" /data'
2024-10-13 17:21:04 -04:00
printResult(true)
2020-02-18 23:55:06 -05:00
}
failure {
2024-01-09 18:32:12 -05:00
archiveArtifacts(artifacts: 'debug/**/*.*', allowEmptyArchive: true)
2020-02-18 23:55:06 -05:00
}
unstable {
2024-01-09 18:32:12 -05:00
archiveArtifacts(artifacts: 'debug/**/*.*', allowEmptyArchive: true)
2020-02-18 23:55:06 -05:00
}
}
}
2019-03-06 18:45:01 -05:00
2020-02-18 23:55:06 -05:00
def getVersion() {
ver = sh(script: 'cat .version', returnStdout: true)
return ver.trim()
2018-05-03 01:43:04 -04:00
}
2018-05-03 01:56:35 -04:00
2020-02-18 23:55:06 -05:00
def getCommit() {
ver = sh(script: 'git log -n 1 --format=%h', returnStdout: true)
return ver.trim()
2018-05-03 01:56:35 -04:00
}