Skip to content

Commit f4099e4

Browse files
authored
Java 21 (#1928)
* Introducing Java 21 * Gradle 8.11, fixed CI * Gradle 8.10
1 parent 37ccfd4 commit f4099e4

File tree

20 files changed

+112
-95
lines changed

20 files changed

+112
-95
lines changed

.github/workflows/ci.yml

+2-2
Original file line numberDiff line numberDiff line change
@@ -47,10 +47,10 @@ jobs:
4747
- uses: actions/checkout@v4
4848
with:
4949
fetch-depth: 0
50-
- name: Set up JDK 17
50+
- name: Set up JDK 21
5151
uses: actions/setup-java@v4
5252
with:
53-
java-version: 17
53+
java-version: 21
5454
distribution: 'temurin'
5555
- name: Setup Gradle
5656
uses: gradle/gradle-build-action@v2

.github/workflows/codeql-analysis.yml

+2-2
Original file line numberDiff line numberDiff line change
@@ -37,10 +37,10 @@ jobs:
3737
- name: Checkout repository
3838
uses: actions/checkout@v4
3939

40-
- name: Set up JDK 17
40+
- name: Set up JDK 21
4141
uses: actions/setup-java@v4
4242
with:
43-
java-version: 17
43+
java-version: 21
4444
distribution: 'temurin'
4545

4646
# Initializes the CodeQL tools for scanning.

.github/workflows/release.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ jobs:
2222
- name: Set up JDK
2323
uses: actions/setup-java@v4
2424
with:
25-
java-version: '17'
25+
java-version: '21'
2626
distribution: 'temurin'
2727
- name: Setup Gradle
2828
uses: gradle/gradle-build-action@v2

.idea/misc.xml

+1-1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

build.gradle

+9-6
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,12 @@ scmVersion {
2020
versionCreator 'versionWithBranch'
2121
}
2222

23+
java {
24+
toolchain {
25+
languageVersion = JavaLanguageVersion.of(21)
26+
}
27+
}
28+
2329
nexusPublishing {
2430
connectTimeout = Duration.ofMinutes(getIntProperty('publishingTimeoutInMin', 10))
2531
clientTimeout = Duration.ofMinutes(getIntProperty('publishingTimeoutInMin', 10))
@@ -43,9 +49,6 @@ allprojects {
4349
group = 'pl.allegro.tech.hermes'
4450
version = scmVersion.version
4551

46-
sourceCompatibility = JavaVersion.VERSION_17
47-
targetCompatibility = JavaVersion.VERSION_17
48-
4952
project.ext.versions = [
5053
kafka : '2.8.2',
5154
guava : '33.1.0-jre',
@@ -195,9 +198,9 @@ subprojects {
195198

196199
test {
197200
reports {
198-
html.enabled = false
199-
junitXml.enabled = true
200-
junitXml.destination = file("$buildDir/test-results/$name")
201+
html.required = false
202+
junitXml.required = true
203+
junitXml.outputLocation = file("$buildDir/test-results/$name")
201204
}
202205

203206
testLogging {

docker/latest/consumers/Dockerfile

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,10 @@
1-
FROM gradle:7.6-jdk17 AS builder
1+
FROM gradle:7.6-jdk21 AS builder
22

33
COPY --chown=gradle:gradle . /home/gradle/src/
44
WORKDIR /home/gradle/src/
55
RUN gradle clean distZip -Pdistribution
66

7-
FROM eclipse-temurin:17.0.7_7-jre
7+
FROM eclipse-temurin:21-jre
88

99
RUN apt-get update \
1010
&& apt-get -y install unzip wget bash \

docker/latest/frontend/Dockerfile

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,10 @@
1-
FROM gradle:7.6-jdk17 AS builder
1+
FROM gradle:7.6-jdk21 AS builder
22

33
COPY --chown=gradle:gradle . /home/gradle/src/
44
WORKDIR /home/gradle/src/
55
RUN gradle clean distZip -Pdistribution
66

7-
FROM eclipse-temurin:17.0.7_7-jre
7+
FROM eclipse-temurin:21-jre
88

99
RUN apt-get update \
1010
&& apt-get -y install unzip wget bash \

docker/latest/management/Dockerfile

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,10 @@
1-
FROM gradle:7.6-jdk17 AS builder
1+
FROM gradle:7.6-jdk21 AS builder
22

33
COPY --chown=gradle:gradle . /home/gradle/src/
44
WORKDIR /home/gradle/src/
55
RUN gradle clean distZip -Pdistribution
66

7-
FROM eclipse-temurin:17.0.7_7-jre
7+
FROM eclipse-temurin:21-jre
88

99
RUN apt-get update \
1010
&& apt-get -y install unzip wget bash \

gradle/wrapper/gradle-wrapper.jar

-15.3 KB
Binary file not shown.
+3-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,7 @@
11
distributionBase=GRADLE_USER_HOME
22
distributionPath=wrapper/dists
3-
distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-bin.zip
3+
distributionUrl=https\://services.gradle.org/distributions/gradle-8.10-bin.zip
4+
networkTimeout=10000
5+
validateDistributionUrl=true
46
zipStoreBase=GRADLE_USER_HOME
57
zipStorePath=wrapper/dists

gradlew

+31-13
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,8 @@
1515
# See the License for the specific language governing permissions and
1616
# limitations under the License.
1717
#
18+
# SPDX-License-Identifier: Apache-2.0
19+
#
1820

1921
##############################################################################
2022
#
@@ -55,7 +57,7 @@
5557
# Darwin, MinGW, and NonStop.
5658
#
5759
# (3) This script is generated from the Groovy template
58-
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
60+
# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
5961
# within the Gradle project.
6062
#
6163
# You can find Gradle at https://github.com/gradle/gradle/.
@@ -80,13 +82,12 @@ do
8082
esac
8183
done
8284

83-
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
84-
85-
APP_NAME="Gradle"
85+
# This is normally unused
86+
# shellcheck disable=SC2034
8687
APP_BASE_NAME=${0##*/}
87-
88-
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
89-
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
88+
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
89+
APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s
90+
' "$PWD" ) || exit
9091

9192
# Use the maximum available, or set MAX_FD != -1 to use that value.
9293
MAX_FD=maximum
@@ -133,22 +134,29 @@ location of your Java installation."
133134
fi
134135
else
135136
JAVACMD=java
136-
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
137+
if ! command -v java >/dev/null 2>&1
138+
then
139+
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
137140
138141
Please set the JAVA_HOME variable in your environment to match the
139142
location of your Java installation."
143+
fi
140144
fi
141145

142146
# Increase the maximum file descriptors if we can.
143147
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
144148
case $MAX_FD in #(
145149
max*)
150+
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
151+
# shellcheck disable=SC2039,SC3045
146152
MAX_FD=$( ulimit -H -n ) ||
147153
warn "Could not query maximum file descriptor limit"
148154
esac
149155
case $MAX_FD in #(
150156
'' | soft) :;; #(
151157
*)
158+
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
159+
# shellcheck disable=SC2039,SC3045
152160
ulimit -n "$MAX_FD" ||
153161
warn "Could not set maximum file descriptor limit to $MAX_FD"
154162
esac
@@ -193,18 +201,28 @@ if "$cygwin" || "$msys" ; then
193201
done
194202
fi
195203

196-
# Collect all arguments for the java command;
197-
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
198-
# shell script including quotes and variable substitutions, so put them in
199-
# double quotes to make sure that they get re-expanded; and
200-
# * put everything else in single quotes, so that it's not re-expanded.
204+
205+
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
206+
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
207+
208+
# Collect all arguments for the java command:
209+
# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
210+
# and any embedded shellness will be escaped.
211+
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
212+
# treated as '${Hostname}' itself on the command line.
201213

202214
set -- \
203215
"-Dorg.gradle.appname=$APP_BASE_NAME" \
204216
-classpath "$CLASSPATH" \
205217
org.gradle.wrapper.GradleWrapperMain \
206218
"$@"
207219

220+
# Stop when "xargs" is not available.
221+
if ! command -v xargs >/dev/null 2>&1
222+
then
223+
die "xargs is not available"
224+
fi
225+
208226
# Use "xargs" to parse quoted args.
209227
#
210228
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.

gradlew.bat

+21-16
Original file line numberDiff line numberDiff line change
@@ -13,8 +13,10 @@
1313
@rem See the License for the specific language governing permissions and
1414
@rem limitations under the License.
1515
@rem
16+
@rem SPDX-License-Identifier: Apache-2.0
17+
@rem
1618

17-
@if "%DEBUG%" == "" @echo off
19+
@if "%DEBUG%"=="" @echo off
1820
@rem ##########################################################################
1921
@rem
2022
@rem Gradle startup script for Windows
@@ -25,7 +27,8 @@
2527
if "%OS%"=="Windows_NT" setlocal
2628

2729
set DIRNAME=%~dp0
28-
if "%DIRNAME%" == "" set DIRNAME=.
30+
if "%DIRNAME%"=="" set DIRNAME=.
31+
@rem This is normally unused
2932
set APP_BASE_NAME=%~n0
3033
set APP_HOME=%DIRNAME%
3134

@@ -40,13 +43,13 @@ if defined JAVA_HOME goto findJavaFromJavaHome
4043

4144
set JAVA_EXE=java.exe
4245
%JAVA_EXE% -version >NUL 2>&1
43-
if "%ERRORLEVEL%" == "0" goto execute
46+
if %ERRORLEVEL% equ 0 goto execute
4447

45-
echo.
46-
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
47-
echo.
48-
echo Please set the JAVA_HOME variable in your environment to match the
49-
echo location of your Java installation.
48+
echo. 1>&2
49+
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
50+
echo. 1>&2
51+
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
52+
echo location of your Java installation. 1>&2
5053

5154
goto fail
5255

@@ -56,11 +59,11 @@ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
5659

5760
if exist "%JAVA_EXE%" goto execute
5861

59-
echo.
60-
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
61-
echo.
62-
echo Please set the JAVA_HOME variable in your environment to match the
63-
echo location of your Java installation.
62+
echo. 1>&2
63+
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
64+
echo. 1>&2
65+
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
66+
echo location of your Java installation. 1>&2
6467

6568
goto fail
6669

@@ -75,13 +78,15 @@ set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
7578

7679
:end
7780
@rem End local scope for the variables with windows NT shell
78-
if "%ERRORLEVEL%"=="0" goto mainEnd
81+
if %ERRORLEVEL% equ 0 goto mainEnd
7982

8083
:fail
8184
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
8285
rem the _cmd.exe /c_ return code!
83-
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
84-
exit /b 1
86+
set EXIT_CODE=%ERRORLEVEL%
87+
if %EXIT_CODE% equ 0 set EXIT_CODE=1
88+
if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
89+
exit /b %EXIT_CODE%
8590

8691
:mainEnd
8792
if "%OS%"=="Windows_NT" endlocal

hermes-frontend/build.gradle

+1-1
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@ dependencies {
1414
api group: 'org.springframework.boot', name: 'spring-boot-starter', version: versions.spring
1515
api group: 'io.undertow', name: 'undertow-core', version: versions.undertow
1616
// Did not update that as we're trying to abandon buffers
17-
api(group: 'net.openhft', name: 'chronicle-map', version: '3.22.9') {
17+
api(group: 'net.openhft', name: 'chronicle-map', version: '3.25ea6') {
1818
exclude group: 'net.openhft', module: 'chronicle-analytics'
1919
}
2020
implementation group: 'commons-io', name: 'commons-io', version: '2.16.1'

hermes-frontend/src/test/groovy/pl/allegro/tech/hermes/frontend/producer/kafka/LocalDatacenterMessageProducerIntegrationTest.groovy

+1-2
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
package pl.allegro.tech.hermes.frontend.producer.kafka
22

3-
import com.codahale.metrics.MetricRegistry
43
import io.micrometer.core.instrument.simple.SimpleMeterRegistry
54
import org.apache.commons.lang3.tuple.ImmutablePair
65
import org.apache.kafka.clients.admin.AdminClient
@@ -85,7 +84,7 @@ class LocalDatacenterMessageProducerIntegrationTest extends Specification {
8584
String datacenter = "dc"
8685

8786
@Shared
88-
ScheduledExecutorService chaosScheduler = Executors.newSingleThreadScheduledExecutor();
87+
ScheduledExecutorService chaosScheduler = Executors.newSingleThreadScheduledExecutor()
8988

9089
@Shared
9190
MetricsFacade metricsFacade = new MetricsFacade(new SimpleMeterRegistry())

hermes-management/build.gradle

+8
Original file line numberDiff line numberDiff line change
@@ -89,6 +89,14 @@ tasks.register('prepareIndexTemplate') {
8989
}
9090
}
9191

92+
tasks.named('compileTestGroovy') {
93+
dependsOn 'attachHermesConsole'
94+
}
95+
96+
tasks.named('javadoc') {
97+
dependsOn 'attachHermesConsole'
98+
}
99+
92100
jar.dependsOn(attachHermesConsole, 'prepareIndexTemplate')
93101

94102
run.dependsOn(attachHermesConsole, 'prepareIndexTemplate')

hermes-tracker-elasticsearch/build.gradle

+2-5
Original file line numberDiff line numberDiff line change
@@ -5,15 +5,12 @@ dependencies {
55
implementation project(':hermes-common')
66
implementation project(':hermes-tracker')
77
implementation 'org.slf4j:slf4j-api:2.0.13'
8-
// TODO: client has to have the same major version as backend: https://www.elastic.co/guide/en/elasticsearch/client/java-api/current/client.html
9-
// we need to use test-containers for elasticsearch server to able to use newer client.
10-
api group: 'org.elasticsearch.client', name: 'transport', version: '6.8.12'
8+
api group: 'org.elasticsearch.client', name: 'transport', version: '7.10.2'
119

1210
testImplementation project(path: ":hermes-tracker", configuration: "testArtifacts")
1311
testImplementation project(path: ":hermes-test-helper")
1412
testImplementation group: 'org.spockframework', name: 'spock-core', version: versions.spock
1513
testImplementation group: 'org.spockframework', name: 'spock-junit4', version: versions.spock
16-
// this should be migrated to testcontainers
17-
testImplementation 'pl.allegro.tech:embedded-elasticsearch:2.10.0'
14+
testImplementation "org.testcontainers:elasticsearch:1.20.3"
1815
testRuntimeOnly group: 'org.junit.vintage', name: 'junit-vintage-engine', version: versions.junit_jupiter
1916
}

0 commit comments

Comments
 (0)