This repository has been archived on 2025-03-20. You can view files and clone it, but cannot push or open issues or pull requests.
build-containers/build-sonarscanner.jenkins
2024-09-29 07:30:53 -05:00

68 lines
2.0 KiB
Groovy

#!groovy
def repository = "registry.c.test-chamber-13.lan"
def repositoryCreds = "harbor-repository-creds"
def workspace
def dockerFile
def label = "kubernetes-${UUID.randomUUID().toString()}"
def templateName = "pipeline-worker"
pipeline {
agent {
kubernetes {
yaml functions.podYaml(
repo: repository,
templateName: templateName,
kaniko: true
)
}
}
stages {
stage ('Initalize Jenkins') {
steps {
script {
workspace = pwd()
writeFile(file: workspace + "/test-chamber-13.lan.root.crt", text: functions.getCurrentRootCA())
dockerFile = """FROM ${repository}/dockerhub/sonarsource/sonar-scanner-cli:latest
LABEL org.opencontainers.image.authors="The_Spider <spider@smoothnet.org>"
LABEL org.opencontainers.image.title="sonar-scanner-cli"
LABEL org.opencontainers.image.description="Docker container for sonarqube scanning"
LABEL org.opencontainers.image.base.name="docker.io/sonarsource/sonar-scanner-cli:latest"
USER root
COPY test-chamber-13.lan.root.crt /etc/pki/ca-trust/source/anchors/
RUN update-ca-trust
USER scanner-cli
"""
}
}
}
stage ('Build & Push') {
steps {
container ('kaniko') {
script {
declarativeFunctions.buildContainerMultipleDestinations(
dockerFile: dockerFile,
repositoryAccess: [
[
repository: repository,
credentials: repositoryCreds
],
],
destination: [
"${repository}/library/sonarscanner:latest",
]
)
}
}
}
}
}
}