Skip to content

Commit c0d5fd7

Browse files
gregturnmp911de
authored andcommitted
Externalize build properties.
By reading a properties file from an external location, it is possible to inject a consistent set of properties from Spring Data Build. This also supports repeatable builds. Closes #2245.
1 parent 30599ae commit c0d5fd7

File tree

4 files changed

+54
-16
lines changed

4 files changed

+54
-16
lines changed

Jenkinsfile

+19-11
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,9 @@
1+
def p = [:]
2+
node {
3+
checkout scm
4+
p = readProperties interpolate: true, file: 'ci/pipeline.properties'
5+
}
6+
17
pipeline {
28
agent none
39

@@ -14,38 +20,40 @@ pipeline {
1420
stages {
1521
stage("Docker images") {
1622
parallel {
17-
stage('Publish OpenJDK 8 + Redis 6.2 docker image') {
23+
stage('Publish OpenJDK (main) + Redis 6.2 docker image') {
1824
when {
1925
anyOf {
20-
changeset "ci/openjdk8-redis-6.2/**"
26+
changeset "ci/openjdk8-redis-6.2/Dockerfile"
2127
changeset "Makefile"
28+
changeset "ci/pipeline.properties"
2229
}
2330
}
2431
agent { label 'data' }
2532
options { timeout(time: 20, unit: 'MINUTES') }
2633

2734
steps {
2835
script {
29-
def image = docker.build("springci/spring-data-openjdk8-with-redis-6.2", "-f ci/openjdk8-redis-6.2/Dockerfile .")
36+
def image = docker.build("springci/spring-data-with-redis-6.2:${p['java.main.tag']}", "--build-arg BASE=${p['docker.java.main.image']} --build-arg REDIS=${p['docker.redis.6.version']} -f ci/openjdk8-redis-6.2/Dockerfile .")
3037
docker.withRegistry('', 'hub.docker.com-springbuildmaster') {
3138
image.push()
3239
}
3340
}
3441
}
3542
}
36-
stage('Publish OpenJDK 17 + Redis 6.2 docker image') {
43+
stage('Publish OpenJDK (LTS) + Redis 6.2 docker image') {
3744
when {
3845
anyOf {
39-
changeset "ci/openjdk16-redis-6.2/**"
46+
changeset "ci/openjdk17-redis-6.2/Dockerfile"
4047
changeset "Makefile"
48+
changeset "ci/pipeline.properties"
4149
}
4250
}
4351
agent { label 'data' }
4452
options { timeout(time: 20, unit: 'MINUTES') }
4553

4654
steps {
4755
script {
48-
def image = docker.build("springci/spring-data-openjdk17-with-redis-6.2", "-f ci/openjdk17-redis-6.2/Dockerfile .")
56+
def image = docker.build("springci/spring-data-with-redis-6.2:${p['java.lts.tag']}", "--build-arg BASE=${p['docker.java.lts.image']} --build-arg REDIS=${p['docker.redis.6.version']} -f ci/openjdk17-redis-6.2/Dockerfile .")
4957
docker.withRegistry('', 'hub.docker.com-springbuildmaster') {
5058
image.push()
5159
}
@@ -55,7 +63,7 @@ pipeline {
5563
}
5664
}
5765

58-
stage("test: baseline (jdk8)") {
66+
stage("test: baseline (main)") {
5967
when {
6068
beforeAgent(true)
6169
anyOf {
@@ -73,7 +81,7 @@ pipeline {
7381
steps {
7482
script {
7583
docker.withRegistry('', 'hub.docker.com-springbuildmaster') {
76-
docker.image('springci/spring-data-openjdk8-with-redis-6.2:latest').inside('-v $HOME:/tmp/jenkins-home') {
84+
docker.image("springci/spring-data-with-redis-6.2:${p['java.main.tag']}").inside(p['docker.java.inside.basic']) {
7785
sh 'PROFILE=none LONG_TESTS=true ci/test.sh'
7886
}
7987
}
@@ -90,7 +98,7 @@ pipeline {
9098
}
9199
}
92100
parallel {
93-
stage("test: baseline (jdk17)") {
101+
stage("test: baseline (LTS)") {
94102
agent {
95103
label 'data'
96104
}
@@ -101,7 +109,7 @@ pipeline {
101109
steps {
102110
script {
103111
docker.withRegistry('', 'hub.docker.com-springbuildmaster') {
104-
docker.image('springci/spring-data-openjdk17-with-redis-6.2:latest').inside('-v $HOME:/tmp/jenkins-home') {
112+
docker.image("springci/spring-data-with-redis-6.2:${p['java.lts.tag']}").inside(p['docker.java.inside.basic']) {
105113
sh 'PROFILE=java11 ci/test.sh'
106114
}
107115
}
@@ -131,7 +139,7 @@ pipeline {
131139
steps {
132140
script {
133141
docker.withRegistry('', 'hub.docker.com-springbuildmaster') {
134-
docker.image('adoptopenjdk/openjdk8:latest').inside('-v $HOME:/tmp/jenkins-home') {
142+
docker.image(p['docker.java.main.image']).inside(p['docker.java.inside.basic']) {
135143
sh 'MAVEN_OPTS="-Duser.name=jenkins -Duser.home=/tmp/jenkins-home" ./mvnw -s settings.xml -Pci,artifactory ' +
136144
'-Dartifactory.server=https://repo.spring.io ' +
137145
"-Dartifactory.username=${ARTIFACTORY_USR} " +

ci/openjdk17-redis-6.2/Dockerfile

+6-3
Original file line numberDiff line numberDiff line change
@@ -1,13 +1,16 @@
1-
FROM openjdk:17-bullseye
1+
ARG BASE
2+
FROM ${BASE}
3+
# Any ARG statements before FROM are cleared.
4+
ARG REDIS
25

36
# Copy Spring Data Redis's Makefile into the container
47
COPY ./Makefile /
58

69
RUN set -eux; \
7-
sed -i -e 's/http/https/g' /etc/apt/sources.list ; \
10+
# sed -i -e 's/http/https/g' /etc/apt/sources.list ; \
811
apt-get update ; \
912
apt-get install -y build-essential ; \
10-
make work/redis/bin/redis-cli work/redis/bin/redis-server REDIS_VERSION=6.2.4; \
13+
make work/redis/bin/redis-cli work/redis/bin/redis-server REDIS_VERSION=${REDIS}; \
1114
chmod -R o+rw work; \
1215
apt-get clean; \
1316
rm -rf /var/lib/apt/lists/*;

ci/openjdk8-redis-6.2/Dockerfile

+5-2
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,15 @@
1-
FROM adoptopenjdk/openjdk8:latest
1+
ARG BASE
2+
FROM ${BASE}
3+
# Any ARG statements before FROM are cleared.
4+
ARG REDIS
25

36
# Copy Spring Data Redis's Makefile into the container
47
COPY ./Makefile /
58

69
RUN set -eux; \
710
apt-get update ; \
811
apt-get install -y build-essential ; \
9-
make work/redis/bin/redis-cli work/redis/bin/redis-server REDIS_VERSION=6.2.4; \
12+
make work/redis/bin/redis-cli work/redis/bin/redis-server REDIS_VERSION=${REDIS}; \
1013
chmod -R o+rw work; \
1114
apt-get clean; \
1215
rm -rf /var/lib/apt/lists/*;

ci/pipeline.properties

+24
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
# Java versions
2+
java.main.tag=8u312-b07-jdk
3+
java.next.tag=11.0.13_8-jdk
4+
java.lts.tag=17.0.1_12-jdk
5+
6+
# Docker container images - standard
7+
docker.java.main.image=eclipse-temurin:${java.main.tag}
8+
docker.java.next.image=eclipse-temurin:${java.next.tag}
9+
docker.java.lts.image=eclipse-temurin:${java.lts.tag}
10+
11+
# Supported versions of MongoDB
12+
docker.mongodb.4.0.version=4.0.23
13+
docker.mongodb.4.4.version=4.4.4
14+
docker.mongodb.5.0.version=5.0.3
15+
16+
# Supported versions of Redis
17+
docker.redis.6.version=6.2.4
18+
19+
# Supported versions of Cassandra
20+
docker.cassandra.3.version=3.11.10
21+
22+
# Docker environment settings
23+
docker.java.inside.basic=-v $HOME:/tmp/jenkins-home
24+
docker.java.inside.docker=-u root -v /var/run/docker.sock:/var/run/docker.sock -v /usr/bin/docker:/usr/bin/docker -v $HOME:/tmp/jenkins-home

0 commit comments

Comments
 (0)