Skip to content

Commit

Permalink
chore(ci): test java distribution temurin and zulu
Browse files Browse the repository at this point in the history
  • Loading branch information
oldratlee committed Jan 2, 2024
1 parent 030722c commit e674484
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 80 deletions.
14 changes: 6 additions & 8 deletions .github/workflows/maven.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,11 @@ jobs:

runs-on: ubuntu-latest
timeout-minutes: 20
name: CI with multiply java versions
name: CI with multiply ${{ matrix.java-distribution }} java versions
strategy:
matrix:
java-distribution: [ zulu, temurin ]
fail-fast: false

steps:
- uses: actions/checkout@v4
Expand All @@ -28,18 +32,12 @@ jobs:
uses: actions/setup-java@v4
with:
# https://github.com/actions/setup-java?tab=readme-ov-file#install-multiple-jdks
#
# CAUTION:
# do NOT move specified old version `11.0.3` before version `11`,
# or the version `11.0.3` will not be installed!
# because the old version 11.0.3 satisfies the version 11.
java-version: |
8
11
11.0.3
17
21
distribution: zulu
distribution: ${{ matrix.java-distribution }}
cache: maven

- name: Run integration test with multiply java versions
Expand Down
85 changes: 13 additions & 72 deletions scripts/integration-test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,10 @@ die() {
################################################################################

switch_to_jdk_home() {
export JAVA_HOME="$1"
local version="$1"
local jh_var_name="JAVA${version//./_}_HOME"
export JAVA_HOME="${!jh_var_name}"

[ -x "$JAVA_HOME/bin/java" ] ||
die "JAVA_HOME($JAVA_HOME) is invalid: \$JAVA_HOME/bin/java is not existed or executable!"
}
Expand Down Expand Up @@ -96,86 +99,24 @@ __detect_java_homes_and_set_when_running_on_github_actions() {
}
__detect_java_homes_and_set_when_running_on_github_actions

__find_latest_specified_java_version_and_export() {
local specified_java_version="$1"
local major_version="${specified_java_version%%.*}"

local reference_jh_var_name="JAVA${major_version}_HOME"
local reference_dir=${!reference_jh_var_name}
reference_dir="${reference_dir%/}" # remove tailing slash

local bkp_shopt_null_glob=0
shopt -q nullglob && bkp_shopt_null_glob=1
shopt -s nullglob

local found_arr found
if [ "${GITHUB_ACTIONS:-}" = true ]; then
# the JAVA_HOME env vars introduced by `actions/setup-java@v4`, e.g.
# JAVA_HOME_8_X64: /opt/hostedtoolcache/Java_Zulu_jdk/8.0.392-8/x64
# JAVA_HOME_21_X64: /opt/hostedtoolcache/Java_Zulu_jdk/21.0.1-12/x64
local extra_child_dir_name="${reference_dir##*/}" # get basename, e.g. "x64"
found_arr=(
"$reference_dir/../../$specified_java_version"-*/
"$reference_dir/../../$specified_java_version".*/
)
else
found_arr=(
"$JAVA11_HOME/../$specified_java_version".*/
"$JAVA11_HOME/../$specified_java_version"-*/
)
fi

((${#found_arr[@]} > 0)) || die "Fail to find java home for version $specified_java_version!"

if ((${#found_arr[@]} > 1)); then
# TODO `ls -v` is not robust, but it works for now.
# shellcheck disable=SC2012
found="$(ls -v -d "${found_arr[@]}" | tail -n 1)"
else
found="${found_arr[0]}"
fi
found="$(cd "$found" && pwd)" # normalize path

if [ "${GITHUB_ACTIONS:-}" = true ]; then
found="${found}/$extra_child_dir_name"
fi

((${#found_arr[@]} == 1)) || echo "Found multiply java homes for the specified java version $specified_java_version: ${found_arr[*]}; use the last one"

local expr
printf -v expr 'JAVA%q_HOME=%q' "${specified_java_version//./_}" "$found"
# shellcheck disable=SC2163
export "$expr"
warn_print "Found the specified java version($specified_java_version): export $expr"

# restore null glob shopt
[ "$bkp_shopt_null_glob" -eq 0 ] && shopt -u nullglob
}

__find_latest_specified_java_version_and_export 11.0.3
# correct the latest version of java 11 back;
# because actions/setup-java set up 2 versions of java 11 and last old version wins in `JAVA11_HOME`.
__find_latest_specified_java_version_and_export 11

################################################################################
# CI build logic
################################################################################

# shellcheck disable=SC2153
readonly default_build_jdk_home="$JAVA21_HOME"
readonly JDK_HOMES=(
"$JAVA8_HOME"
"$JAVA11_0_3_HOME"
"$JAVA11_HOME"
"$JAVA17_HOME"
"$default_build_jdk_home"
readonly default_build_jdk_version=21
readonly CI_JDK_VERSIONS=(
8
11
17
"$default_build_jdk_version"
)

##################################################
# build and test by default version jdk
##################################################

switch_to_jdk_home "$default_build_jdk_home"
switch_to_jdk_home "$default_build_jdk_version"

head_line_print "build and test with Java: $JAVA_HOME"
# `-V`: show the java version info (essential info when test multiple java versions)
Expand All @@ -186,8 +127,8 @@ mvn -V --no-transfer-progress clean package
# test by multiply java versions
##################################################

for jdk_version in "${JDK_HOMES[@]}"; do
if [ "$jdk_version" == "$default_build_jdk_home" ]; then
for jdk_version in "${CI_JDK_VERSIONS[@]}"; do
if [ "$jdk_version" == "$default_build_jdk_version" ]; then
# skip default jdk, already tested above
continue
fi
Expand Down

0 comments on commit e674484

Please sign in to comment.