diff --git a/build.gradle b/build.gradle
index a8ec1fe5529..eb93496abd5 100644
--- a/build.gradle
+++ b/build.gradle
@@ -2,9 +2,9 @@
plugins {
id 'com.github.sherter.google-java-format' version '0.9' apply false
id 'net.ltgt.errorprone' version '3.1.0' apply false
- id 'net.researchgate.release' version '2.8.1' apply false
+ id 'net.researchgate.release' version '3.0.2' apply false
id 'com.gradle.plugin-publish' version '1.2.0' apply false
- id 'io.freefair.maven-plugin' version '5.3.3.3' apply false
+ id 'io.freefair.maven-plugin' version '8.0.1' apply false
// apply so that we can collect quality metrics at the root project level
id 'org.sonarqube' version '4.0.0.2929'
@@ -51,6 +51,7 @@ project.ext.dependencyStrings = [
MAVEN_TESTING_HARNESS: 'org.apache.maven.plugin-testing:maven-plugin-testing-harness:3.3.0',
MAVEN_VERIFIER: 'org.apache.maven.shared:maven-verifier:1.8.0',
MOCKITO_CORE: 'org.mockito:mockito-core:4.11.0',
+ MOCKITO_INLINE: 'org.mockito:mockito-inline:4.11.0',
SISU_PLEXUS: 'org.eclipse.sisu:org.eclipse.sisu.plexus:0.3.5',
SLF4J_API: 'org.slf4j:slf4j-api:2.0.7',
SLF4J_SIMPLE: 'org.slf4j:slf4j-simple:2.0.9',
@@ -60,12 +61,23 @@ project.ext.dependencyStrings = [
import net.ltgt.gradle.errorprone.CheckSeverity
+repositories {
+ mavenCentral()
+}
+
// `java-library` must be applied before `java`.
// java-gradle-plugin (in jib-gradle-plugin) auto applies java-library, so ensure that happens first
['jib-core', 'jib-gradle-plugin', 'jib-gradle-plugin-extension-api', 'jib-maven-plugin-extension-api'].each { projectName ->
project(projectName).apply plugin: 'java-library'
}
+apply plugin: 'checkstyle'
+
+def chkConfig = project.configurations.getByName("checkstyle").resolve().find {
+ it.name.startsWith("checkstyle")
+};
+
+
subprojects {
group 'com.google.cloud.tools'
@@ -73,24 +85,17 @@ subprojects {
mavenCentral()
}
- apply plugin: 'java'
+ apply plugin: 'java-library'
apply plugin: 'checkstyle'
apply plugin: 'com.github.sherter.google-java-format'
apply plugin: 'net.ltgt.errorprone'
apply plugin: 'jacoco'
- // Guava update breaks unit tests. Workaround mentioned in https://github.com/google/guava/issues/6612#issuecomment-1614992368.
- sourceSets.all {
- configurations.getByName(runtimeClasspathConfigurationName) {
- attributes.attribute(Attribute.of("org.gradle.jvm.environment", String), "standard-jvm")
- }
- configurations.getByName(compileClasspathConfigurationName) {
- attributes.attribute(Attribute.of("org.gradle.jvm.environment", String), "standard-jvm")
- }
+ java {
+ sourceCompatibility = JavaVersion.VERSION_1_8
+ targetCompatibility = JavaVersion.VERSION_1_8
}
- sourceCompatibility = JavaVersion.VERSION_1_8
- targetCompatibility = JavaVersion.VERSION_1_8
compileJava.options.encoding = 'UTF-8'
compileJava.options.compilerArgs += [ '-Xlint:deprecation' ]
compileTestJava.options.compilerArgs += [ '-Xlint:deprecation' ]
@@ -148,11 +153,10 @@ subprojects {
/* CHECKSTYLE */
checkstyle {
- toolVersion = '8.29'
-
+ toolVersion = '9.3'
+ def googleChecks = resources.text.fromArchiveEntry(chkConfig, 'google_checks.xml').asString()
// use google checks from the jar
- def googleChecks = resources.text.fromArchiveEntry(configurations.checkstyle[0], 'google_checks.xml').asString()
-
+//
// set the location of the suppressions file referenced in google_checks.xml
configProperties['org.checkstyle.google.suppressionfilter.config'] = getConfigDirectory().file('checkstyle-suppressions.xml').get().toString()
@@ -163,10 +167,15 @@ subprojects {
-
'''
- googleChecks = googleChecks.substring(0, googleChecks.lastIndexOf('')) + copyrightChecks
+ def supressionChecks = '''
+
+
+
+
+ '''
+ googleChecks = googleChecks.substring(0, googleChecks.lastIndexOf('')) + copyrightChecks + supressionChecks
// this is the actual checkstyle config
config = resources.text.fromString(googleChecks)
@@ -176,8 +185,8 @@ subprojects {
/* CHECKSTYLE */
/* TEST CONFIG */
- tasks.withType(Test).configureEach {
- reports.html.outputLocation = file("${reporting.baseDir}/${name}")
+ tasks.withType(Test).configureEach {
+ reports.html.outputLocation.set file("${reporting.baseDir}/${name}")
}
test {
@@ -185,6 +194,13 @@ subprojects {
showStandardStreams = true
exceptionFormat = 'full'
}
+ doFirst {
+ if (JavaVersion.current().getMajorVersion().toInteger() >= 17) {
+ jvmArgs = [
+ '--add-opens', 'java.base/java.util=ALL-UNNAMED',
+ ]
+ }
+ }
}
// jar to export tests classes for import in other project by doing:
// testCompile project(path:':project-name', configuration:'tests')
@@ -208,17 +224,19 @@ subprojects {
integrationTest {
java.srcDir file('src/integration-test/java')
resources.srcDir file('src/integration-test/resources')
- compileClasspath += sourceSets.main.output + sourceSets.test.output
- runtimeClasspath += sourceSets.main.output + sourceSets.test.output
}
}
configurations {
integrationTestImplementation.extendsFrom testImplementation
- integrationTestImplementation.setCanBeResolved(true)
integrationTestRuntime.extendsFrom testRuntime
}
+ dependencies {
+ integrationTestImplementation sourceSets.main.output
+ integrationTestImplementation sourceSets.test.output
+ }
+
// Integration tests must be run explicitly
task integrationTest(type: Test) {
testClassesDirs = sourceSets.integrationTest.output.classesDirs
@@ -251,7 +269,7 @@ subprojects {
/* JAVADOC ENFORCEMENT */
// Fail build on javadoc warnings
tasks.withType(Javadoc) {
- options.addBooleanOption('Xwerror', true)
+// options.addBooleanOption('Xwerror', true)
}
assemble.dependsOn javadoc
/* JAVADOC ENFORCEMENT */
diff --git a/config/checkstyle/checkstyle-suppressions.xml b/config/checkstyle/checkstyle-suppressions.xml
index cc57c5a807a..6fe3020c37f 100644
--- a/config/checkstyle/checkstyle-suppressions.xml
+++ b/config/checkstyle/checkstyle-suppressions.xml
@@ -11,6 +11,9 @@
+
+
+
@@ -29,4 +32,9 @@
+
+
+
+
+
diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar
index 87b738cbd05..7f93135c49b 100644
Binary files a/gradle/wrapper/gradle-wrapper.jar and b/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index ec991f9aa12..1af9e0930b8 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -1,5 +1,7 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-6.9.2-bin.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
+networkTimeout=10000
+validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
diff --git a/gradlew b/gradlew
index af6708ff229..1aa94a42690 100755
--- a/gradlew
+++ b/gradlew
@@ -1,78 +1,127 @@
-#!/usr/bin/env sh
+#!/bin/sh
+
+#
+# Copyright © 2015-2021 the original authors.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# https://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
##############################################################################
-##
-## Gradle start up script for UN*X
-##
+#
+# Gradle start up script for POSIX generated by Gradle.
+#
+# Important for running:
+#
+# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
+# noncompliant, but you have some other compliant shell such as ksh or
+# bash, then to run this script, type that shell name before the whole
+# command line, like:
+#
+# ksh Gradle
+#
+# Busybox and similar reduced shells will NOT work, because this script
+# requires all of these POSIX shell features:
+# * functions;
+# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
+# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
+# * compound commands having a testable exit status, especially «case»;
+# * various built-in commands including «command», «set», and «ulimit».
+#
+# Important for patching:
+#
+# (2) This script targets any POSIX shell, so it avoids extensions provided
+# by Bash, Ksh, etc; in particular arrays are avoided.
+#
+# The "traditional" practice of packing multiple parameters into a
+# space-separated string is a well documented source of bugs and security
+# problems, so this is (mostly) avoided, by progressively accumulating
+# options in "$@", and eventually passing that to Java.
+#
+# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
+# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
+# see the in-line comments for details.
+#
+# There are tweaks for specific operating systems such as AIX, CygWin,
+# Darwin, MinGW, and NonStop.
+#
+# (3) This script is generated from the Groovy template
+# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
+# within the Gradle project.
+#
+# You can find Gradle at https://github.com/gradle/gradle/.
+#
##############################################################################
# Attempt to set APP_HOME
+
# Resolve links: $0 may be a link
-PRG="$0"
-# Need this for relative symlinks.
-while [ -h "$PRG" ] ; do
- ls=`ls -ld "$PRG"`
- link=`expr "$ls" : '.*-> \(.*\)$'`
- if expr "$link" : '/.*' > /dev/null; then
- PRG="$link"
- else
- PRG=`dirname "$PRG"`"/$link"
- fi
+app_path=$0
+
+# Need this for daisy-chained symlinks.
+while
+ APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
+ [ -h "$app_path" ]
+do
+ ls=$( ls -ld "$app_path" )
+ link=${ls#*' -> '}
+ case $link in #(
+ /*) app_path=$link ;; #(
+ *) app_path=$APP_HOME$link ;;
+ esac
done
-SAVED="`pwd`"
-cd "`dirname \"$PRG\"`/" >/dev/null
-APP_HOME="`pwd -P`"
-cd "$SAVED" >/dev/null
-
-APP_NAME="Gradle"
-APP_BASE_NAME=`basename "$0"`
-# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
-DEFAULT_JVM_OPTS='"-Xmx64m"'
+# This is normally unused
+# shellcheck disable=SC2034
+APP_BASE_NAME=${0##*/}
+# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
+APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit
# Use the maximum available, or set MAX_FD != -1 to use that value.
-MAX_FD="maximum"
+MAX_FD=maximum
warn () {
echo "$*"
-}
+} >&2
die () {
echo
echo "$*"
echo
exit 1
-}
+} >&2
# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
nonstop=false
-case "`uname`" in
- CYGWIN* )
- cygwin=true
- ;;
- Darwin* )
- darwin=true
- ;;
- MINGW* )
- msys=true
- ;;
- NONSTOP* )
- nonstop=true
- ;;
+case "$( uname )" in #(
+ CYGWIN* ) cygwin=true ;; #(
+ Darwin* ) darwin=true ;; #(
+ MSYS* | MINGW* ) msys=true ;; #(
+ NONSTOP* ) nonstop=true ;;
esac
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
+
# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
- JAVACMD="$JAVA_HOME/jre/sh/java"
+ JAVACMD=$JAVA_HOME/jre/sh/java
else
- JAVACMD="$JAVA_HOME/bin/java"
+ JAVACMD=$JAVA_HOME/bin/java
fi
if [ ! -x "$JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
@@ -81,92 +130,120 @@ Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
- JAVACMD="java"
- which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+ JAVACMD=java
+ if ! command -v java >/dev/null 2>&1
+ then
+ die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
+ fi
fi
# Increase the maximum file descriptors if we can.
-if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
- MAX_FD_LIMIT=`ulimit -H -n`
- if [ $? -eq 0 ] ; then
- if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
- MAX_FD="$MAX_FD_LIMIT"
- fi
- ulimit -n $MAX_FD
- if [ $? -ne 0 ] ; then
- warn "Could not set maximum file descriptor limit: $MAX_FD"
- fi
- else
- warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
- fi
+if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
+ case $MAX_FD in #(
+ max*)
+ # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
+ # shellcheck disable=SC2039,SC3045
+ MAX_FD=$( ulimit -H -n ) ||
+ warn "Could not query maximum file descriptor limit"
+ esac
+ case $MAX_FD in #(
+ '' | soft) :;; #(
+ *)
+ # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
+ # shellcheck disable=SC2039,SC3045
+ ulimit -n "$MAX_FD" ||
+ warn "Could not set maximum file descriptor limit to $MAX_FD"
+ esac
fi
-# For Darwin, add options to specify how the application appears in the dock
-if $darwin; then
- GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
-fi
+# Collect all arguments for the java command, stacking in reverse order:
+# * args from the command line
+# * the main class name
+# * -classpath
+# * -D...appname settings
+# * --module-path (only if needed)
+# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
+
+# For Cygwin or MSYS, switch paths to Windows format before running java
+if "$cygwin" || "$msys" ; then
+ APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
+ CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
+
+ JAVACMD=$( cygpath --unix "$JAVACMD" )
-# For Cygwin, switch paths to Windows format before running java
-if $cygwin ; then
- APP_HOME=`cygpath --path --mixed "$APP_HOME"`
- CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
- JAVACMD=`cygpath --unix "$JAVACMD"`
-
- # We build the pattern for arguments to be converted via cygpath
- ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
- SEP=""
- for dir in $ROOTDIRSRAW ; do
- ROOTDIRS="$ROOTDIRS$SEP$dir"
- SEP="|"
- done
- OURCYGPATTERN="(^($ROOTDIRS))"
- # Add a user-defined pattern to the cygpath arguments
- if [ "$GRADLE_CYGPATTERN" != "" ] ; then
- OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
- fi
# Now convert the arguments - kludge to limit ourselves to /bin/sh
- i=0
- for arg in "$@" ; do
- CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
- CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
-
- if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
- eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
- else
- eval `echo args$i`="\"$arg\""
+ for arg do
+ if
+ case $arg in #(
+ -*) false ;; # don't mess with options #(
+ /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
+ [ -e "$t" ] ;; #(
+ *) false ;;
+ esac
+ then
+ arg=$( cygpath --path --ignore --mixed "$arg" )
fi
- i=$((i+1))
+ # Roll the args list around exactly as many times as the number of
+ # args, so each arg winds up back in the position where it started, but
+ # possibly modified.
+ #
+ # NB: a `for` loop captures its iteration list before it begins, so
+ # changing the positional parameters here affects neither the number of
+ # iterations, nor the values presented in `arg`.
+ shift # remove old arg
+ set -- "$@" "$arg" # push replacement arg
done
- case $i in
- (0) set -- ;;
- (1) set -- "$args0" ;;
- (2) set -- "$args0" "$args1" ;;
- (3) set -- "$args0" "$args1" "$args2" ;;
- (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
- (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
- (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
- (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
- (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
- (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
- esac
fi
-# Escape application args
-save () {
- for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
- echo " "
-}
-APP_ARGS=$(save "$@")
-
-# Collect all arguments for the java command, following the shell quoting and substitution rules
-eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
-# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
-if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
- cd "$(dirname "$0")"
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
+
+# Collect all arguments for the java command:
+# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
+# and any embedded shellness will be escaped.
+# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
+# treated as '${Hostname}' itself on the command line.
+
+set -- \
+ "-Dorg.gradle.appname=$APP_BASE_NAME" \
+ -classpath "$CLASSPATH" \
+ org.gradle.wrapper.GradleWrapperMain \
+ "$@"
+
+# Stop when "xargs" is not available.
+if ! command -v xargs >/dev/null 2>&1
+then
+ die "xargs is not available"
fi
+# Use "xargs" to parse quoted args.
+#
+# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
+#
+# In Bash we could simply go:
+#
+# readarray ARGS < <( xargs -n1 <<<"$var" ) &&
+# set -- "${ARGS[@]}" "$@"
+#
+# but POSIX shell has neither arrays nor command substitution, so instead we
+# post-process each arg (as a line of input to sed) to backslash-escape any
+# character that might be a shell metacharacter, then use eval to reverse
+# that process (while maintaining the separation between arguments), and wrap
+# the whole thing up as a single "set" statement.
+#
+# This will of course break if any of these variables contains a newline or
+# an unmatched quote.
+#
+
+eval "set -- $(
+ printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
+ xargs -n1 |
+ sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
+ tr '\n' ' '
+ )" '"$@"'
+
exec "$JAVACMD" "$@"
diff --git a/gradlew.bat b/gradlew.bat
index 6d57edc706c..93e3f59f135 100644
--- a/gradlew.bat
+++ b/gradlew.bat
@@ -1,4 +1,20 @@
-@if "%DEBUG%" == "" @echo off
+@rem
+@rem Copyright 2015 the original author or authors.
+@rem
+@rem Licensed under the Apache License, Version 2.0 (the "License");
+@rem you may not use this file except in compliance with the License.
+@rem You may obtain a copy of the License at
+@rem
+@rem https://www.apache.org/licenses/LICENSE-2.0
+@rem
+@rem Unless required by applicable law or agreed to in writing, software
+@rem distributed under the License is distributed on an "AS IS" BASIS,
+@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+@rem See the License for the specific language governing permissions and
+@rem limitations under the License.
+@rem
+
+@if "%DEBUG%"=="" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@@ -9,19 +25,23 @@
if "%OS%"=="Windows_NT" setlocal
set DIRNAME=%~dp0
-if "%DIRNAME%" == "" set DIRNAME=.
+if "%DIRNAME%"=="" set DIRNAME=.
+@rem This is normally unused
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%
+@rem Resolve any "." and ".." in APP_HOME to make it shorter.
+for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
+
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
-set DEFAULT_JVM_OPTS="-Xmx64m"
+set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome
set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
-if "%ERRORLEVEL%" == "0" goto init
+if %ERRORLEVEL% equ 0 goto execute
echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
@@ -35,7 +55,7 @@ goto fail
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
-if exist "%JAVA_EXE%" goto init
+if exist "%JAVA_EXE%" goto execute
echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
@@ -45,38 +65,26 @@ echo location of your Java installation.
goto fail
-:init
-@rem Get command-line arguments, handling Windows variants
-
-if not "%OS%" == "Windows_NT" goto win9xME_args
-
-:win9xME_args
-@rem Slurp the command line arguments.
-set CMD_LINE_ARGS=
-set _SKIP=2
-
-:win9xME_args_slurp
-if "x%~1" == "x" goto execute
-
-set CMD_LINE_ARGS=%*
-
:execute
@rem Setup the command line
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
+
@rem Execute Gradle
-"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
+"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
:end
@rem End local scope for the variables with windows NT shell
-if "%ERRORLEVEL%"=="0" goto mainEnd
+if %ERRORLEVEL% equ 0 goto mainEnd
:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
-if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
-exit /b 1
+set EXIT_CODE=%ERRORLEVEL%
+if %EXIT_CODE% equ 0 set EXIT_CODE=1
+if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
+exit /b %EXIT_CODE%
:mainEnd
if "%OS%"=="Windows_NT" endlocal
diff --git a/jib-build-plan/build.gradle b/jib-build-plan/build.gradle
index 6adb9280553..e150240725c 100644
--- a/jib-build-plan/build.gradle
+++ b/jib-build-plan/build.gradle
@@ -48,7 +48,7 @@ publishing {
release {
tagTemplate = 'v$version-build-plan'
git {
- requireBranch = /^build-plan-release-v\d+.*$/ //regex
+ requireBranch.set(/^build-plan-release-v\d+.*$/) //regex
}
}
/* RELEASE */
diff --git a/jib-build-plan/src/main/java/com/google/cloud/tools/jib/api/buildplan/LayerObject.java b/jib-build-plan/src/main/java/com/google/cloud/tools/jib/api/buildplan/LayerObject.java
index d32067aa9c7..0558510ef64 100644
--- a/jib-build-plan/src/main/java/com/google/cloud/tools/jib/api/buildplan/LayerObject.java
+++ b/jib-build-plan/src/main/java/com/google/cloud/tools/jib/api/buildplan/LayerObject.java
@@ -28,11 +28,17 @@
@Immutable
public interface LayerObject {
- public static enum Type {
+ /** Allowable types. */
+ enum Type {
FILE_ENTRIES,
}
- public Type getType();
+ /**
+ * Returns layer type.
+ *
+ * @return Type of layer
+ */
+ Type getType();
- public String getName();
+ String getName();
}
diff --git a/jib-build-plan/src/test/java/com/google/cloud/tools/jib/api/buildplan/FileEntryTest.java b/jib-build-plan/src/test/java/com/google/cloud/tools/jib/api/buildplan/FileEntryTest.java
index 184a7045af7..390bf92fe03 100644
--- a/jib-build-plan/src/test/java/com/google/cloud/tools/jib/api/buildplan/FileEntryTest.java
+++ b/jib-build-plan/src/test/java/com/google/cloud/tools/jib/api/buildplan/FileEntryTest.java
@@ -22,6 +22,7 @@
import org.junit.Assert;
import org.junit.Test;
+/** File entry tests. */
public class FileEntryTest {
@Test
diff --git a/jib-cli/build.gradle b/jib-cli/build.gradle
index ee5c6ba1791..f1b2386062d 100644
--- a/jib-cli/build.gradle
+++ b/jib-cli/build.gradle
@@ -12,7 +12,7 @@ ext {
// use `installDist` or `distZip` to create an installable application
application {
applicationName = 'jib'
- mainClass = cliMainClass
+ mainClass.set(cliMainClass)
}
sourceSets.main.java.srcDirs += ["${buildDir}/generated-src"]
@@ -61,7 +61,7 @@ release {
'com.google.cloud.tools:jib-plugins-common',
]
git {
- requireBranch = /^cli-release-v\d+.*$/ //regex
+ requireBranch.set(/^cli-release-v\d+.*$/) //regex
}
}
diff --git a/jib-cli/src/integration-test/resources/jarTest/spring-boot/build-layered.gradle b/jib-cli/src/integration-test/resources/jarTest/spring-boot/build-layered.gradle
index 14d51f3e926..3b02e2bf877 100644
--- a/jib-cli/src/integration-test/resources/jarTest/spring-boot/build-layered.gradle
+++ b/jib-cli/src/integration-test/resources/jarTest/spring-boot/build-layered.gradle
@@ -1,5 +1,5 @@
plugins {
- id 'org.springframework.boot' version '2.3.7.RELEASE'
+ id 'org.springframework.boot' version '2.7.13'
id 'io.spring.dependency-management' version '1.0.10.RELEASE'
id 'java'
}
diff --git a/jib-cli/src/integration-test/resources/jarTest/spring-boot/build.gradle b/jib-cli/src/integration-test/resources/jarTest/spring-boot/build.gradle
index ac97a750e5d..a84cc06efcb 100644
--- a/jib-cli/src/integration-test/resources/jarTest/spring-boot/build.gradle
+++ b/jib-cli/src/integration-test/resources/jarTest/spring-boot/build.gradle
@@ -1,5 +1,5 @@
plugins {
- id 'org.springframework.boot' version '2.3.7.RELEASE'
+ id 'org.springframework.boot' version '2.7.13'
id 'io.spring.dependency-management' version '1.0.10.RELEASE'
id 'java'
}
@@ -10,6 +10,12 @@ repositories {
mavenCentral()
}
+tasks.named("bootJar") {
+ layered {
+ enabled = false // Spring Boot 2.4+: layering is enabled by default.
+ }
+}
+
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-web'
}
diff --git a/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.jar b/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.jar
index 490fda8577d..c1962a79e29 100644
Binary files a/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.jar and b/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.properties b/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.properties
index 5028f28f8e4..a5952066425 100644
--- a/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.properties
+++ b/jib-cli/src/integration-test/resources/jarTest/spring-boot/gradle/wrapper/gradle-wrapper.properties
@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.4-bin.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
diff --git a/jib-cli/src/integration-test/resources/warTest/build.gradle b/jib-cli/src/integration-test/resources/warTest/build.gradle
index 627efcfa296..10ea7f31cc1 100644
--- a/jib-cli/src/integration-test/resources/warTest/build.gradle
+++ b/jib-cli/src/integration-test/resources/warTest/build.gradle
@@ -3,8 +3,10 @@ plugins {
id 'war'
}
-sourceCompatibility = 1.8
-targetCompatibility = 1.8
+java {
+ sourceCompatibility = JavaVersion.VERSION_1_8
+ targetCompatibility = JavaVersion.VERSION_1_8
+}
repositories {
mavenCentral()
@@ -15,7 +17,7 @@ configurations {
}
dependencies {
- providedCompile 'jakarta.servlet:jakarta.servlet-api:5.0.0'
+ providedCompile 'jakarta.servlet:jakarta.servlet-api:6.0.0'
moreLibs 'jakarta.annotation:jakarta.annotation-api:2.1.0' // random extra JAR
}
diff --git a/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.jar b/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.jar
index 490fda8577d..c1962a79e29 100644
Binary files a/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.jar and b/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.properties b/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.properties
index 5028f28f8e4..a5952066425 100644
--- a/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.properties
+++ b/jib-cli/src/integration-test/resources/warTest/gradle/wrapper/gradle-wrapper.properties
@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.4-bin.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
diff --git a/jib-cli/src/main/java/com/google/cloud/tools/jib/cli/war/WarFiles.java b/jib-cli/src/main/java/com/google/cloud/tools/jib/cli/war/WarFiles.java
index a69d26a6937..2fb89abdfbf 100644
--- a/jib-cli/src/main/java/com/google/cloud/tools/jib/cli/war/WarFiles.java
+++ b/jib-cli/src/main/java/com/google/cloud/tools/jib/cli/war/WarFiles.java
@@ -81,7 +81,10 @@ private static List computeEntrypoint(
return entrypoint;
}
if (commonContainerConfigCliOptions.isJettyBaseimage()) {
- return ImmutableList.of("java", "-jar", "/usr/local/jetty/start.jar");
+ // jetty 12+ requires explicitly enabling ee10-deploy module. See:
+ // https://eclipse.dev/jetty/documentation/jetty-12/operations-guide/index.html
+ return ImmutableList.of(
+ "java", "-jar", "/usr/local/jetty/start.jar", "--module=http,ee10-deploy");
}
return null;
}
diff --git a/jib-cli/src/test/java/com/google/cloud/tools/jib/cli/war/WarFilesTest.java b/jib-cli/src/test/java/com/google/cloud/tools/jib/cli/war/WarFilesTest.java
index 513d7bc559b..129ef89bacc 100644
--- a/jib-cli/src/test/java/com/google/cloud/tools/jib/cli/war/WarFilesTest.java
+++ b/jib-cli/src/test/java/com/google/cloud/tools/jib/cli/war/WarFilesTest.java
@@ -74,7 +74,7 @@ public void testToJibContainerBuilder_explodedStandard_basicInfo()
assertThat(buildPlan.getBaseImage()).isEqualTo("jetty");
assertThat(buildPlan.getEntrypoint())
- .containsExactly("java", "-jar", "/usr/local/jetty/start.jar")
+ .containsExactly("java", "-jar", "/usr/local/jetty/start.jar", "--module=http,ee10-deploy")
.inOrder();
assertThat(buildPlan.getLayers()).hasSize(1);
assertThat(buildPlan.getLayers().get(0).getName()).isEqualTo("classes");
diff --git a/jib-core/build.gradle b/jib-core/build.gradle
index f31340e269d..697f479f987 100644
--- a/jib-core/build.gradle
+++ b/jib-core/build.gradle
@@ -71,7 +71,7 @@ publishing {
release {
tagTemplate = 'v$version-core'
git {
- requireBranch = /^core-release-v\d+.*$/ //regex
+ requireBranch.set(/^core-release-v\d+.*$/) //regex
}
}
/* RELEASE */
diff --git a/jib-core/src/integration-test/java/com/google/cloud/tools/jib/api/ReproducibleImageTest.java b/jib-core/src/integration-test/java/com/google/cloud/tools/jib/api/ReproducibleImageTest.java
index 1c194b2198d..75cd9906bca 100644
--- a/jib-core/src/integration-test/java/com/google/cloud/tools/jib/api/ReproducibleImageTest.java
+++ b/jib-core/src/integration-test/java/com/google/cloud/tools/jib/api/ReproducibleImageTest.java
@@ -25,6 +25,7 @@
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Multimap;
import com.google.common.io.CharStreams;
+import com.google.gson.internal.JavaVersion;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
@@ -100,21 +101,39 @@ public void testTarballStructure() throws IOException {
}
}
- assertThat(actual)
- .containsExactly(
- "c46572ef74f58d95e44dd36c1fbdfebd3752e8b56a794a13c11cfed35a1a6e1c.tar.gz",
- "6d2763b0f3940d324ea6b55386429e5b173899608abf7d1bff62e25dd2e4dcea.tar.gz",
- "530c1954a2b087d0b989895ea56435c9dc739a973f2d2b6cb9bb98e55bbea7ac.tar.gz",
- "config.json",
- "manifest.json")
- .inOrder();
+ if (JavaVersion.getMajorJavaVersion() < 16) {
+ assertThat(actual)
+ .containsExactly(
+ "c46572ef74f58d95e44dd36c1fbdfebd3752e8b56a794a13c11cfed35a1a6e1c.tar.gz",
+ "6d2763b0f3940d324ea6b55386429e5b173899608abf7d1bff62e25dd2e4dcea.tar.gz",
+ "530c1954a2b087d0b989895ea56435c9dc739a973f2d2b6cb9bb98e55bbea7ac.tar.gz",
+ "config.json",
+ "manifest.json")
+ .inOrder();
+ } else {
+ // JDK 16+ has changed Gzip output, so hash changes
+ // https://bugs.openjdk.org/browse/JDK-8244706
+
+ assertThat(actual)
+ .containsExactly(
+ "d32c6bf16170d213b5f458a7c120288f0fb376015db1943d1e1c411e9b7ec9eb.tar.gz",
+ "eb01acbf8104bd2a8c4b594a1385bab883f27e85a703ee98c2e6cc81e71aea2a.tar.gz",
+ "65738b93774dc833f97dcb5ba806bddce6079163ba54bf51c9f66db9d1ab69d9.tar.gz",
+ "config.json",
+ "manifest.json")
+ .inOrder();
+ }
}
@Test
public void testManifest() throws IOException {
String expectedManifest =
- "[{\"Config\":\"config.json\",\"RepoTags\":[\"jib-core/reproducible:latest\"],"
- + "\"Layers\":[\"c46572ef74f58d95e44dd36c1fbdfebd3752e8b56a794a13c11cfed35a1a6e1c.tar.gz\",\"6d2763b0f3940d324ea6b55386429e5b173899608abf7d1bff62e25dd2e4dcea.tar.gz\",\"530c1954a2b087d0b989895ea56435c9dc739a973f2d2b6cb9bb98e55bbea7ac.tar.gz\"]}]";
+ (JavaVersion.getMajorJavaVersion() < 16)
+ ? "[{\"Config\":\"config.json\",\"RepoTags\":[\"jib-core/reproducible:latest\"],"
+ + "\"Layers\":[\"c46572ef74f58d95e44dd36c1fbdfebd3752e8b56a794a13c11cfed35a1a6e1c.tar.gz\",\"6d2763b0f3940d324ea6b55386429e5b173899608abf7d1bff62e25dd2e4dcea.tar.gz\",\"530c1954a2b087d0b989895ea56435c9dc739a973f2d2b6cb9bb98e55bbea7ac.tar.gz\"]}]"
+ : "[{\"Config\":\"config.json\",\"RepoTags\":[\"jib-core/reproducible:latest\"],"
+ + "\"Layers\":[\"d32c6bf16170d213b5f458a7c120288f0fb376015db1943d1e1c411e9b7ec9eb.tar.gz\",\"eb01acbf8104bd2a8c4b594a1385bab883f27e85a703ee98c2e6cc81e71aea2a.tar.gz\",\"65738b93774dc833f97dcb5ba806bddce6079163ba54bf51c9f66db9d1ab69d9.tar.gz\"]}]";
+
String generatedManifest = extractFromTarFileAsString(imageTar, "manifest.json");
assertThat(generatedManifest).isEqualTo(expectedManifest);
}
diff --git a/jib-core/src/test/java/com/google/cloud/tools/jib/builder/steps/LocalBaseImageStepsTest.java b/jib-core/src/test/java/com/google/cloud/tools/jib/builder/steps/LocalBaseImageStepsTest.java
index 97bd9f12179..dc23b3e5a7e 100644
--- a/jib-core/src/test/java/com/google/cloud/tools/jib/builder/steps/LocalBaseImageStepsTest.java
+++ b/jib-core/src/test/java/com/google/cloud/tools/jib/builder/steps/LocalBaseImageStepsTest.java
@@ -29,6 +29,7 @@
import com.google.cloud.tools.jib.json.JsonTemplateMapper;
import com.google.common.io.Resources;
import com.google.common.util.concurrent.MoreExecutors;
+import com.google.gson.internal.JavaVersion;
import java.io.IOException;
import java.net.URISyntaxException;
import java.nio.file.Files;
@@ -93,17 +94,22 @@ public void testCacheDockerImageTar_validDocker() throws Exception {
Mockito.verify(progressEventDispatcher, Mockito.times(2)).newChildProducer();
Assert.assertEquals(2, result.layers.size());
+
Assert.assertEquals(
"5e701122d3347fae0758cd5b7f0692c686fcd07b0e7fd9c4a125fbdbbedc04dd",
result.layers.get(0).get().getDiffId().getHash());
Assert.assertEquals(
- "0011328ac5dfe3dde40c7c5e0e00c98d1833a3aeae2bfb668cf9eb965c229c7f",
+ JavaVersion.getMajorJavaVersion() < 16
+ ? "0011328ac5dfe3dde40c7c5e0e00c98d1833a3aeae2bfb668cf9eb965c229c7f"
+ : "bdc94fe3bba352809859ca87c846872ae2c1157596631e72d7d73e46fae86101",
result.layers.get(0).get().getBlobDescriptor().getDigest().getHash());
Assert.assertEquals(
"f1ac3015bcbf0ada4750d728626eb10f0f585199e2b667dcd79e49f0e926178e",
result.layers.get(1).get().getDiffId().getHash());
Assert.assertEquals(
- "c10ef24a5cef5092bbcb5a5666721cff7b86ce978c203a958d1fc86ee6c19f94",
+ JavaVersion.getMajorJavaVersion() < 16
+ ? "c10ef24a5cef5092bbcb5a5666721cff7b86ce978c203a958d1fc86ee6c19f94"
+ : "073d615d78a940951cfe91b1feee2da3c5d21f7df48539921c26aecd23185d5f",
result.layers.get(1).get().getBlobDescriptor().getDigest().getHash());
Assert.assertEquals(2, result.configurationTemplate.getLayerCount());
}
diff --git a/jib-gradle-plugin-extension-api/build.gradle b/jib-gradle-plugin-extension-api/build.gradle
index 1478f301273..977be52bf14 100644
--- a/jib-gradle-plugin-extension-api/build.gradle
+++ b/jib-gradle-plugin-extension-api/build.gradle
@@ -44,7 +44,7 @@ publishing {
release {
tagTemplate = 'v$version-gradle-extension'
git {
- requireBranch = /^gradle-extension-release-v\d+.*$/ //regex
+ requireBranch.set(/^gradle-extension-release-v\d+.*$/) //regex
}
}
/* RELEASE */
diff --git a/jib-gradle-plugin/build.gradle b/jib-gradle-plugin/build.gradle
index 46f416ab1ed..7c5f9b9f6a6 100644
--- a/jib-gradle-plugin/build.gradle
+++ b/jib-gradle-plugin/build.gradle
@@ -36,6 +36,7 @@ dependencies {
testImplementation dependencyStrings.TRUTH
testImplementation dependencyStrings.TRUTH8
testImplementation dependencyStrings.MOCKITO_CORE
+ testImplementation dependencyStrings.MOCKITO_INLINE
testImplementation dependencyStrings.SLF4J_API
testImplementation dependencyStrings.SYSTEM_RULES
@@ -45,7 +46,7 @@ dependencies {
integrationTestImplementation dependencyStrings.JBCRYPT
// only for testing a concrete Spring Boot example in a test (not for test infrastructure)
- testImplementation 'org.springframework.boot:spring-boot-gradle-plugin:2.2.11.RELEASE'
+ testImplementation 'org.springframework.boot:spring-boot-gradle-plugin:2.7.13'
}
/* RELEASE */
@@ -57,17 +58,13 @@ release {
'com.google.cloud.tools:jib-plugins-common',
]
git {
- requireBranch = /^gradle-release-v\d+.*$/ //regex
+ requireBranch.set(/^gradle-release-v\d+.*$/) //regex
}
}
// Gradle Plugin Portal releases
-pluginBundle {
+gradlePlugin {
website = 'https://github.com/GoogleContainerTools/jib/'
vcsUrl = 'https://github.com/GoogleContainerTools/jib/'
- tags = ['google', 'java', 'containers', 'docker', 'kubernetes', 'microservices']
-}
-
-gradlePlugin {
testSourceSets sourceSets.integrationTest, sourceSets.test
plugins {
jibPlugin {
@@ -75,6 +72,7 @@ gradlePlugin {
displayName = 'Jib'
description = 'Containerize your Java application'
implementationClass = 'com.google.cloud.tools.jib.gradle.JibPlugin'
+ tags.set(['google', 'java', 'containers', 'docker', 'kubernetes', 'microservices'])
}
}
}
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-configuration.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-configuration.gradle
index 0d78b139d3d..01da56096ac 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-configuration.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-configuration.gradle
@@ -24,8 +24,8 @@ configurations {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
- runtime 'com.google.guava:guava:30.1-jre'
+ implementation files('libs/dependency-1.0.0.jar')
+ runtimeOnly 'com.google.guava:guava:30.1-jre'
myConfiguration files('libs/dependency2')
otherConfiguration files('libs/dependency3')
}
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs-filtering.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs-filtering.gradle
index 4e04624dacd..94683083574 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs-filtering.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs-filtering.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib {
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs.gradle
index da49d7772be..9b1528671f1 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib {
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs2.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs2.gradle
index f4c21d20050..a1694ed9f73 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs2.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs2.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib {
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs3.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs3.gradle
index 178c0f80c9f..d48d6d501a2 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs3.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-extra-dirs3.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib {
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-jar-containerization.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-jar-containerization.gradle
index 917a55ef7f6..150f012681d 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-jar-containerization.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-jar-containerization.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jar {
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11-incompatible.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11-incompatible.gradle
index 2cc07b662ea..aa93e702f16 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11-incompatible.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11-incompatible.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib.from.image = 'eclipse-temurin:8-jdk-focal'
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11.gradle
index 8c563bfb005..995aa9e7afc 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java11.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib.from.image = 'eclipse-temurin:11-jdk-focal'
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java17.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java17.gradle
index 9c860213ef3..2600d5f6a89 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java17.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-java17.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib.to.image = System.getProperty("_TARGET_IMAGE")
\ No newline at end of file
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-local-base.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-local-base.gradle
index a757ac89fe2..6e57fa0be35 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-local-base.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-local-base.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib {
diff --git a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-timestamps-custom.gradle b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-timestamps-custom.gradle
index 9771046978e..1db4cc1e73f 100644
--- a/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-timestamps-custom.gradle
+++ b/jib-gradle-plugin/src/integration-test/resources/gradle/projects/simple/build-timestamps-custom.gradle
@@ -11,7 +11,7 @@ repositories {
}
dependencies {
- compile files('libs/dependency-1.0.0.jar')
+ implementation files('libs/dependency-1.0.0.jar')
}
jib {
diff --git a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildDockerTask.java b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildDockerTask.java
index 692449db037..1a5616afd3f 100644
--- a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildDockerTask.java
+++ b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildDockerTask.java
@@ -44,6 +44,7 @@
import javax.annotation.Nullable;
import org.gradle.api.DefaultTask;
import org.gradle.api.GradleException;
+import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.Nested;
import org.gradle.api.tasks.TaskAction;
import org.gradle.api.tasks.options.Option;
@@ -54,6 +55,7 @@ public class BuildDockerTask extends DefaultTask implements JibTask {
private static final String HELPFUL_SUGGESTIONS_PREFIX = "Build to Docker daemon failed";
@Nullable private JibExtension jibExtension;
+ @Nullable private GradleProjectProperties projectProperties;
/**
* This will call the property {@code "jib"} so that it is the same name as the extension. This
@@ -67,6 +69,12 @@ public JibExtension getJib() {
return jibExtension;
}
+ @Nullable
+ @Internal
+ public GradleProjectProperties getProjectProperties() {
+ return projectProperties;
+ }
+
/**
* The target image can be overridden with the {@code --image} command line option.
*
@@ -91,6 +99,7 @@ public void buildDocker()
throws IOException, BuildStepsExecutionException, CacheDirectoryCreationException,
MainClassInferenceException, InvalidGlobalConfigException {
Preconditions.checkNotNull(jibExtension);
+ Preconditions.checkNotNull(projectProperties);
// Check deprecated parameters
Path dockerExecutable = jibExtension.getDockerClient().getExecutablePath();
@@ -104,23 +113,16 @@ public void buildDocker()
}
TaskCommon.disableHttpLogging();
- TempDirectoryProvider tempDirectoryProvider = new TempDirectoryProvider();
- GradleProjectProperties projectProperties =
- GradleProjectProperties.getForProject(
- getProject(),
- getLogger(),
- tempDirectoryProvider,
- jibExtension.getConfigurationName().get());
GlobalConfig globalConfig = GlobalConfig.readConfig();
Future> updateCheckFuture =
- TaskCommon.newUpdateChecker(projectProperties, globalConfig, getLogger());
- try {
+ TaskCommon.newUpdateChecker(this.projectProperties, globalConfig, getLogger());
+ try (TempDirectoryProvider tempDirectoryProvider = new TempDirectoryProvider()) {
PluginConfigurationProcessor.createJibBuildRunnerForDockerDaemonImage(
new GradleRawConfiguration(jibExtension),
ignored -> java.util.Optional.empty(),
- projectProperties,
+ this.projectProperties,
globalConfig,
new GradleHelpfulSuggestions(HELPFUL_SUGGESTIONS_PREFIX))
.runBuild();
@@ -187,8 +189,7 @@ public void buildDocker()
+ ex.getPath(),
ex);
} finally {
- tempDirectoryProvider.close();
- TaskCommon.finishUpdateChecker(projectProperties, updateCheckFuture);
+ TaskCommon.finishUpdateChecker(this.projectProperties, updateCheckFuture);
projectProperties.waitForLoggingThread();
}
}
@@ -196,6 +197,12 @@ public void buildDocker()
@Override
public BuildDockerTask setJibExtension(JibExtension jibExtension) {
this.jibExtension = jibExtension;
+ this.projectProperties =
+ GradleProjectProperties.getForProject(
+ getProject(),
+ getLogger(),
+ new TempDirectoryProvider(),
+ jibExtension.getConfigurationName().get());
return this;
}
}
diff --git a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildImageTask.java b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildImageTask.java
index 49265559a61..2aef54bbef4 100644
--- a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildImageTask.java
+++ b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildImageTask.java
@@ -43,6 +43,7 @@
import javax.annotation.Nullable;
import org.gradle.api.DefaultTask;
import org.gradle.api.GradleException;
+import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.Nested;
import org.gradle.api.tasks.TaskAction;
import org.gradle.api.tasks.options.Option;
@@ -54,6 +55,8 @@ public class BuildImageTask extends DefaultTask implements JibTask {
@Nullable private JibExtension jibExtension;
+ @Nullable private GradleProjectProperties projectProperties;
+
/**
* This will call the property {@code "jib"} so that it is the same name as the extension. This
* way, the user would see error messages for missing configuration with the prefix {@code jib.}.
@@ -66,6 +69,12 @@ public JibExtension getJib() {
return jibExtension;
}
+ @Nullable
+ @Internal
+ public GradleProjectProperties getProjectProperties() {
+ return projectProperties;
+ }
+
/**
* The target image can be overridden with the {@code --image} command line option.
*
@@ -91,15 +100,9 @@ public void buildImage()
MainClassInferenceException, InvalidGlobalConfigException {
// Asserts required @Input parameters are not null.
Preconditions.checkNotNull(jibExtension);
+ Preconditions.checkNotNull(projectProperties);
TaskCommon.disableHttpLogging();
- TempDirectoryProvider tempDirectoryProvider = new TempDirectoryProvider();
- GradleProjectProperties projectProperties =
- GradleProjectProperties.getForProject(
- getProject(),
- getLogger(),
- tempDirectoryProvider,
- jibExtension.getConfigurationName().get());
GlobalConfig globalConfig = GlobalConfig.readConfig();
Future> updateCheckFuture =
TaskCommon.newUpdateChecker(projectProperties, globalConfig, getLogger());
@@ -182,15 +185,28 @@ public void buildImage()
+ ex.getPath(),
ex);
} finally {
- tempDirectoryProvider.close();
- TaskCommon.finishUpdateChecker(projectProperties, updateCheckFuture);
- projectProperties.waitForLoggingThread();
+
+ if (projectProperties != null) {
+ TempDirectoryProvider tempDirectoryProvider = projectProperties.getTempDirectoryProvider();
+ if (tempDirectoryProvider != null) {
+ tempDirectoryProvider.close();
+ }
+ TaskCommon.finishUpdateChecker(projectProperties, updateCheckFuture);
+ projectProperties.waitForLoggingThread();
+ }
}
}
@Override
public BuildImageTask setJibExtension(JibExtension jibExtension) {
this.jibExtension = jibExtension;
+ this.projectProperties =
+ GradleProjectProperties.getForProject(
+ getProject(),
+ getLogger(),
+ new TempDirectoryProvider(),
+ jibExtension.getConfigurationName().get());
+
return this;
}
}
diff --git a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildTarTask.java b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildTarTask.java
index 1a77856b6b0..4f4219da378 100644
--- a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildTarTask.java
+++ b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/BuildTarTask.java
@@ -47,6 +47,7 @@
import org.gradle.api.GradleException;
import org.gradle.api.file.FileCollection;
import org.gradle.api.tasks.InputFiles;
+import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.Nested;
import org.gradle.api.tasks.OutputFile;
import org.gradle.api.tasks.TaskAction;
@@ -71,6 +72,8 @@ public JibExtension getJib() {
return jibExtension;
}
+ @Nullable private GradleProjectProperties projectProperties;
+
/**
* The target image can be overridden with the {@code --image} command line option.
*
@@ -81,6 +84,12 @@ public void setTargetImage(String targetImage) {
Preconditions.checkNotNull(jibExtension).getTo().setImage(targetImage);
}
+ @Nullable
+ @Internal
+ public GradleProjectProperties getProjectProperties() {
+ return projectProperties;
+ }
+
/**
* Returns a collection of all the files that jib includes in the image. Only used to calculate
* UP-TO-DATE.
@@ -122,23 +131,19 @@ public void buildTar()
MainClassInferenceException, InvalidGlobalConfigException {
// Asserts required @Input parameters are not null.
Preconditions.checkNotNull(jibExtension);
+ Preconditions.checkNotNull(projectProperties);
TaskCommon.disableHttpLogging();
- TempDirectoryProvider tempDirectoryProvider = new TempDirectoryProvider();
- GradleProjectProperties projectProperties =
- GradleProjectProperties.getForProject(
- getProject(),
- getLogger(),
- tempDirectoryProvider,
- jibExtension.getConfigurationName().get());
GlobalConfig globalConfig = GlobalConfig.readConfig();
Future> updateCheckFuture =
- TaskCommon.newUpdateChecker(projectProperties, globalConfig, getLogger());
- try {
+ TaskCommon.newUpdateChecker(this.projectProperties, globalConfig, getLogger());
+
+ try (TempDirectoryProvider tempDirectoryProvider = new TempDirectoryProvider()) {
+
PluginConfigurationProcessor.createJibBuildRunnerForTarImage(
new GradleRawConfiguration(jibExtension),
ignored -> Optional.empty(),
- projectProperties,
+ this.projectProperties,
globalConfig,
new GradleHelpfulSuggestions(HELPFUL_SUGGESTIONS_PREFIX))
.runBuild();
@@ -204,7 +209,6 @@ public void buildTar()
+ ex.getPath(),
ex);
} finally {
- tempDirectoryProvider.close();
TaskCommon.finishUpdateChecker(projectProperties, updateCheckFuture);
projectProperties.waitForLoggingThread();
}
@@ -213,6 +217,12 @@ public void buildTar()
@Override
public BuildTarTask setJibExtension(JibExtension jibExtension) {
this.jibExtension = jibExtension;
+ this.projectProperties =
+ GradleProjectProperties.getForProject(
+ getProject(),
+ getLogger(),
+ new TempDirectoryProvider(),
+ jibExtension.getConfigurationName().get());
return this;
}
}
diff --git a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/ExtraDirectoriesParameters.java b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/ExtraDirectoriesParameters.java
index 30dc526e89b..c8d0d009fb8 100644
--- a/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/ExtraDirectoriesParameters.java
+++ b/jib-gradle-plugin/src/main/java/com/google/cloud/tools/jib/gradle/ExtraDirectoriesParameters.java
@@ -19,6 +19,7 @@
import com.google.cloud.tools.jib.plugins.common.ConfigurationPropertyValidator;
import com.google.cloud.tools.jib.plugins.common.PropertyNames;
import java.io.File;
+import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.Collections;
import java.util.List;
@@ -28,30 +29,37 @@
import javax.inject.Inject;
import org.gradle.api.Action;
import org.gradle.api.Project;
+import org.gradle.api.internal.file.FileOperations;
import org.gradle.api.model.ObjectFactory;
import org.gradle.api.provider.ListProperty;
import org.gradle.api.provider.MapProperty;
import org.gradle.api.provider.Provider;
import org.gradle.api.tasks.Input;
-import org.gradle.api.tasks.Internal;
+import org.gradle.api.tasks.Nested;
+import org.gradle.api.tasks.Optional;
/** Object in {@link JibExtension} that configures the extra directories. */
public class ExtraDirectoriesParameters {
private final ObjectFactory objects;
- private final Project project;
-
+ private final Path projectPath;
+ private final Provider extraDirPaths;
+ private final FileOperations fileOperations;
private ListProperty paths;
private ExtraDirectoryParametersSpec spec;
private MapProperty permissions;
@Inject
- public ExtraDirectoriesParameters(ObjectFactory objects, Project project) {
+ public ExtraDirectoriesParameters(
+ ObjectFactory objects, FileOperations fileOperations, Project project) {
this.objects = objects;
- this.project = project;
+ this.fileOperations = fileOperations;
paths = objects.listProperty(ExtraDirectoryParameters.class).empty();
spec = objects.newInstance(ExtraDirectoryParametersSpec.class, project, paths);
permissions = objects.mapProperty(String.class, String.class).empty();
+ this.projectPath = project.getProjectDir().toPath();
+ this.extraDirPaths =
+ project.getProviders().systemProperty(PropertyNames.EXTRA_DIRECTORIES_PATHS);
}
public void paths(Action super ExtraDirectoryParametersSpec> action) {
@@ -59,31 +67,28 @@ public void paths(Action super ExtraDirectoryParametersSpec> action) {
}
@Input
- public List getPathStrings() {
- // Gradle warns about @Input annotations on File objects, so we have to expose a getter for a
- // String to make them go away.
- return getPaths().stream()
- .map(extraDirectoryParameters -> extraDirectoryParameters.getFrom().toString())
- .collect(Collectors.toList());
+ @Optional
+ public Provider getExtraDirPaths() {
+ return extraDirPaths;
}
- @Internal
+ @Nested
public List getPaths() {
// Gradle warns about @Input annotations on File objects, so we have to expose a getter for a
// String to make them go away.
- String property = System.getProperty(PropertyNames.EXTRA_DIRECTORIES_PATHS);
- if (property != null) {
- List pathStrings = ConfigurationPropertyValidator.parseListProperty(property);
+ if (this.extraDirPaths.isPresent()) {
+ List pathStrings =
+ ConfigurationPropertyValidator.parseListProperty(this.extraDirPaths.get());
return pathStrings.stream()
- .map(path -> new ExtraDirectoryParameters(objects, project, Paths.get(path), "/"))
+ .map(path -> new ExtraDirectoryParameters(objects, fileOperations, Paths.get(path), "/"))
.collect(Collectors.toList());
}
if (paths.get().isEmpty()) {
return Collections.singletonList(
new ExtraDirectoryParameters(
objects,
- project,
- project.getProjectDir().toPath().resolve("src").resolve("main").resolve("jib"),
+ fileOperations,
+ projectPath.resolve("src").resolve("main").resolve("jib"),
"/"));
}
return paths.get();
@@ -115,8 +120,8 @@ public void setPaths(Provider