mirror of
				https://github.com/gradle/gradle-build-action.git
				synced 2025-10-22 09:38:54 +08:00 
			
		
		
		
	Compare commits
	
		
			8 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | d0c5f7955e | ||
|  | a2ba194e38 | ||
|  | 064f85c156 | ||
|  | 580b26a94c | ||
|  | c61d0fe2b5 | ||
|  | 6170f06e8d | ||
|  | e561eefa28 | ||
|  | 2d5ca45eab | 
							
								
								
									
										3
									
								
								.github/dco.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/dco.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +0,0 @@ | |||||||
| # Disable sign-off checking for members of the Gradle GitHub organization |  | ||||||
| require: |  | ||||||
|   members: false |  | ||||||
							
								
								
									
										5
									
								
								.github/workflow-samples/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/workflow-samples/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +0,0 @@ | |||||||
| # Ignore Gradle project-specific cache directory |  | ||||||
| .gradle |  | ||||||
|  |  | ||||||
| # Ignore Gradle build output directory |  | ||||||
| build |  | ||||||
										
											Binary file not shown.
										
									
								
							| @@ -1,8 +0,0 @@ | |||||||
| distributionBase=GRADLE_USER_HOME |  | ||||||
| distributionPath=wrapper/dists |  | ||||||
| distributionSha256Sum=544c35d6bd849ae8a5ed0bcea39ba677dc40f49df7d1835561582da2009b961d |  | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip |  | ||||||
| networkTimeout=10000 |  | ||||||
| validateDistributionUrl=true |  | ||||||
| zipStoreBase=GRADLE_USER_HOME |  | ||||||
| zipStorePath=wrapper/dists |  | ||||||
							
								
								
									
										249
									
								
								.github/workflow-samples/gradle-plugin/gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										249
									
								
								.github/workflow-samples/gradle-plugin/gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -1,249 +0,0 @@ | |||||||
| #!/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 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 |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| # 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 |  | ||||||
|  |  | ||||||
| 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  ;; #( |  | ||||||
|   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 |  | ||||||
|     else |  | ||||||
|         JAVACMD=$JAVA_HOME/bin/java |  | ||||||
|     fi |  | ||||||
|     if [ ! -x "$JAVACMD" ] ; then |  | ||||||
|         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |  | ||||||
|  |  | ||||||
| Please set the JAVA_HOME variable in your environment to match the |  | ||||||
| location of your Java installation." |  | ||||||
|     fi |  | ||||||
| else |  | ||||||
|     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" && ! "$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 |  | ||||||
|  |  | ||||||
| # 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" ) |  | ||||||
|  |  | ||||||
|     # Now convert the arguments - kludge to limit ourselves to /bin/sh |  | ||||||
|     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 |  | ||||||
|         # 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 |  | ||||||
| fi |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # 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" "$@" |  | ||||||
| @@ -1,92 +0,0 @@ | |||||||
| @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 |  | ||||||
| @rem |  | ||||||
| @rem ########################################################################## |  | ||||||
|  |  | ||||||
| @rem Set local scope for the variables with windows NT shell |  | ||||||
| if "%OS%"=="Windows_NT" setlocal |  | ||||||
|  |  | ||||||
| set DIRNAME=%~dp0 |  | ||||||
| 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" "-Xms64m" |  | ||||||
|  |  | ||||||
| @rem Find java.exe |  | ||||||
| if defined JAVA_HOME goto findJavaFromJavaHome |  | ||||||
|  |  | ||||||
| set JAVA_EXE=java.exe |  | ||||||
| %JAVA_EXE% -version >NUL 2>&1 |  | ||||||
| if %ERRORLEVEL% equ 0 goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :findJavaFromJavaHome |  | ||||||
| set JAVA_HOME=%JAVA_HOME:"=% |  | ||||||
| set JAVA_EXE=%JAVA_HOME%/bin/java.exe |  | ||||||
|  |  | ||||||
| if exist "%JAVA_EXE%" goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :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 %* |  | ||||||
|  |  | ||||||
| :end |  | ||||||
| @rem End local scope for the variables with windows NT shell |  | ||||||
| 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! |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| :omega |  | ||||||
| @@ -1,60 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This file was generated by the Gradle 'init' task. |  | ||||||
|  * |  | ||||||
|  * This generated file contains a sample Gradle plugin project to get you started. |  | ||||||
|  * For more details take a look at the Writing Custom Plugins chapter in the Gradle |  | ||||||
|  * User Manual available at https://docs.gradle.org/7.3/userguide/custom_plugins.html |  | ||||||
|  * This project uses @Incubating APIs which are subject to change. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| plugins { |  | ||||||
|     // Apply the Java Gradle plugin development plugin to add support for developing Gradle plugins |  | ||||||
|     id 'java-gradle-plugin' |  | ||||||
| } |  | ||||||
|  |  | ||||||
| repositories { |  | ||||||
|     // Use Maven Central for resolving dependencies. |  | ||||||
|     mavenCentral() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| testing { |  | ||||||
|     suites { |  | ||||||
|         // Configure the built-in test suite |  | ||||||
|         test { |  | ||||||
|             // Use JUnit Jupiter test framework |  | ||||||
|             useJUnitJupiter('5.7.2') |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Create a new test suite |  | ||||||
|         functionalTest(JvmTestSuite) { |  | ||||||
|             dependencies { |  | ||||||
|                 // functionalTest test suite depends on the production code in tests |  | ||||||
|                 implementation(project(':plugin')) |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             targets { |  | ||||||
|                 all { |  | ||||||
|                     // This test suite should run after the built-in test suite has run its tests |  | ||||||
|                     testTask.configure { shouldRunAfter(test) }  |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradlePlugin { |  | ||||||
|     // Define the plugin |  | ||||||
|     plugins { |  | ||||||
|         greeting { |  | ||||||
|             id = 'org.example.gradle.plugin.greeting' |  | ||||||
|             implementationClass = 'org.example.gradle.plugin.GradlePluginPlugin' |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradlePlugin.testSourceSets(sourceSets.functionalTest) |  | ||||||
|  |  | ||||||
| tasks.named('check') { |  | ||||||
|     // Include functionalTest as part of the check lifecycle |  | ||||||
|     dependsOn(testing.suites.functionalTest) |  | ||||||
| } |  | ||||||
| @@ -1,57 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This Java source file was generated by the Gradle 'init' task. |  | ||||||
|  */ |  | ||||||
| package org.example.gradle.plugin; |  | ||||||
|  |  | ||||||
| import java.io.File; |  | ||||||
| import java.io.IOException; |  | ||||||
| import java.io.Writer; |  | ||||||
| import java.io.FileWriter; |  | ||||||
| import java.nio.file.Files; |  | ||||||
| import org.gradle.testkit.runner.GradleRunner; |  | ||||||
| import org.gradle.testkit.runner.BuildResult; |  | ||||||
| import org.junit.jupiter.api.Test; |  | ||||||
| import org.junit.jupiter.api.io.TempDir; |  | ||||||
| import static org.junit.jupiter.api.Assertions.*; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * A simple functional test for the 'org.example.gradle.plugin.greeting' plugin. |  | ||||||
|  */ |  | ||||||
| class GradlePluginPluginFunctionalTest { |  | ||||||
|     @TempDir |  | ||||||
|     File projectDir; |  | ||||||
|  |  | ||||||
|     private File getBuildFile() { |  | ||||||
|         return new File(projectDir, "build.gradle"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private File getSettingsFile() { |  | ||||||
|         return new File(projectDir, "settings.gradle"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Test void canRunTaskWithGradle691() throws IOException { |  | ||||||
|         writeString(getSettingsFile(), ""); |  | ||||||
|         writeString(getBuildFile(), |  | ||||||
|             "plugins {" + |  | ||||||
|             "  id('org.example.gradle.plugin.greeting')" + |  | ||||||
|             "}"); |  | ||||||
|  |  | ||||||
|         // Run the build |  | ||||||
|         GradleRunner runner = GradleRunner.create(); |  | ||||||
|         runner.forwardOutput(); |  | ||||||
|         runner.withGradleVersion("6.9.1"); |  | ||||||
|         runner.withPluginClasspath(); |  | ||||||
|         runner.withArguments("greeting"); |  | ||||||
|         runner.withProjectDir(projectDir); |  | ||||||
|         BuildResult result = runner.build(); |  | ||||||
|  |  | ||||||
|         // Verify the result |  | ||||||
|         assertTrue(result.getOutput().contains("Hello from plugin 'org.example.gradle.plugin.greeting'")); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void writeString(File file, String string) throws IOException { |  | ||||||
|         try (Writer writer = new FileWriter(file)) { |  | ||||||
|             writer.write(string); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This Java source file was generated by the Gradle 'init' task. |  | ||||||
|  */ |  | ||||||
| package org.example.gradle.plugin; |  | ||||||
|  |  | ||||||
| import org.gradle.api.Project; |  | ||||||
| import org.gradle.api.Plugin; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * A simple 'hello world' plugin. |  | ||||||
|  */ |  | ||||||
| public class GradlePluginPlugin implements Plugin<Project> { |  | ||||||
|     public void apply(Project project) { |  | ||||||
|         // Register a task |  | ||||||
|         project.getTasks().register("greeting", task -> { |  | ||||||
|             task.doLast(s -> System.out.println("Hello from plugin 'org.example.gradle.plugin.greeting'")); |  | ||||||
|         }); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This Java source file was generated by the Gradle 'init' task. |  | ||||||
|  */ |  | ||||||
| package org.example.gradle.plugin; |  | ||||||
|  |  | ||||||
| import org.gradle.testfixtures.ProjectBuilder; |  | ||||||
| import org.gradle.api.Project; |  | ||||||
| import org.junit.jupiter.api.Test; |  | ||||||
| import static org.junit.jupiter.api.Assertions.*; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * A simple unit test for the 'org.example.gradle.plugin.greeting' plugin. |  | ||||||
|  */ |  | ||||||
| class GradlePluginPluginTest { |  | ||||||
|     @Test void pluginRegistersATask() { |  | ||||||
|         // Create a test project and apply the plugin |  | ||||||
|         Project project = ProjectBuilder.builder().build(); |  | ||||||
|         project.getPlugins().apply("org.example.gradle.plugin.greeting"); |  | ||||||
|  |  | ||||||
|         // Verify the result |  | ||||||
|         assertNotNull(project.getTasks().findByName("greeting")); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This file was generated by the Gradle 'init' task. |  | ||||||
|  * |  | ||||||
|  * The settings file is used to specify which projects to include in your build. |  | ||||||
|  * |  | ||||||
|  * Detailed information about configuring a multi-project build in Gradle can be found |  | ||||||
|  * in the user manual at https://docs.gradle.org/7.3/userguide/multi_project_builds.html |  | ||||||
|  * This project uses @Incubating APIs which are subject to change. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| rootProject.name = 'gradle-plugin' |  | ||||||
| include('plugin') |  | ||||||
							
								
								
									
										22
									
								
								.github/workflow-samples/groovy-dsl/build.gradle
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								.github/workflow-samples/groovy-dsl/build.gradle
									
									
									
									
										vendored
									
									
								
							| @@ -1,22 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id 'java' |  | ||||||
| } |  | ||||||
|  |  | ||||||
| repositories { |  | ||||||
|     mavenCentral() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| dependencies { |  | ||||||
|     testImplementation('junit:junit:4.13.2') |  | ||||||
| } |  | ||||||
|  |  | ||||||
| tasks.named("test").configure { |  | ||||||
|     // Write marker file so we can detect if task was configured |  | ||||||
|     file("task-configured.txt").text = "true" |  | ||||||
|  |  | ||||||
|     doLast { |  | ||||||
|         if (System.properties.verifyCachedBuild) { |  | ||||||
|             throw new RuntimeException("Build was not cached: unexpected execution of test task") |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| org.gradle.caching=true |  | ||||||
										
											Binary file not shown.
										
									
								
							| @@ -1,8 +0,0 @@ | |||||||
| distributionBase=GRADLE_USER_HOME |  | ||||||
| distributionPath=wrapper/dists |  | ||||||
| distributionSha256Sum=544c35d6bd849ae8a5ed0bcea39ba677dc40f49df7d1835561582da2009b961d |  | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip |  | ||||||
| networkTimeout=10000 |  | ||||||
| validateDistributionUrl=true |  | ||||||
| zipStoreBase=GRADLE_USER_HOME |  | ||||||
| zipStorePath=wrapper/dists |  | ||||||
							
								
								
									
										249
									
								
								.github/workflow-samples/groovy-dsl/gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										249
									
								
								.github/workflow-samples/groovy-dsl/gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -1,249 +0,0 @@ | |||||||
| #!/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 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 |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| # 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 |  | ||||||
|  |  | ||||||
| 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  ;; #( |  | ||||||
|   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 |  | ||||||
|     else |  | ||||||
|         JAVACMD=$JAVA_HOME/bin/java |  | ||||||
|     fi |  | ||||||
|     if [ ! -x "$JAVACMD" ] ; then |  | ||||||
|         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |  | ||||||
|  |  | ||||||
| Please set the JAVA_HOME variable in your environment to match the |  | ||||||
| location of your Java installation." |  | ||||||
|     fi |  | ||||||
| else |  | ||||||
|     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" && ! "$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 |  | ||||||
|  |  | ||||||
| # 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" ) |  | ||||||
|  |  | ||||||
|     # Now convert the arguments - kludge to limit ourselves to /bin/sh |  | ||||||
|     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 |  | ||||||
|         # 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 |  | ||||||
| fi |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # 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" "$@" |  | ||||||
							
								
								
									
										92
									
								
								.github/workflow-samples/groovy-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										92
									
								
								.github/workflow-samples/groovy-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @@ -1,92 +0,0 @@ | |||||||
| @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 |  | ||||||
| @rem |  | ||||||
| @rem ########################################################################## |  | ||||||
|  |  | ||||||
| @rem Set local scope for the variables with windows NT shell |  | ||||||
| if "%OS%"=="Windows_NT" setlocal |  | ||||||
|  |  | ||||||
| set DIRNAME=%~dp0 |  | ||||||
| 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" "-Xms64m" |  | ||||||
|  |  | ||||||
| @rem Find java.exe |  | ||||||
| if defined JAVA_HOME goto findJavaFromJavaHome |  | ||||||
|  |  | ||||||
| set JAVA_EXE=java.exe |  | ||||||
| %JAVA_EXE% -version >NUL 2>&1 |  | ||||||
| if %ERRORLEVEL% equ 0 goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :findJavaFromJavaHome |  | ||||||
| set JAVA_HOME=%JAVA_HOME:"=% |  | ||||||
| set JAVA_EXE=%JAVA_HOME%/bin/java.exe |  | ||||||
|  |  | ||||||
| if exist "%JAVA_EXE%" goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :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 %* |  | ||||||
|  |  | ||||||
| :end |  | ||||||
| @rem End local scope for the variables with windows NT shell |  | ||||||
| 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! |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| :omega |  | ||||||
| @@ -1,14 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id "com.gradle.enterprise" version "3.16.2" |  | ||||||
|     id "com.gradle.common-custom-user-data-gradle-plugin" version "1.13" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradleEnterprise { |  | ||||||
|     buildScan { |  | ||||||
|         termsOfServiceUrl = "https://gradle.com/terms-of-service" |  | ||||||
|         termsOfServiceAgree = "yes" |  | ||||||
|         publishAlways() |  | ||||||
|         uploadInBackground = false |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| rootProject.name = 'groovy-dsl' |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| package basic; |  | ||||||
|  |  | ||||||
| import org.junit.Test; |  | ||||||
|  |  | ||||||
| public class BasicTest { |  | ||||||
|     @Test |  | ||||||
|     public void test() { |  | ||||||
|         assert true; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,17 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id 'java' |  | ||||||
| } |  | ||||||
|  |  | ||||||
| java { |  | ||||||
|     toolchain { |  | ||||||
|         languageVersion = JavaLanguageVersion.of(16) |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| repositories { |  | ||||||
|     mavenCentral() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| dependencies { |  | ||||||
|     testImplementation('junit:junit:4.13.2') |  | ||||||
| } |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| org.gradle.caching=true |  | ||||||
										
											Binary file not shown.
										
									
								
							| @@ -1,8 +0,0 @@ | |||||||
| distributionBase=GRADLE_USER_HOME |  | ||||||
| distributionPath=wrapper/dists |  | ||||||
| distributionSha256Sum=544c35d6bd849ae8a5ed0bcea39ba677dc40f49df7d1835561582da2009b961d |  | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip |  | ||||||
| networkTimeout=10000 |  | ||||||
| validateDistributionUrl=true |  | ||||||
| zipStoreBase=GRADLE_USER_HOME |  | ||||||
| zipStorePath=wrapper/dists |  | ||||||
							
								
								
									
										249
									
								
								.github/workflow-samples/java-toolchain/gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										249
									
								
								.github/workflow-samples/java-toolchain/gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -1,249 +0,0 @@ | |||||||
| #!/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 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 |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| # 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 |  | ||||||
|  |  | ||||||
| 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  ;; #( |  | ||||||
|   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 |  | ||||||
|     else |  | ||||||
|         JAVACMD=$JAVA_HOME/bin/java |  | ||||||
|     fi |  | ||||||
|     if [ ! -x "$JAVACMD" ] ; then |  | ||||||
|         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |  | ||||||
|  |  | ||||||
| Please set the JAVA_HOME variable in your environment to match the |  | ||||||
| location of your Java installation." |  | ||||||
|     fi |  | ||||||
| else |  | ||||||
|     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" && ! "$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 |  | ||||||
|  |  | ||||||
| # 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" ) |  | ||||||
|  |  | ||||||
|     # Now convert the arguments - kludge to limit ourselves to /bin/sh |  | ||||||
|     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 |  | ||||||
|         # 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 |  | ||||||
| fi |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # 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" "$@" |  | ||||||
| @@ -1,92 +0,0 @@ | |||||||
| @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 |  | ||||||
| @rem |  | ||||||
| @rem ########################################################################## |  | ||||||
|  |  | ||||||
| @rem Set local scope for the variables with windows NT shell |  | ||||||
| if "%OS%"=="Windows_NT" setlocal |  | ||||||
|  |  | ||||||
| set DIRNAME=%~dp0 |  | ||||||
| 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" "-Xms64m" |  | ||||||
|  |  | ||||||
| @rem Find java.exe |  | ||||||
| if defined JAVA_HOME goto findJavaFromJavaHome |  | ||||||
|  |  | ||||||
| set JAVA_EXE=java.exe |  | ||||||
| %JAVA_EXE% -version >NUL 2>&1 |  | ||||||
| if %ERRORLEVEL% equ 0 goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :findJavaFromJavaHome |  | ||||||
| set JAVA_HOME=%JAVA_HOME:"=% |  | ||||||
| set JAVA_EXE=%JAVA_HOME%/bin/java.exe |  | ||||||
|  |  | ||||||
| if exist "%JAVA_EXE%" goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :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 %* |  | ||||||
|  |  | ||||||
| :end |  | ||||||
| @rem End local scope for the variables with windows NT shell |  | ||||||
| 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! |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| :omega |  | ||||||
| @@ -1,5 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id("org.gradle.toolchains.foojay-resolver-convention") version("0.7.0") |  | ||||||
| } |  | ||||||
|  |  | ||||||
| rootProject.name = 'basic' |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| package basic; |  | ||||||
|  |  | ||||||
| import org.junit.Test; |  | ||||||
|  |  | ||||||
| public class BasicTest { |  | ||||||
|     @Test |  | ||||||
|     public void test() { |  | ||||||
|         assert true; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,29 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     `java-library` |  | ||||||
| } |  | ||||||
|  |  | ||||||
| repositories { |  | ||||||
|     mavenCentral() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| dependencies { |  | ||||||
|     api("org.apache.commons:commons-math3:3.6.1") |  | ||||||
|     implementation("com.google.guava:guava:33.1.0-jre") |  | ||||||
|  |  | ||||||
|     testImplementation("org.junit.jupiter:junit-jupiter:5.10.2") |  | ||||||
| } |  | ||||||
|  |  | ||||||
| tasks.test { |  | ||||||
|     useJUnitPlatform() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| tasks.named("test").configure { |  | ||||||
|     // Write marker file so we can detect if task was configured |  | ||||||
|     file("task-configured.txt").writeText("true") |  | ||||||
|  |  | ||||||
|     doLast { |  | ||||||
|         if (System.getProperties().containsKey("verifyCachedBuild")) { |  | ||||||
|             throw RuntimeException("Build was not cached: unexpected execution of test task") |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| org.gradle.caching=true |  | ||||||
										
											Binary file not shown.
										
									
								
							| @@ -1,8 +0,0 @@ | |||||||
| distributionBase=GRADLE_USER_HOME |  | ||||||
| distributionPath=wrapper/dists |  | ||||||
| distributionSha256Sum=544c35d6bd849ae8a5ed0bcea39ba677dc40f49df7d1835561582da2009b961d |  | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip |  | ||||||
| networkTimeout=10000 |  | ||||||
| validateDistributionUrl=true |  | ||||||
| zipStoreBase=GRADLE_USER_HOME |  | ||||||
| zipStorePath=wrapper/dists |  | ||||||
							
								
								
									
										249
									
								
								.github/workflow-samples/kotlin-dsl/gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										249
									
								
								.github/workflow-samples/kotlin-dsl/gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -1,249 +0,0 @@ | |||||||
| #!/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 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 |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| # 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 |  | ||||||
|  |  | ||||||
| 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  ;; #( |  | ||||||
|   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 |  | ||||||
|     else |  | ||||||
|         JAVACMD=$JAVA_HOME/bin/java |  | ||||||
|     fi |  | ||||||
|     if [ ! -x "$JAVACMD" ] ; then |  | ||||||
|         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |  | ||||||
|  |  | ||||||
| Please set the JAVA_HOME variable in your environment to match the |  | ||||||
| location of your Java installation." |  | ||||||
|     fi |  | ||||||
| else |  | ||||||
|     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" && ! "$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 |  | ||||||
|  |  | ||||||
| # 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" ) |  | ||||||
|  |  | ||||||
|     # Now convert the arguments - kludge to limit ourselves to /bin/sh |  | ||||||
|     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 |  | ||||||
|         # 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 |  | ||||||
| fi |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # 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" "$@" |  | ||||||
							
								
								
									
										92
									
								
								.github/workflow-samples/kotlin-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										92
									
								
								.github/workflow-samples/kotlin-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @@ -1,92 +0,0 @@ | |||||||
| @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 |  | ||||||
| @rem |  | ||||||
| @rem ########################################################################## |  | ||||||
|  |  | ||||||
| @rem Set local scope for the variables with windows NT shell |  | ||||||
| if "%OS%"=="Windows_NT" setlocal |  | ||||||
|  |  | ||||||
| set DIRNAME=%~dp0 |  | ||||||
| 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" "-Xms64m" |  | ||||||
|  |  | ||||||
| @rem Find java.exe |  | ||||||
| if defined JAVA_HOME goto findJavaFromJavaHome |  | ||||||
|  |  | ||||||
| set JAVA_EXE=java.exe |  | ||||||
| %JAVA_EXE% -version >NUL 2>&1 |  | ||||||
| if %ERRORLEVEL% equ 0 goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :findJavaFromJavaHome |  | ||||||
| set JAVA_HOME=%JAVA_HOME:"=% |  | ||||||
| set JAVA_EXE=%JAVA_HOME%/bin/java.exe |  | ||||||
|  |  | ||||||
| if exist "%JAVA_EXE%" goto execute |  | ||||||
|  |  | ||||||
| echo. 1>&2 |  | ||||||
| echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 |  | ||||||
| echo. 1>&2 |  | ||||||
| echo Please set the JAVA_HOME variable in your environment to match the 1>&2 |  | ||||||
| echo location of your Java installation. 1>&2 |  | ||||||
|  |  | ||||||
| goto fail |  | ||||||
|  |  | ||||||
| :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 %* |  | ||||||
|  |  | ||||||
| :end |  | ||||||
| @rem End local scope for the variables with windows NT shell |  | ||||||
| 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! |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| :omega |  | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id("com.gradle.enterprise") version "3.16.2" |  | ||||||
|     id("com.gradle.common-custom-user-data-gradle-plugin") version "1.13" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradleEnterprise { |  | ||||||
|     buildScan { |  | ||||||
|         termsOfServiceUrl = "https://gradle.com/terms-of-service" |  | ||||||
|         termsOfServiceAgree = "yes" |  | ||||||
|         publishAlways() |  | ||||||
|         isUploadInBackground = false |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| rootProject.name = "kotlin-dsl" |  | ||||||
|  |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This Java source file was generated by the Gradle 'init' task. |  | ||||||
|  */ |  | ||||||
| package com.example; |  | ||||||
|  |  | ||||||
| public class Library { |  | ||||||
|     public boolean someLibraryMethod() { |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,14 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This Java source file was generated by the Gradle 'init' task. |  | ||||||
|  */ |  | ||||||
| package com.example; |  | ||||||
|  |  | ||||||
| import org.junit.jupiter.api.Test; |  | ||||||
| import static org.junit.jupiter.api.Assertions.*; |  | ||||||
|  |  | ||||||
| class LibraryTest { |  | ||||||
|     @Test void someLibraryMethodReturnsTrue() { |  | ||||||
|         Library classUnderTest = new Library(); |  | ||||||
|         assertTrue(classUnderTest.someLibraryMethod(), "someLibraryMethod should return 'true'"); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
							
								
								
									
										1
									
								
								.github/workflow-samples/no-ge/build.gradle
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflow-samples/no-ge/build.gradle
									
									
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| // Required to keep dependabot happy |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| rootProject.name = 'no-ge' |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id "com.gradle.build-scan" version "1.16" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| buildScan { |  | ||||||
|     termsOfServiceUrl = "https://gradle.com/terms-of-service" |  | ||||||
|     termsOfServiceAgree = "yes" |  | ||||||
|     publishAlways() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| rootProject.name = 'no-wrapper' |  | ||||||
|  |  | ||||||
| println "Using Gradle version: ${gradle.gradleVersion}" |  | ||||||
|  |  | ||||||
| def gradleVersionCheck = System.properties.gradleVersionCheck |  | ||||||
| if (gradleVersionCheck && gradle.gradleVersion != gradleVersionCheck) { |  | ||||||
|     throw new RuntimeException("Got the wrong version: expected ${gradleVersionCheck} but was ${gradle.gradleVersion}") |  | ||||||
| } |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id "com.gradle.build-scan" version "3.16.2" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradleEnterprise { |  | ||||||
|     buildScan { |  | ||||||
|         termsOfServiceUrl = "https://gradle.com/terms-of-service" |  | ||||||
|         termsOfServiceAgree = "yes" |  | ||||||
|         publishAlways() |  | ||||||
|         uploadInBackground = false |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| rootProject.name = 'no-wrapper' |  | ||||||
|  |  | ||||||
| println "Using Gradle version: ${gradle.gradleVersion}" |  | ||||||
|  |  | ||||||
| def gradleVersionCheck = System.properties.gradleVersionCheck |  | ||||||
| if (gradleVersionCheck && gradle.gradleVersion != gradleVersionCheck) { |  | ||||||
|     throw new RuntimeException("Got the wrong version: expected ${gradleVersionCheck} but was ${gradle.gradleVersion}") |  | ||||||
| } |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| // Required to keep dependabot happy |  | ||||||
| @@ -1,21 +0,0 @@ | |||||||
| plugins { |  | ||||||
|     id "com.gradle.enterprise" version "3.16.2" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradleEnterprise { |  | ||||||
|     buildScan { |  | ||||||
|         termsOfServiceUrl = "https://gradle.com/terms-of-service" |  | ||||||
|         termsOfServiceAgree = "yes" |  | ||||||
|         publishAlways() |  | ||||||
|         uploadInBackground = false |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| rootProject.name = 'no-wrapper' |  | ||||||
|  |  | ||||||
| println "Using Gradle version: ${gradle.gradleVersion}" |  | ||||||
|  |  | ||||||
| def gradleVersionCheck = System.properties.gradleVersionCheck |  | ||||||
| if (gradleVersionCheck && gradle.gradleVersion != gradleVersionCheck) { |  | ||||||
|     throw new RuntimeException("Got the wrong version: expected ${gradleVersionCheck} but was ${gradle.gradleVersion}") |  | ||||||
| } |  | ||||||
							
								
								
									
										25
									
								
								.github/workflows/checkin.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								.github/workflows/checkin.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | name: "PR Checks" | ||||||
|  | on: [pull_request, push] | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   check_pr: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - uses: actions/checkout@v1 | ||||||
|  |  | ||||||
|  |     - name: "npm ci" | ||||||
|  |       run: npm ci | ||||||
|  |  | ||||||
|  |     - name: "npm run build" | ||||||
|  |       run: npm run build | ||||||
|  |  | ||||||
|  |     - name: "npm run test" | ||||||
|  |       run: npm run test | ||||||
|  |  | ||||||
|  |     - name: "check for uncommitted changes" | ||||||
|  |       # Ensure no changes, but ignore node_modules dir since dev/fresh ci deps installed. | ||||||
|  |       run: | | ||||||
|  |         git diff --exit-code --stat -- . ':!node_modules' \ | ||||||
|  |         || (echo "##[error] found changed files after build. please 'npm run build && npm run format'" \ | ||||||
|  |                  "and check in all changes" \ | ||||||
|  |             && exit 1) | ||||||
							
								
								
									
										91
									
								
								.github/workflows/ci-full-check.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										91
									
								
								.github/workflows/ci-full-check.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,91 +0,0 @@ | |||||||
| name: CI-full-check |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_dispatch: |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   action-inputs: |  | ||||||
|     uses: ./.github/workflows/integ-test-action-inputs.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   caching-config: |  | ||||||
|     uses: ./.github/workflows/integ-test-caching-config.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   dependency-graph: |  | ||||||
|     uses: ./.github/workflows/integ-test-dependency-graph.yml |  | ||||||
|     permissions: |  | ||||||
|       contents: write |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   dependency-graph-failures: |  | ||||||
|     uses: ./.github/workflows/integ-test-dependency-graph-failures.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   execution-with-caching: |  | ||||||
|     uses: ./.github/workflows/integ-test-execution-with-caching.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   execution: |  | ||||||
|     uses: ./.github/workflows/integ-test-execution.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   develocity-injection: |  | ||||||
|     uses: ./.github/workflows/integ-test-inject-develocity.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|     secrets: |  | ||||||
|       DEVELOCITY_ACCESS_KEY: ${{ secrets.GE_SOLUTIONS_ACCESS_TOKEN }} |  | ||||||
|  |  | ||||||
|   provision-gradle-versions: |  | ||||||
|     uses: ./.github/workflows/integ-test-provision-gradle-versions.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   restore-configuration-cache: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-configuration-cache.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|     secrets: |  | ||||||
|       GRADLE_ENCRYPTION_KEY: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|  |  | ||||||
|   restore-custom-gradle-home: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-custom-gradle-home.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   restore-containerized-gradle-home: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-containerized-gradle-home.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   restore-gradle-home: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-gradle-home.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   restore-java-toolchain: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-java-toolchain.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   sample-kotlin-dsl: |  | ||||||
|     uses: ./.github/workflows/integ-test-sample-kotlin-dsl.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   sample-gradle-plugin: |  | ||||||
|     uses: ./.github/workflows/integ-test-sample-gradle-plugin.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
|  |  | ||||||
|   toolchain-detection: |  | ||||||
|     uses: ./.github/workflows/integ-test-detect-java-toolchains.yml |  | ||||||
|     with: |  | ||||||
|       cache-key-prefix: ${{github.run_number}}- |  | ||||||
							
								
								
									
										88
									
								
								.github/workflows/ci-quick-check.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										88
									
								
								.github/workflows/ci-quick-check.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,88 +0,0 @@ | |||||||
| name: CI-quick-check |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_dispatch: |  | ||||||
|   push: |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   action-inputs: |  | ||||||
|     uses: ./.github/workflows/integ-test-action-inputs.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   caching-config: |  | ||||||
|     uses: ./.github/workflows/integ-test-caching-config.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   dependency-graph: |  | ||||||
|     uses: ./.github/workflows/integ-test-dependency-graph.yml |  | ||||||
|     permissions: |  | ||||||
|       contents: write |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   dependency-graph-failures: |  | ||||||
|     uses: ./.github/workflows/integ-test-dependency-graph-failures.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   execution-with-caching: |  | ||||||
|     uses: ./.github/workflows/integ-test-execution-with-caching.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   execution: |  | ||||||
|     uses: ./.github/workflows/integ-test-execution.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   develocity-injection: |  | ||||||
|     uses: ./.github/workflows/integ-test-inject-develocity.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|     secrets: |  | ||||||
|       DEVELOCITY_ACCESS_KEY: ${{ secrets.GE_SOLUTIONS_ACCESS_TOKEN }} |  | ||||||
|  |  | ||||||
|   provision-gradle-versions: |  | ||||||
|     uses: ./.github/workflows/integ-test-provision-gradle-versions.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   restore-configuration-cache: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-configuration-cache.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|     secrets: |  | ||||||
|       GRADLE_ENCRYPTION_KEY: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|  |  | ||||||
|   restore-containerized-gradle-home: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-containerized-gradle-home.yml |  | ||||||
|  |  | ||||||
|   restore-custom-gradle-home: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-custom-gradle-home.yml |  | ||||||
|  |  | ||||||
|   restore-gradle-home: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-gradle-home.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   restore-java-toolchain: |  | ||||||
|     uses: ./.github/workflows/integ-test-restore-java-toolchain.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   sample-kotlin-dsl: |  | ||||||
|     uses: ./.github/workflows/integ-test-sample-kotlin-dsl.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   sample-gradle-plugin: |  | ||||||
|     uses: ./.github/workflows/integ-test-sample-gradle-plugin.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
|  |  | ||||||
|   toolchain-detection: |  | ||||||
|     uses: ./.github/workflows/integ-test-detect-java-toolchains.yml |  | ||||||
|     with: |  | ||||||
|       runner-os: '["ubuntu-latest"]' |  | ||||||
							
								
								
									
										43
									
								
								.github/workflows/demo-failure-cases.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										43
									
								
								.github/workflows/demo-failure-cases.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,43 +0,0 @@ | |||||||
| name: demo-failure-cases |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_dispatch: |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|  |  | ||||||
|   failing-build: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Test build failure |  | ||||||
|       uses: ./ |  | ||||||
|       continue-on-error: true |  | ||||||
|       with: |  | ||||||
|         build-root-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|         arguments: not-a-valid-task |  | ||||||
|  |  | ||||||
|   wrapper-missing: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Test wrapper missing |  | ||||||
|       uses: ./ |  | ||||||
|       continue-on-error: true |  | ||||||
|       with: |  | ||||||
|         build-root-directory: .github/workflow-samples/no-wrapper |  | ||||||
|         arguments: help |  | ||||||
|  |  | ||||||
|   bad-configuration: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Test bad config value |  | ||||||
|       uses: ./ |  | ||||||
|       continue-on-error: true |  | ||||||
|       with: |  | ||||||
|         build-root-directory: .github/workflow-samples/no-wrapper |  | ||||||
|         arguments: help |  | ||||||
|         cache-disabled: yes |  | ||||||
							
								
								
									
										71
									
								
								.github/workflows/demo-job-summary.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										71
									
								
								.github/workflows/demo-job-summary.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,71 +0,0 @@ | |||||||
| name: Demo Job Summary, for Gradle builds |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_dispatch: |  | ||||||
|   push: |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   many-gradle-builds: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|     - name: Build kotlin-dsl project |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew assemble |  | ||||||
|     - name: Build kotlin-dsl project without Build Scan® |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew assemble check --no-scan |  | ||||||
|     - name: Build kotlin-dsl project with Build Scan® publish failure |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew check -Dgradle.enterprise.url=https://not.valid.server |  | ||||||
|     - name: Build groovy-dsl project |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew assemble |  | ||||||
|     - name: Build kotlin-dsl project with multiple gradle invocations |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: |  |  | ||||||
|          ./gradlew tasks --no-daemon |  | ||||||
|          ./gradlew help check |  | ||||||
|     - name: Fail groovy-dsl project |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       continue-on-error: true |  | ||||||
|       run: ./gradlew not-a-real-task |  | ||||||
|  |  | ||||||
|   successful-builds-with-no-summary: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         add-job-summary: on-failure |  | ||||||
|     - name: Build kotlin-dsl project |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew assemble |  | ||||||
|     - name: Build kotlin-dsl project without Build Scan® |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew assemble check --no-scan |  | ||||||
|  |  | ||||||
|   pre-existing-gradle-home: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Pre-create Gradle User Home |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         mkdir ~/.gradle |  | ||||||
|         mkdir ~/.gradle/caches |  | ||||||
|         touch ~/.gradle/caches/dummy.txt |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|     - name: Run build |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew assemble |  | ||||||
							
								
								
									
										51
									
								
								.github/workflows/demo-pr-build-scan-comment.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										51
									
								
								.github/workflows/demo-pr-build-scan-comment.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,51 +0,0 @@ | |||||||
| name: Demo adding Build Scan® comment to PR |  | ||||||
| on: |  | ||||||
|   pull_request: |  | ||||||
|     types: [assigned, review_requested] |  | ||||||
|  |  | ||||||
| permissions: |  | ||||||
|   pull-requests: write |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   successful-build-with-always-comment: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout project sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         add-job-summary-as-pr-comment: always |  | ||||||
|     - name: Run build with Gradle wrapper |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew build --scan |  | ||||||
|  |  | ||||||
|   successful-build-with-comment-on-failure: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout project sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         add-job-summary-as-pr-comment: on-failure |  | ||||||
|     - name: Run build with Gradle wrapper |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew build --scan |  | ||||||
|  |  | ||||||
|   failing-build-with-comment-on-failure: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout project sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         add-job-summary-as-pr-comment: on-failure |  | ||||||
|     - name: Run build with Gradle wrapper |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew no-a-real-task --scan |  | ||||||
|       continue-on-error: true |  | ||||||
							
								
								
									
										35
									
								
								.github/workflows/integ-test-action-inputs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										35
									
								
								.github/workflows/integ-test-action-inputs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,35 +0,0 @@ | |||||||
| name: Test action inputs |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: action-inputs-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   action-inputs: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Invoke with multi-line arguments |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         build-root-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|         arguments: | |  | ||||||
|             --configuration-cache |  | ||||||
|             --build-cache |  | ||||||
|             -DsystemProperty=FOO |  | ||||||
|             -PgradleProperty=BAR |  | ||||||
|             test |  | ||||||
|             jar |  | ||||||
							
								
								
									
										148
									
								
								.github/workflows/integ-test-caching-config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										148
									
								
								.github/workflows/integ-test-caching-config.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,148 +0,0 @@ | |||||||
| name: Test caching configuration |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: action-inputs-caching-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         # Add "enterprise" to main cache entry but omit "notifications" |  | ||||||
|         gradle-home-cache-includes: | |  | ||||||
|             caches |  | ||||||
|             enterprise |  | ||||||
|         # Exclude build-cache from main cache entry |  | ||||||
|         gradle-home-cache-excludes: | |  | ||||||
|             caches/build-cache-* |  | ||||||
|             caches/*/executionHistory |  | ||||||
|     - name: Build using Gradle wrapper |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline |  | ||||||
|   verify-build: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         # Use the same configuration as used in the seed build |  | ||||||
|         gradle-home-cache-includes: | |  | ||||||
|             caches |  | ||||||
|             enterprise |  | ||||||
|         gradle-home-cache-excludes: | |  | ||||||
|             caches/build-cache-* |  | ||||||
|             caches/*/executionHistory |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build with --offline |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test --offline |  | ||||||
|  |  | ||||||
|   # Test that build scans are captured when caching is explicitly disabled |  | ||||||
|   cache-disabled: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-disabled: true |  | ||||||
|     - name: Run Gradle build |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} |  | ||||||
|       run: gradle help "-DgradleVersionCheck=${{matrix.gradle}}" |  | ||||||
|     - name: Check Build Scan url is captured |  | ||||||
|       if: ${{ !steps.gradle.outputs.build-scan-url }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('No Build Scan detected') |  | ||||||
|  |  | ||||||
|   # Test that build scans are captured when caching is disabled because Gradle User Home already exists |  | ||||||
|   cache-disabled-pre-existing-gradle-home: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Create dummy Gradle User Home |  | ||||||
|       run: mkdir -p ~/.gradle/caches |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|     - name: Run Gradle build |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} |  | ||||||
|       run: gradle help "-DgradleVersionCheck=${{matrix.gradle}}" |  | ||||||
|     - name: Check Build Scan url is captured |  | ||||||
|       if: ${{ !steps.gradle.outputs.build-scan-url }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('No Build Scan detected') |  | ||||||
|  |  | ||||||
|   # Test seed the cache with cache-write-only and verify with cache-read-only |  | ||||||
|   seed-build-write-only: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: ${{ inputs.cache-key-prefix }}-write-only- |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-write-only: true |  | ||||||
|     - name: Build using Gradle wrapper |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test |  | ||||||
|  |  | ||||||
|   verify-write-only-build: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: ${{ inputs.cache-key-prefix }}-write-only- |  | ||||||
|     needs: seed-build-write-only |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build with --offline |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test --offline |  | ||||||
|  |  | ||||||
| @@ -1,91 +0,0 @@ | |||||||
| name: Test dependency graph |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: dependency-graph-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   unsupported-gradle-version-warning: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         gradle-version: 7.0.1 |  | ||||||
|         dependency-graph: generate |  | ||||||
|         dependency-graph-continue-on-failure: true |  | ||||||
|     - name: Run with unsupported Gradle version |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: | |  | ||||||
|         if gradle help | grep -q 'warning::Dependency Graph is not supported for Gradle 7.0.1. No dependency snapshot will be generated.'; |  | ||||||
|         then |  | ||||||
|           echo "Got the expected warning" |  | ||||||
|         else |  | ||||||
|           echo "Did not get the expected warning" |  | ||||||
|           exit 1 |  | ||||||
|         fi |  | ||||||
|  |  | ||||||
|   unsupported-gradle-version-failure: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         gradle-version: 7.0.1 |  | ||||||
|         dependency-graph: generate |  | ||||||
|         dependency-graph-continue-on-failure: false |  | ||||||
|     - name: Run with unsupported Gradle version |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: | |  | ||||||
|         if gradle help; then |  | ||||||
|           echo "Expected build to fail with Gradle 7.0.1" |  | ||||||
|           exit 1 |  | ||||||
|         fi |  | ||||||
|  |  | ||||||
|   insufficient-permissions-warning: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     permissions: |  | ||||||
|       contents: read |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         dependency-graph: generate-and-submit |  | ||||||
|         dependency-graph-continue-on-failure: true |  | ||||||
|     - name: Run with insufficient permissions |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew help |  | ||||||
|       # This test is primarily for demonstration: it's unclear how to check for warnings emitted in the post-action |  | ||||||
|  |  | ||||||
|   SHOULD_FAIL-insufficient-permissions-failure: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     permissions: |  | ||||||
|       contents: read |  | ||||||
|     continue-on-error: true |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         dependency-graph: generate-and-submit |  | ||||||
|         dependency-graph-continue-on-failure: false |  | ||||||
|     - name: Run with insufficient permissions |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew help |  | ||||||
|       # This test is primarily for demonstration: it's unclear how to check for a failure in the post-action |  | ||||||
							
								
								
									
										134
									
								
								.github/workflows/integ-test-dependency-graph.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										134
									
								
								.github/workflows/integ-test-dependency-graph.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,134 +0,0 @@ | |||||||
| name: Test dependency graph |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| permissions: |  | ||||||
|   contents: write |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: dependency-graph-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   groovy-generate: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         dependency-graph: generate-and-upload |  | ||||||
|     - name: Run gradle build |  | ||||||
|       run: ./gradlew build |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|  |  | ||||||
|   kotlin-generate: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         dependency-graph: generate-and-submit |  | ||||||
|     - name: Run gradle build |  | ||||||
|       run: ./gradlew build |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|    |  | ||||||
|   submit: |  | ||||||
|     needs: [groovy-generate] |  | ||||||
|     runs-on: "ubuntu-latest" |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Submit dependency graphs |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         dependency-graph: download-and-submit |  | ||||||
|  |  | ||||||
|   multiple-builds: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         dependency-graph: generate-and-submit |  | ||||||
|     - id: gradle-assemble |  | ||||||
|       run: ./gradlew assemble |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|     - id: gradle-build |  | ||||||
|       run: ./gradlew build |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|     - id: gradle-build-again |  | ||||||
|       run: ./gradlew build |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|     - name: Check generated dependency graphs |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         echo "gradle-assemble report file: ${{ steps.gradle-assemble.outputs.dependency-graph-file }}" |  | ||||||
|         echo "gradle-build report file: ${{ steps.gradle-build.outputs.dependency-graph-file }}" |  | ||||||
|         echo "gradle-build-again report file: ${{ steps.gradle-build-again.outputs.dependency-graph-file }}" |  | ||||||
|         ls -l dependency-graph-reports |  | ||||||
|         if [ ! -e "${{ steps.gradle-assemble.outputs.dependency-graph-file }}" ]; then |  | ||||||
|             echo "Did not find gradle-assemble dependency graph file" |  | ||||||
|             exit 1 |  | ||||||
|         fi |  | ||||||
|         if [ ! -e "${{ steps.gradle-build.outputs.dependency-graph-file }}" ]; then |  | ||||||
|             echo "Did not find gradle-build dependency graph files" |  | ||||||
|             exit 1 |  | ||||||
|         fi |  | ||||||
|         if [ ! -e "${{ steps.gradle-build-again.outputs.dependency-graph-file }}" ]; then |  | ||||||
|             echo "Did not find gradle-build-again dependency graph files" |  | ||||||
|             exit 1 |  | ||||||
|         fi |  | ||||||
|          |  | ||||||
|   config-cache: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle for dependency-graph generate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         dependency-graph: generate-and-submit |  | ||||||
|     - id: config-cache-store |  | ||||||
|       run: ./gradlew assemble --configuration-cache |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|     - name: Check and delete generated dependency graph |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         if [ ! -e "${{ steps.config-cache-store.outputs.dependency-graph-file }}" ]; then |  | ||||||
|             echo "Did not find config-cache-store dependency graph files" |  | ||||||
|             exit 1 |  | ||||||
|         fi |  | ||||||
|         rm ${{ steps.config-cache-store.outputs.dependency-graph-file }} |  | ||||||
|     - id: config-cache-reuse |  | ||||||
|       run: ./gradlew assemble --configuration-cache |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|     - name: Check no dependency graph is generated |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         if [ ! -z "$(ls -A dependency-graph-reports)" ]; then |  | ||||||
|             echo "Expected no dependency graph files to be generated" |  | ||||||
|             ls -l dependency-graph-reports |  | ||||||
|             exit 1 |  | ||||||
|         fi         |  | ||||||
| @@ -1,85 +0,0 @@ | |||||||
| name: Test detect java toolchains |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: detect-java-toolchain-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   # Test that pre-installed runner JDKs are detected |  | ||||||
|   pre-installed-toolchains: |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|     - name: List detected toolchains |  | ||||||
|       shell: bash |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: |  |  | ||||||
|         gradle --info javaToolchains > output.txt |  | ||||||
|         cat output.txt |  | ||||||
|     - name: Verify detected toolchains |  | ||||||
|       shell: bash |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: |  |  | ||||||
|         grep -q 'Eclipse Temurin JDK 1.8' output.txt || (echo "::error::Did not detect preinstalled JDK 1.8" && exit 1) |  | ||||||
|         grep -q 'Eclipse Temurin JDK 11' output.txt || (echo "::error::Did not detect preinstalled JDK 11" && exit 1) |  | ||||||
|         grep -q 'Eclipse Temurin JDK 17' output.txt || (echo "::error::Did not detect preinstalled JDK 17" && exit 1) |  | ||||||
|         grep -q 'Eclipse Temurin JDK 21' output.txt || (echo "::error::Did not detect preinstalled JDK 21" && exit 1) |  | ||||||
|  |  | ||||||
|   # Test that JDKs provisioned by setup-java are detected |  | ||||||
|   setup-java-installed-toolchain: |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java 20 |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'temurin' |  | ||||||
|         java-version: '20' |  | ||||||
|     - name: Setup Java 16 |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'temurin' |  | ||||||
|         java-version: '16' |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|     - name: List detected toolchains |  | ||||||
|       shell: bash |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: |  |  | ||||||
|         gradle --info javaToolchains > output.txt |  | ||||||
|         cat output.txt |  | ||||||
|     - name: Verify setup JDKs are detected |  | ||||||
|       shell: bash |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: |  |  | ||||||
|         grep -q 'Eclipse Temurin JDK 16' output.txt || (echo "::error::Did not detect setup-java installed JDK 16" && exit 1) |  | ||||||
|         grep -q 'Eclipse Temurin JDK 20' output.txt || (echo "::error::Did not detect setup-java installed JDK 20" && exit 1) |  | ||||||
|     - name: Verify pre-installed toolchains are detected |  | ||||||
|       shell: bash |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: |  |  | ||||||
|         grep -q 'Eclipse Temurin JDK 1.8' output.txt || (echo "::error::Did not detect preinstalled JDK 1.8" && exit 1) |  | ||||||
|         grep -q 'Eclipse Temurin JDK 11' output.txt || (echo "::error::Did not detect preinstalled JDK 11" && exit 1) |  | ||||||
|         grep -q 'Eclipse Temurin JDK 17' output.txt || (echo "::error::Did not detect preinstalled JDK 17" && exit 1) |  | ||||||
|         grep -q 'Eclipse Temurin JDK 21' output.txt || (echo "::error::Did not detect preinstalled JDK 21" && exit 1) |  | ||||||
| @@ -1,48 +0,0 @@ | |||||||
| name: Test execution with caching |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: execution-with-caching-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Execute Gradle build |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         build-root-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|         arguments: test |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home is restored |  | ||||||
|   verify-build: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Execute Gradle build |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|         build-root-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|         arguments: test --offline -DverifyCachedBuild=true |  | ||||||
|  |  | ||||||
							
								
								
									
										80
									
								
								.github/workflows/integ-test-execution.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										80
									
								
								.github/workflows/integ-test-execution.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,80 +0,0 @@ | |||||||
| name: Test execution |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: execution-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs:    |  | ||||||
|   # Tests for executing with different Gradle versions.  |  | ||||||
|   # Each build verifies that it is executed with the expected Gradle version. |  | ||||||
|   gradle-execution: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|         include: |  | ||||||
|           - os: windows-latest |  | ||||||
|             script-suffix: '.bat' |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Test use defined Gradle version |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         gradle-version: 6.9 |  | ||||||
|         build-root-directory: .github/workflow-samples/no-wrapper |  | ||||||
|         arguments: help -DgradleVersionCheck=6.9 |  | ||||||
|     - name: Test use Gradle version alias |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         gradle-version: release-candidate |  | ||||||
|         build-root-directory: .github/workflow-samples/no-wrapper |  | ||||||
|         arguments: help |  | ||||||
|  |  | ||||||
|   gradle-versions: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         gradle: [7.5.1, 6.9.2, 5.6.4, 4.10.3, 3.5.1] |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|         include: |  | ||||||
|           - gradle: 5.6.4 |  | ||||||
|             build-root-suffix: -gradle-5 |  | ||||||
|           - gradle: 4.10.3 |  | ||||||
|             build-root-suffix: -gradle-4 |  | ||||||
|           - gradle: 3.5.1 |  | ||||||
|             build-root-suffix: -gradle-4 |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: temurin |  | ||||||
|         java-version: 8 |  | ||||||
|     - name: Run Gradle build |  | ||||||
|       uses: ./ |  | ||||||
|       id: gradle |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         gradle-version: ${{matrix.gradle}} |  | ||||||
|         build-root-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} |  | ||||||
|         arguments: help -DgradleVersionCheck=${{matrix.gradle}} |  | ||||||
|     - name: Check Build Scan url |  | ||||||
|       if: ${{ !steps.gradle.outputs.build-scan-url }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('No Build Scan detected')     |  | ||||||
|    |  | ||||||
|     |  | ||||||
| @@ -1,89 +0,0 @@ | |||||||
| name: Test develocity injection |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|     secrets: |  | ||||||
|       DEVELOCITY_ACCESS_KEY: |  | ||||||
|         required: true |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: provision-gradle-versions-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   inject-develocity: |  | ||||||
|     env: |  | ||||||
|       DEVELOCITY_INJECTION_ENABLED: true |  | ||||||
|       DEVELOCITY_URL: https://ge.solutions-team.gradle.com |  | ||||||
|       DEVELOCITY_PLUGIN_VERSION: 3.16.2 |  | ||||||
|       DEVELOCITY_CCUD_PLUGIN_VERSION: 1.13 |  | ||||||
|       GRADLE_ENTERPRISE_ACCESS_KEY: ${{ secrets.DEVELOCITY_ACCESS_KEY }} # This env var has not (yet) been renamed/aliased in GE plugin 3.16.2 |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         gradle: [current, 7.6.2, 6.9.4, 5.6.4] |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: temurin |  | ||||||
|         java-version: 8 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       id: setup-gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         gradle-version: ${{ matrix.gradle }} |  | ||||||
|     - name: Run Gradle build |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/no-ge |  | ||||||
|       run: gradle help |  | ||||||
|     - name: Check Build Scan url |  | ||||||
|       if: ${{ !steps.gradle.outputs.build-scan-url }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('No Build Scan detected')    |  | ||||||
|  |  | ||||||
|   build-scan-publish: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         gradle: [current, 7.6.2, 6.9.4, 5.6.4] |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: temurin |  | ||||||
|         java-version: 8 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       id: setup-gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         gradle-version: ${{ matrix.gradle }} |  | ||||||
|         build-scan-publish: true |  | ||||||
|         build-scan-terms-of-service-url: "https://gradle.com/terms-of-service" |  | ||||||
|         build-scan-terms-of-service-agree: "yes" |  | ||||||
|     - name: Run Gradle build |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/no-ge |  | ||||||
|       run: gradle help |  | ||||||
|     - name: Check Build Scan url |  | ||||||
|       if: ${{ !steps.gradle.outputs.build-scan-url }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('No Build Scan detected')    |  | ||||||
|  |  | ||||||
| @@ -1,108 +0,0 @@ | |||||||
| name: Test provision Gradle versions |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: provision-gradle-versions-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs:    |  | ||||||
|   # Tests for executing with different Gradle versions.  |  | ||||||
|   # Each build verifies that it is executed with the expected Gradle version. |  | ||||||
|   provision-gradle: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|         include: |  | ||||||
|           - os: windows-latest |  | ||||||
|             script-suffix: '.bat' |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle with v6.9 |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         gradle-version: 6.9 |  | ||||||
|     - name: Test uses Gradle v6.9 |  | ||||||
|       working-directory: .github/workflow-samples/no-wrapper |  | ||||||
|       run: gradle help "-DgradleVersionCheck=6.9" |  | ||||||
|     - name: Setup Gradle with v7.1.1 |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         gradle-version: 7.1.1 |  | ||||||
|     - name: Test uses Gradle v7.1.1 |  | ||||||
|       working-directory: .github/workflow-samples/no-wrapper |  | ||||||
|       run: gradle help "-DgradleVersionCheck=7.1.1" |  | ||||||
|     - name: Setup Gradle with release-candidate |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         gradle-version: release-candidate |  | ||||||
|     - name: Test use release-candidate |  | ||||||
|       working-directory: .github/workflow-samples/no-wrapper |  | ||||||
|       run: gradle help |  | ||||||
|     - name: Setup Gradle with current |  | ||||||
|       id: gradle-current |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         gradle-version: current |  | ||||||
|     - name: Check current version output parameter |  | ||||||
|       if: ${{ !startsWith(steps.gradle-current.outputs.gradle-version , '8.') }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('Gradle version parameter not set correctly: value was "${{ steps.gradle-current.outputs.gradle-version }}"')     |  | ||||||
|    |  | ||||||
|   gradle-versions: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         gradle: [7.3, 6.9, 5.6.4, 4.10.3, 3.5.1] |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|         include: |  | ||||||
|           - gradle: 5.6.4 |  | ||||||
|             build-root-suffix: -gradle-5 |  | ||||||
|           - gradle: 4.10.3 |  | ||||||
|             build-root-suffix: -gradle-4 |  | ||||||
|           - gradle: 3.5.1 |  | ||||||
|             build-root-suffix: -gradle-4 |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: temurin |  | ||||||
|         java-version: 8 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       id: setup-gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         gradle-version: ${{ matrix.gradle }} |  | ||||||
|     - name: Check output parameter |  | ||||||
|       if: ${{ steps.setup-gradle.outputs.gradle-version != matrix.gradle }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('Gradle version parameter not set correctly: value was "${{ steps.setup-gradle.outputs.gradle-version }}"')     |  | ||||||
|     - name: Run Gradle build |  | ||||||
|       id: gradle |  | ||||||
|       working-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} |  | ||||||
|       run: gradle help "-DgradleVersionCheck=${{matrix.gradle}}" |  | ||||||
|     - name: Check Build Scan url |  | ||||||
|       if: ${{ !steps.gradle.outputs.build-scan-url }} |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           core.setFailed('No Build Scan detected')     |  | ||||||
|    |  | ||||||
|     |  | ||||||
| @@ -1,195 +0,0 @@ | |||||||
| name: Test restore configuration-cache |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|     secrets: |  | ||||||
|       GRADLE_ENCRYPTION_KEY: |  | ||||||
|         required: true |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-configuration-cache-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build-groovy: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-groovy |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java to ensure consistency |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'liberica' |  | ||||||
|         java-version: '21' |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|         gradle-version: 8.6-rc-1 |  | ||||||
|     - name: Groovy build with configuration-cache enabled |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: gradle test --configuration-cache |  | ||||||
|  |  | ||||||
|   verify-build-groovy: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-groovy |  | ||||||
|     needs: seed-build-groovy |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java to ensure consistency |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'liberica' |  | ||||||
|         java-version: '21' |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|         cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|         gradle-version: 8.6-rc-1 |  | ||||||
|     - name: Groovy build with configuration-cache enabled |  | ||||||
|       id: execute |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: gradle test --configuration-cache |  | ||||||
|     - name: Check that configuration-cache was used |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           const fs = require('fs') |  | ||||||
|           if (fs.existsSync('.github/workflow-samples/groovy-dsl/task-configured.txt')) { |  | ||||||
|             core.setFailed('Configuration cache was not used - task was configured unexpectedly') |  | ||||||
|           } |  | ||||||
|  |  | ||||||
|   # Check that the build can run when no extracted cache entries are restored |  | ||||||
|   gradle-user-home-not-fully-restored: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-groovy |  | ||||||
|     needs: seed-build-groovy |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java to ensure consistency |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'liberica' |  | ||||||
|         java-version: '21' |  | ||||||
|     - name: Setup Gradle with no extracted cache entries restored |  | ||||||
|       uses: ./ |  | ||||||
|       env:  |  | ||||||
|         GRADLE_BUILD_ACTION_SKIP_RESTORE: "generated-gradle-jars|wrapper-zips|java-toolchains|instrumented-jars|dependencies|kotlin-dsl" |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|         cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|         gradle-version: 8.6-rc-1 |  | ||||||
|     - name: Check execute Gradle build with configuration cache enabled (but not restored) |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: gradle test --configuration-cache |  | ||||||
|  |  | ||||||
|   seed-build-kotlin: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-kotlin |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java to ensure consistency |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'liberica' |  | ||||||
|         java-version: '21' |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|         gradle-version: 8.6-rc-1 |  | ||||||
|     - name: Execute 'help' with configuration-cache enabled |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: gradle help --configuration-cache |  | ||||||
|  |  | ||||||
|   modify-build-kotlin: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-kotlin-modified |  | ||||||
|     needs: seed-build-kotlin |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java to ensure consistency |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'liberica' |  | ||||||
|         java-version: '21' |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|         cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|         gradle-version: 8.6-rc-1 |  | ||||||
|     - name: Execute 'test' with configuration-cache enabled |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: gradle test --configuration-cache |  | ||||||
|  |  | ||||||
|   # Test restore configuration-cache from the third build invocation |  | ||||||
|   verify-build-kotlin: |  | ||||||
|     env: |  | ||||||
|       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-kotlin-modified |  | ||||||
|     needs: modify-build-kotlin |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java to ensure consistency |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         distribution: 'liberica' |  | ||||||
|         java-version: '21' |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|         cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} |  | ||||||
|         gradle-version: 8.6-rc-1 |  | ||||||
|     - name: Execute 'test' again with configuration-cache enabled |  | ||||||
|       id: execute |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: gradle test --configuration-cache |  | ||||||
|     - name: Check that configuration-cache was used |  | ||||||
|       uses: actions/github-script@v7 |  | ||||||
|       with: |  | ||||||
|         script: | |  | ||||||
|           const fs = require('fs') |  | ||||||
|           if (fs.existsSync('.github/workflow-samples/kotlin-dsl/task-configured.txt')) { |  | ||||||
|             core.setFailed('Configuration cache was not used - task was configured unexpectedly') |  | ||||||
|           } |  | ||||||
|  |  | ||||||
| @@ -1,52 +0,0 @@ | |||||||
| name: Test restore custom Gradle Home |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-custom-gradle-home-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     container: fedora:latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         java-version: 11 |  | ||||||
|         distribution: temurin |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|     - name: Build using Gradle wrapper |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline |  | ||||||
|   dependencies-cache: |  | ||||||
|     needs: seed-build |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     container: fedora:latest |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Java |  | ||||||
|       uses: actions/setup-java@v4 |  | ||||||
|       with: |  | ||||||
|         java-version: 11 |  | ||||||
|         distribution: temurin |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build with --offline |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test --offline |  | ||||||
| @@ -1,67 +0,0 @@ | |||||||
| name: Test restore custom Gradle Home |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-custom-gradle-home-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Set Gradle User Home |  | ||||||
|       run: | |  | ||||||
|         mkdir -p $GITHUB_WORKSPACE/gradle-user-home |  | ||||||
|         echo "GRADLE_USER_HOME=$GITHUB_WORKSPACE/gradle-user-home" >> $GITHUB_ENV |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|     - name: Build using Gradle wrapper |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test --info |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline |  | ||||||
|   dependencies-cache: |  | ||||||
|     needs: seed-build |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Set Gradle User Home |  | ||||||
|       run: | |  | ||||||
|         mkdir -p $GITHUB_WORKSPACE/gradle-user-home |  | ||||||
|         echo "GRADLE_USER_HOME=$GITHUB_WORKSPACE/gradle-user-home" >> $GITHUB_ENV |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build with --offline |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test --offline --info |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home cache will cache and restore local build-cache |  | ||||||
|   build-cache: |  | ||||||
|     needs: seed-build |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - name: Set Gradle User Home |  | ||||||
|       run: | |  | ||||||
|         mkdir -p $GITHUB_WORKSPACE/gradle-user-home |  | ||||||
|         echo "GRADLE_USER_HOME=$GITHUB_WORKSPACE/gradle-user-home" >> $GITHUB_ENV |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build and verify tasks from cache |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test -DverifyCachedBuild=true --info |  | ||||||
							
								
								
									
										124
									
								
								.github/workflows/integ-test-restore-gradle-home.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										124
									
								
								.github/workflows/integ-test-restore-gradle-home.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,124 +0,0 @@ | |||||||
| name: Test restore Gradle Home |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-gradle-home-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-gradle-home |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|     - name: Build using Gradle wrapper |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline |  | ||||||
|   dependencies-cache: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build with --offline |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test --offline |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home cache will cache and restore local build-cache |  | ||||||
|   build-cache: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build and verify tasks from cache |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test -DverifyCachedBuild=true |  | ||||||
|  |  | ||||||
|   # Check that the build can run when Gradle User Home is not fully restored |  | ||||||
|   no-extracted-cache-entries-restored: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle with no extracted cache entries restored |  | ||||||
|       uses: ./ |  | ||||||
|       env:  |  | ||||||
|         GRADLE_BUILD_ACTION_SKIP_RESTORE: "generated-gradle-jars|wrapper-zips|java-toolchains|instrumented-jars|dependencies|kotlin-dsl" |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Check executee Gradle build |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test |  | ||||||
|  |  | ||||||
|   # Test that a pre-existing gradle-user-home can be overwritten by the restored cache |  | ||||||
|   pre-existing-gradle-home: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Pre-create Gradle User Home |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         mkdir -p ~/.gradle/caches |  | ||||||
|         touch ~/.gradle/gradle.properties |  | ||||||
|         touch ~/.gradle/caches/dummy.txt |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|         cache-overwrite-existing: true |  | ||||||
|     - name: Check that pre-existing content still exists |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         if [ ! -e ~/.gradle/caches/dummy.txt ]; then |  | ||||||
|           echo "::error ::Should find dummy.txt after cache restore" |  | ||||||
|           exit 1 |  | ||||||
|         fi |  | ||||||
|         if [ ! -e ~/.gradle/gradle.properties ]; then |  | ||||||
|           echo "::error ::Should find gradle.properties after cache restore" |  | ||||||
|           exit 1 |  | ||||||
|         fi |  | ||||||
|     - name: Execute Gradle build with --offline |  | ||||||
|       working-directory: .github/workflow-samples/groovy-dsl |  | ||||||
|       run: ./gradlew test --offline |  | ||||||
| @@ -1,49 +0,0 @@ | |||||||
| name: Test restore java toolchains |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-java-toolchain-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|     - name: Build using Gradle wrapper |  | ||||||
|       working-directory: .github/workflow-samples/java-toolchain |  | ||||||
|       run: ./gradlew test --info |  | ||||||
|  |  | ||||||
|   # Test that the gradle-user-home cache will cache the toolchain, by running build with --offline |  | ||||||
|   toolchain-cache: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Execute Gradle build with --offline |  | ||||||
|       working-directory: .github/workflow-samples/java-toolchain |  | ||||||
|       run: ./gradlew test --info --offline |  | ||||||
| @@ -1,48 +0,0 @@ | |||||||
| name: Test sample Gradle Plugin project |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: sample-gradle-plugin-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|     - name: Build gradle-plugin project |  | ||||||
|       working-directory: .github/workflow-samples/gradle-plugin |  | ||||||
|       run: ./gradlew build |  | ||||||
|  |  | ||||||
|   verify-build: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Build gradle-plugin project |  | ||||||
|       working-directory: .github/workflow-samples/gradle-plugin |  | ||||||
|       run: ./gradlew build --offline |  | ||||||
| @@ -1,48 +0,0 @@ | |||||||
| name: Test sample Kotlin DSL project |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_call: |  | ||||||
|     inputs: |  | ||||||
|       cache-key-prefix: |  | ||||||
|         type: string |  | ||||||
|       runner-os: |  | ||||||
|         type: string |  | ||||||
|         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' |  | ||||||
|  |  | ||||||
| env: |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: sample-kotlin-dsl-${{ inputs.cache-key-prefix }} |  | ||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   seed-build: |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: false # For testing, allow writing cache entries on non-default branches |  | ||||||
|     - name: Build kotlin-dsl project |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew build |  | ||||||
|  |  | ||||||
|   verify-build: |  | ||||||
|     needs: seed-build |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: ${{fromJSON(inputs.runner-os)}} |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     steps: |  | ||||||
|     - name: Checkout sources |  | ||||||
|       uses: actions/checkout@v4 |  | ||||||
|     - name: Setup Gradle |  | ||||||
|       uses: ./ |  | ||||||
|       with: |  | ||||||
|         cache-read-only: true |  | ||||||
|     - name: Build kotlin-dsl project |  | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |  | ||||||
|       run: ./gradlew build --offline |  | ||||||
							
								
								
									
										22
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,10 @@ | |||||||
| # Dependency directory | __tests__/runner/* | ||||||
| node_modules | !lib/ | ||||||
|  | !node_modules | ||||||
|  |  | ||||||
|  | .idea | ||||||
|  | *.iml | ||||||
|  | __tests__/runner/* | ||||||
|  |  | ||||||
| # Rest pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | # Rest pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | ||||||
| # Logs | # Logs | ||||||
| @@ -89,16 +94,3 @@ typings/ | |||||||
|  |  | ||||||
| # DynamoDB Local files | # DynamoDB Local files | ||||||
| .dynamodb/ | .dynamodb/ | ||||||
|  |  | ||||||
| # OS metadata |  | ||||||
| .DS_Store |  | ||||||
| Thumbs.db |  | ||||||
|  |  | ||||||
| # Ignore built ts files |  | ||||||
| __tests__/runner/* |  | ||||||
| # lib/**/* |  | ||||||
|  |  | ||||||
| # IntelliJ IDEA config files |  | ||||||
| .idea/ |  | ||||||
| *.iml |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
|  |  | ||||||
| The MIT License (MIT) | The MIT License (MIT) | ||||||
|  |  | ||||||
| Copyright (c) 2023 Gradle Inc. | Copyright (c) 2018 GitHub, Inc. and contributors | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
| of this software and associated documentation files (the "Software"), to deal | of this software and associated documentation files (the "Software"), to deal | ||||||
|   | |||||||
							
								
								
									
										177
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										177
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,43 +1,154 @@ | |||||||
| > [!IMPORTANT] | # Execute Gradle commands in Github Actions workflows | ||||||
| > As of `v3` this action has been superceded by `gradle/actions/setup-gradle`. |  | ||||||
| > Any workflow that uses `gradle/gradle-build-action@v3` will transparently delegate to `gradle/actions/setup-gradle@v3`. |  | ||||||
| > |  | ||||||
| > Users are encouraged to update their workflows, replacing: |  | ||||||
| > ``` |  | ||||||
| > uses: gradle/gradle-build-action@v3 |  | ||||||
| > ``` |  | ||||||
| > |  | ||||||
| > with |  | ||||||
| > ``` |  | ||||||
| > uses: gradle/actions/setup-gradle@v3 |  | ||||||
| > ``` |  | ||||||
| > |  | ||||||
| > See the [setup-gradle documentation](https://github.com/gradle/actions/tree/main/setup-gradle) for up-to-date documentation for `gradle/actions/setup-gradle`.  |  | ||||||
|  |  | ||||||
| # Execute Gradle builds in GitHub Actions workflows | This Github Action can be used to run arbitrary Gradle commands on any platform supported by Github Actions. | ||||||
|  |  | ||||||
|  | You might also be interested by the related [Gradle Plugin](https://github.com/eskatos/gradle-github-actions-plugin) that allows your build to easily get Github Actions environment and tag Gradle Build Scans accordingly. | ||||||
|  |  | ||||||
|  | ## Usage | ||||||
|  |  | ||||||
|  | The following workflow will run `gradle build` using the wrapper from the repository on ubuntu, macos and windows. The only prerequisite is to have Java installed, you can define the version you need to run the build using the `actions/setup-java` action. | ||||||
|  |  | ||||||
| This GitHub Action can be used to configure Gradle and optionally execute a Gradle build on any platform supported by GitHub Actions. |  | ||||||
|  |  | ||||||
| ## Example usage |  | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| name: Build | # .github/workflows/gradle-build-pr.yml | ||||||
|  | name: Run Gradle on PRs | ||||||
| on: [ push ] | on: pull-request | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   build: |   gradle: | ||||||
|     runs-on: ubuntu-latest |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: [ubuntu-latest, macos-latest, windows-latest] | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout sources |     - uses: actions/checkout@v1 | ||||||
|       uses: actions/checkout@v4 |     - uses: actions/setup-java@v1 | ||||||
|     - name: Setup Gradle |       with: | ||||||
|       uses: gradle/gradle-build-action@v3 |         java-version: 11 | ||||||
|     - name: Build with Gradle |     - uses: eskatos/gradle-command-action@v1 | ||||||
|       run: ./gradlew build |       with: | ||||||
|  |         arguments: build | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| As of `v3`, the `gradle/gradle-build-action` action delegates to `gradle/actions/setup-gradle` with the same version. | ## Gradle arguments | ||||||
| Configuration and usage of these actions is identical for releases with the same version number. |  | ||||||
|  |  | ||||||
| See the [full setup-gradle documentation](https://github.com/gradle/actions/tree/main/setup-gradle) for more advanced usage scenarios.  | The `arguments` input can used to pass arbitrary arguments to the `gradle` command line. | ||||||
|  |  | ||||||
|  | Here are some valid examples: | ||||||
|  | ```yaml | ||||||
|  | arguments: build | ||||||
|  | arguments: check --scan | ||||||
|  | arguments: some arbitrary tasks | ||||||
|  | arguments: build -PgradleProperty=foo | ||||||
|  | arguments: build -DsystemProperty=bar | ||||||
|  | .... | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | See `gradle --help` for more information. | ||||||
|  |  | ||||||
|  | If you need to pass environment variables, simply use the Github Actions workflow syntax: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | - uses: eskatos/gradle-command-action@v1 | ||||||
|  |   env: | ||||||
|  |     CI: true | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Run a build from a different directory | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | - uses: eskatos/gradle-command-action@v1 | ||||||
|  |   with: | ||||||
|  |     build-root-directory: some/subdirectory | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Use a Gradle wrapper from a different directory | ||||||
|  |   | ||||||
|  | ```yaml | ||||||
|  |  - uses: eskatos/gradle-command-action@v1 | ||||||
|  |    with: | ||||||
|  |      wrapper-directory: path/to/wrapper-directory | ||||||
|  |  ``` | ||||||
|  |  | ||||||
|  | ## Use a specific `gradle` executable | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  |  - uses: eskatos/gradle-command-action@v1 | ||||||
|  |    with: | ||||||
|  |      gradle-executable: path/to/gradle | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Setup and use a declared Gradle version | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  |  - uses: eskatos/gradle-command-action@v1 | ||||||
|  |    with: | ||||||
|  |      gradle-version: 5.6.2 | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | `gradle-version` can be set to any valid Gradle version. | ||||||
|  |  | ||||||
|  | Moreover, you can use the following aliases: | ||||||
|  |  | ||||||
|  | | Alias | Selects | | ||||||
|  | | --- |---| | ||||||
|  | | `wrapper`      | The Gradle wrapper's version (default, useful for matrix builds) | | ||||||
|  | | `current`      | The current [stable release](https://gradle.org/install/) | | ||||||
|  | | `rc`      | The current [release candidate](https://gradle.org/release-candidate/) if any, otherwise fallback to `current` | | ||||||
|  | | `nightly` | The latest [nightly](https://gradle.org/nightly/), fails if none. | | ||||||
|  | | `release-nightly` | The latest [release nightly](https://gradle.org/release-nightly/), fails if none.      | | ||||||
|  |  | ||||||
|  | This can be handy to, for example, automatically test your build with the next Gradle version once a release candidate is out: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | # .github/workflows/test-gradle-rc.yml | ||||||
|  | name: Test latest Gradle RC | ||||||
|  | on: | ||||||
|  |   schedule: | ||||||
|  |     - cron: 0 0 * * * # daily | ||||||
|  | jobs: | ||||||
|  |   gradle-rc: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - uses: actions/checkout@v1 | ||||||
|  |     - uses: actions/setup-java@v1 | ||||||
|  |       with: | ||||||
|  |         java-version: 11 | ||||||
|  |     - uses: eskatos/gradle-command-action@v1 | ||||||
|  |       with: | ||||||
|  |         gradle-version: rc | ||||||
|  |         arguments: build --dry-run # just test build configuration | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | # Build scans | ||||||
|  |  | ||||||
|  | If your build publishes a [build scan](https://gradle.com/build-scans/) the `gradle-command-action` action will emit the link to the published build scan as an output named `build-scan-url`. | ||||||
|  |  | ||||||
|  | You can then use that link in subsequent actions of your workflow. | ||||||
|  |  | ||||||
|  | For example: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | # .github/workflows/gradle-build-pr.yml | ||||||
|  | name: Run Gradle on PRs | ||||||
|  | on: pull-request | ||||||
|  | jobs: | ||||||
|  |   gradle: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: [ubuntu-latest, macos-latest, windows-latest] | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - uses: actions/checkout@v1 | ||||||
|  |     - uses: actions/setup-java@v1 | ||||||
|  |       with: | ||||||
|  |         java-version: 11 | ||||||
|  |     - uses: eskatos/gradle-command-action@v1 | ||||||
|  |       with: | ||||||
|  |         arguments: build | ||||||
|  |       id: gradle | ||||||
|  |     - uses: example/action-that-comments-on-the-pr@v0 | ||||||
|  |       if: failure() | ||||||
|  |       with: | ||||||
|  |         comment: Build failed ${{ steps.gradle.outputs.build-scan-url }} | ||||||
|  | ``` | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								__tests__/main.test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								__tests__/main.test.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | describe('TODO - Add a test suite', () => { | ||||||
|  |   it('TODO - Add a test', async () => {}); | ||||||
|  | }); | ||||||
							
								
								
									
										210
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										210
									
								
								action.yml
									
									
									
									
									
								
							| @@ -1,207 +1,33 @@ | |||||||
| name: "Gradle Build Action" | name: "Gradle Command" | ||||||
| description: 'Configures Gradle for GitHub actions, caching state and generating a dependency graph via Dependency Submission.' | description: 'Execute Gradle Command Line' | ||||||
|  | author: 'Paul Merlin <paul@nospere.org>' | ||||||
|  |  | ||||||
|  | # https://help.github.com/en/articles/metadata-syntax-for-github-actions | ||||||
|  |  | ||||||
| inputs: | inputs: | ||||||
|  |   wrapper-directory: | ||||||
|  |     description: Path to the Gradle Wrapper directory | ||||||
|  |     required: false | ||||||
|  |   gradle-executable: | ||||||
|  |     description: Path to the Gradle executable | ||||||
|  |     required: false | ||||||
|   gradle-version: |   gradle-version: | ||||||
|     description: | |     description: Gradle version to use | ||||||
|       Gradle version to use. If specified, this Gradle version will be downloaded, added to the PATH and used for invoking Gradle. |  | ||||||
|       If not provided, it is assumed that the project uses the Gradle Wrapper. |  | ||||||
|     required: false |     required: false | ||||||
|  |  | ||||||
|   # Cache configuration |  | ||||||
|   cache-disabled: |  | ||||||
|     description: When 'true', all caching is disabled. No entries will be written to or read from the cache. |  | ||||||
|     required: false |  | ||||||
|     default: false |  | ||||||
|  |  | ||||||
|   cache-read-only: |  | ||||||
|     description: | |  | ||||||
|       When 'true', existing entries will be read from the cache but no entries will be written. |  | ||||||
|       By default this value is 'false' for workflows on the GitHub default branch and 'true' for workflows on other branches. |  | ||||||
|     required: false |  | ||||||
|     default: ${{ github.event.repository != null && github.ref_name != github.event.repository.default_branch }} |  | ||||||
|  |  | ||||||
|   cache-write-only: |  | ||||||
|     description: | |  | ||||||
|       When 'true', entries will not be restored from the cache but will be saved at the end of the Job.  |  | ||||||
|       Setting this to 'true' implies cache-read-only will be 'false'. |  | ||||||
|     required: false |  | ||||||
|     default: false |  | ||||||
|  |  | ||||||
|   cache-overwrite-existing: |  | ||||||
|     description: When 'true', a pre-existing Gradle User Home will not prevent the cache from being restored. |  | ||||||
|     required: false |  | ||||||
|     default: false |  | ||||||
|  |  | ||||||
|   cache-encryption-key: |  | ||||||
|     description: | |  | ||||||
|       A base64 encoded AES key used to encrypt the configuration-cache data. The key is exported as 'GRADLE_ENCRYPTION_KEY' for later steps.  |  | ||||||
|       A suitable key can be generated with `openssl rand -base64 16`. |  | ||||||
|       Configuration-cache data will not be saved/restored without an encryption key being provided. |  | ||||||
|     required: false |  | ||||||
|  |  | ||||||
|   gradle-home-cache-includes: |  | ||||||
|     description: Paths within Gradle User Home to cache. |  | ||||||
|     required: false |  | ||||||
|     default: | |  | ||||||
|         caches |  | ||||||
|         notifications |  | ||||||
|  |  | ||||||
|   gradle-home-cache-excludes: |  | ||||||
|     description: Paths within Gradle User Home to exclude from cache. |  | ||||||
|     required: false |  | ||||||
|  |  | ||||||
|   gradle-home-cache-cleanup: |  | ||||||
|     description: When 'true', the action will attempt to remove any stale/unused entries from the Gradle User Home prior to saving to the GitHub Actions cache. |  | ||||||
|     required: false |  | ||||||
|     default: false |  | ||||||
|  |  | ||||||
|   # Job summary configuration |  | ||||||
|   add-job-summary: |  | ||||||
|     description: Specifies when a Job Summary should be inluded in the action results. Valid values are 'never', 'always' (default), and 'on-failure'. |  | ||||||
|     required: false |  | ||||||
|     default: 'always' |  | ||||||
|  |  | ||||||
|   add-job-summary-as-pr-comment: |  | ||||||
|     description: Specifies when each Job Summary should be added as a PR comment. Valid values are 'never' (default), 'always', and 'on-failure'. No action will be taken if the workflow was not triggered from a pull request. |  | ||||||
|     required: false |  | ||||||
|     default: 'never' |  | ||||||
|  |  | ||||||
|   # Dependency Graph configuration |  | ||||||
|   dependency-graph: |  | ||||||
|     description: | |  | ||||||
|       Specifies if a GitHub dependency snapshot should be generated for each Gradle build, and if so, how.  |  | ||||||
|       Valid values are 'disabled' (default), 'generate', 'generate-and-submit', 'generate-and-upload', 'download-and-submit' and 'clear'. |  | ||||||
|     required: false |  | ||||||
|     default: 'disabled' |  | ||||||
|  |  | ||||||
|   dependency-graph-continue-on-failure: |  | ||||||
|     description: When 'false' a failure to generate or submit a dependency graph will fail the Step or Job. When 'true' a warning will be emitted but no failure will result. |  | ||||||
|     required: false |  | ||||||
|     default: true |  | ||||||
|  |  | ||||||
|   artifact-retention-days: |  | ||||||
|     description: Specifies the number of days to retain any artifacts generated by the action. If not set, the default retention settings for the repository will apply. |  | ||||||
|     required: false |  | ||||||
|  |  | ||||||
|   # Build Scan configuration |  | ||||||
|   build-scan-publish: |  | ||||||
|     description: | |  | ||||||
|       Set to 'true' to automatically publish build results as a Build Scan on scans.gradle.com. |  | ||||||
|       For publication to succeed without user input, you must also provide values for `build-scan-terms-of-use-url` and 'build-scan-terms-of-use-agree'. |  | ||||||
|     required: false |  | ||||||
|     default: false |  | ||||||
|  |  | ||||||
|   build-scan-terms-of-use-url: |  | ||||||
|     description: The URL to the Build Scan® terms of use. This input must be set to 'https://gradle.com/terms-of-service' or 'https://gradle.com/help/legal-terms-of-use'. |  | ||||||
|     required: false |  | ||||||
|    |  | ||||||
|   build-scan-terms-of-use-agree: |  | ||||||
|     description: Indicate that you agree to the Build Scan® terms of use. This input value must be "yes". |  | ||||||
|     required: false |  | ||||||
|  |  | ||||||
|   # Wrapper validation configuration |  | ||||||
|   validate-wrappers: |  | ||||||
|     description: | |  | ||||||
|       When 'true', the action will perform the 'wrapper-validation' action automatically. |  | ||||||
|       If the wrapper checksums are not valid, the action will fail. |  | ||||||
|     required: false |  | ||||||
|     default: false |  | ||||||
|  |  | ||||||
|   # DEPRECATED ACTION INPUTS |  | ||||||
|   build-scan-terms-of-service-url: |  | ||||||
|     description: The URL to the Build Scan® terms of use. This input must be set to 'https://gradle.com/terms-of-service'. |  | ||||||
|     required: false |  | ||||||
|     deprecation-message: The input has been renamed to align with the Develocity API. Use 'build-scan-terms-of-use-url' instead. |  | ||||||
|  |  | ||||||
|   build-scan-terms-of-service-agree: |  | ||||||
|     description: Indicate that you agree to the Build Scan® terms of use. This input value must be "yes". |  | ||||||
|     required: false |  | ||||||
|     deprecation-message: The input has been renamed to align with the Develocity API. Use 'build-scan-terms-of-use-agree' instead. |  | ||||||
|  |  | ||||||
|   generate-job-summary: |  | ||||||
|     description: When 'false', no Job Summary will be generated for the Job. |  | ||||||
|     required: false |  | ||||||
|     default: true |  | ||||||
|     deprecation-message: Superceded by the new 'add-job-summary' and 'add-job-summary-as-pr-comment' parameters. |  | ||||||
|  |  | ||||||
|   arguments: |  | ||||||
|     description: Gradle command line arguments (supports multi-line input) |  | ||||||
|     required: false |  | ||||||
|     deprecation-message: Using the action to execute Gradle directly is deprecated in favor of using the action to setup Gradle, and executing Gradle in a subsequent Step. |  | ||||||
|  |  | ||||||
|   build-root-directory: |   build-root-directory: | ||||||
|     description: Path to the root directory of the build. Default is the root of the GitHub workspace. |     description: Path to the root directory of the build | ||||||
|     required: false |     required: false | ||||||
|     deprecation-message: Using the action to execute Gradle directly is deprecated in favor of using the action to setup Gradle, and executing Gradle in a subsequent Step. |   arguments: | ||||||
|  |     description: Gradle command line arguments, see gradle --help | ||||||
|   # EXPERIMENTAL ACTION INPUTS |  | ||||||
|   # The following action properties allow fine-grained tweaking of the action caching behaviour. |  | ||||||
|   # These properties are experimental and not (yet) designed for production use, and may change without notice in a subsequent release of `setup-gradle`. |  | ||||||
|   # Use at your own risk! |  | ||||||
|   gradle-home-cache-strict-match: |  | ||||||
|     description: When 'true', the action will not attempt to restore the Gradle User Home entries from other Jobs. |  | ||||||
|     required: false |  | ||||||
|     default: false |  | ||||||
|      |  | ||||||
|   # INTERNAL ACTION INPUTS |  | ||||||
|   # These inputs should not be configured directly, and are only used to pass environmental information to the action |  | ||||||
|   workflow-job-context: |  | ||||||
|     description: Used to uniquely identify the current job invocation. Defaults to the matrix values for this job; this should not be overridden by users (INTERNAL). |  | ||||||
|     required: false |  | ||||||
|     default: ${{ toJSON(matrix) }} |  | ||||||
|  |  | ||||||
|   github-token: |  | ||||||
|     description: The GitHub token used to authenticate when submitting via the Dependency Submission API. |  | ||||||
|     default: ${{ github.token }} |  | ||||||
|     required: false |     required: false | ||||||
|  |  | ||||||
| outputs: | outputs: | ||||||
|   build-scan-url: |   build-scan-url: | ||||||
|     description: Link to the Build Scan® generated by a Gradle build. Note that this output applies to a Step executing Gradle, not to the `setup-gradle` Step itself. |     description: Link to the build scan if any | ||||||
|     value: ${{ steps.setup-gradle.outputs.build-scan-url }} |  | ||||||
|   dependency-graph-file: |  | ||||||
|     description: Path to the GitHub Dependency Graph snapshot file generated by a Gradle build. Note that this output applies to a Step executing Gradle, not to the `setup-gradle` Step itself. |  | ||||||
|     value: ${{ steps.setup-gradle.outputs.dependency-graph-file }} |  | ||||||
|   gradle-version: |  | ||||||
|     description: Version of Gradle that was setup by the action |  | ||||||
|     value: ${{ steps.setup-gradle.outputs.gradle-version }} |  | ||||||
|  |  | ||||||
| runs: | runs: | ||||||
|   using: "composite" |   using: 'node12' | ||||||
|   steps: |   main: 'lib/main.js' | ||||||
|     - name: Setup Gradle |  | ||||||
|       id: setup-gradle |  | ||||||
|       uses: gradle/actions/setup-gradle@v3.3.2 |  | ||||||
|       with: |  | ||||||
|         gradle-version: ${{ inputs.gradle-version }} |  | ||||||
|         cache-disabled: ${{ inputs.cache-disabled }} |  | ||||||
|         cache-read-only: ${{ inputs.cache-read-only }} |  | ||||||
|         cache-write-only: ${{ inputs.cache-write-only }} |  | ||||||
|         cache-overwrite-existing: ${{ inputs.cache-overwrite-existing }} |  | ||||||
|         cache-encryption-key: ${{ inputs.cache-encryption-key }} |  | ||||||
|         gradle-home-cache-includes: ${{ inputs.gradle-home-cache-includes }} |  | ||||||
|         gradle-home-cache-excludes: ${{ inputs.gradle-home-cache-excludes }} |  | ||||||
|         gradle-home-cache-cleanup: ${{ inputs.gradle-home-cache-cleanup }} |  | ||||||
|         add-job-summary: ${{ inputs.add-job-summary }} |  | ||||||
|         add-job-summary-as-pr-comment: ${{ inputs.add-job-summary-as-pr-comment }} |  | ||||||
|         dependency-graph: ${{ inputs.dependency-graph }} |  | ||||||
|         dependency-graph-continue-on-failure: ${{ inputs.dependency-graph-continue-on-failure }} |  | ||||||
|         artifact-retention-days: ${{ inputs.artifact-retention-days }} |  | ||||||
|         build-scan-publish: ${{ inputs.build-scan-publish }} |  | ||||||
|         build-scan-terms-of-use-url: ${{ inputs.build-scan-terms-of-use-url }} |  | ||||||
|         build-scan-terms-of-use-agree: ${{ inputs.build-scan-terms-of-use-agree }} |  | ||||||
|         validate-wrappers: ${{ inputs.validate-wrappers }} |  | ||||||
|         build-scan-terms-of-service-url: ${{ inputs.build-scan-terms-of-service-url }} |  | ||||||
|         build-scan-terms-of-service-agree: ${{ inputs.build-scan-terms-of-service-agree }} |  | ||||||
|         generate-job-summary: ${{ inputs.generate-job-summary }} |  | ||||||
|         arguments: ${{ inputs.arguments }} |  | ||||||
|         build-root-directory: ${{ inputs.build-root-directory }} |  | ||||||
|         gradle-home-cache-strict-match: ${{ inputs.gradle-home-cache-strict-match }} |  | ||||||
|         workflow-job-context: ${{ inputs.workflow-job-context }} |  | ||||||
|         github-token: ${{ inputs.github-token }} |  | ||||||
|       env: |  | ||||||
|         GRADLE_ACTION_ID: gradle/gradle-build-action |  | ||||||
|  |  | ||||||
| branding: | branding: | ||||||
|   icon: 'box' |   icon: 'box' | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								jest.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								jest.config.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | module.exports = { | ||||||
|  |   clearMocks: true, | ||||||
|  |   moduleFileExtensions: ['js', 'ts'], | ||||||
|  |   testEnvironment: 'node', | ||||||
|  |   testMatch: ['**/*.test.ts'], | ||||||
|  |   testRunner: 'jest-circus/runner', | ||||||
|  |   transform: { | ||||||
|  |     '^.+\\.ts$': 'ts-jest' | ||||||
|  |   }, | ||||||
|  |   verbose: true | ||||||
|  | } | ||||||
							
								
								
									
										51
									
								
								lib/execution.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								lib/execution.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | "use strict"; | ||||||
|  | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|  |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|  |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  |         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||||
|  |         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||||
|  |         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||||
|  |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|  |     if (mod && mod.__esModule) return mod; | ||||||
|  |     var result = {}; | ||||||
|  |     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||||
|  |     result["default"] = mod; | ||||||
|  |     return result; | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const exec = __importStar(require("@actions/exec")); | ||||||
|  | function execute(executable, root, argv) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         let publishing = false; | ||||||
|  |         let buildScanUrl; | ||||||
|  |         const status = yield exec.exec(executable, argv, { | ||||||
|  |             cwd: root, | ||||||
|  |             ignoreReturnCode: true, | ||||||
|  |             listeners: { | ||||||
|  |                 stdline: (line) => { | ||||||
|  |                     if (line.startsWith("Publishing build scan...")) { | ||||||
|  |                         publishing = true; | ||||||
|  |                     } | ||||||
|  |                     if (publishing && line.length == 0) { | ||||||
|  |                         publishing = false; | ||||||
|  |                     } | ||||||
|  |                     if (publishing && line.startsWith("http")) { | ||||||
|  |                         buildScanUrl = line.trim(); | ||||||
|  |                         publishing = false; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |         return new BuildResultImpl(status, buildScanUrl); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | exports.execute = execute; | ||||||
|  | class BuildResultImpl { | ||||||
|  |     constructor(status, buildScanUrl) { | ||||||
|  |         this.status = status; | ||||||
|  |         this.buildScanUrl = buildScanUrl; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										11
									
								
								lib/gradlew.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								lib/gradlew.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | "use strict"; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const IS_WINDOWS = process.platform === "win32"; | ||||||
|  | function wrapperFilename() { | ||||||
|  |     return IS_WINDOWS ? "gradlew.bat" : "gradlew"; | ||||||
|  | } | ||||||
|  | exports.wrapperFilename = wrapperFilename; | ||||||
|  | function installScriptFilename() { | ||||||
|  |     return IS_WINDOWS ? "gradle.bat" : "gradle"; | ||||||
|  | } | ||||||
|  | exports.installScriptFilename = installScriptFilename; | ||||||
							
								
								
									
										77
									
								
								lib/main.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								lib/main.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | |||||||
|  | "use strict"; | ||||||
|  | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|  |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|  |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  |         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||||
|  |         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||||
|  |         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||||
|  |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|  |     if (mod && mod.__esModule) return mod; | ||||||
|  |     var result = {}; | ||||||
|  |     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||||
|  |     result["default"] = mod; | ||||||
|  |     return result; | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const core = __importStar(require("@actions/core")); | ||||||
|  | const path = __importStar(require("path")); | ||||||
|  | const string_argv_1 = require("string-argv"); | ||||||
|  | const execution = __importStar(require("./execution")); | ||||||
|  | const gradlew = __importStar(require("./gradlew")); | ||||||
|  | const provision = __importStar(require("./provision")); | ||||||
|  | function run() { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         try { | ||||||
|  |             const baseDirectory = process.env[`GITHUB_WORKSPACE`] || ""; | ||||||
|  |             let result = yield execution.execute(yield resolveGradleExecutable(baseDirectory), resolveBuildRootDirectory(baseDirectory), parseCommandLineArguments()); | ||||||
|  |             if (result.buildScanUrl) { | ||||||
|  |                 core.setOutput("build-scan-url", result.buildScanUrl); | ||||||
|  |             } | ||||||
|  |             if (result.status != 0) { | ||||||
|  |                 core.setFailed(`Gradle process exited with status ${result.status}`); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         catch (error) { | ||||||
|  |             core.setFailed(error.message); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | exports.run = run; | ||||||
|  | run(); | ||||||
|  | function resolveGradleExecutable(baseDirectory) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const gradleVersion = inputOrNull("gradle-version"); | ||||||
|  |         if (gradleVersion != null && gradleVersion != "wrapper") { | ||||||
|  |             return path.resolve(yield provision.gradleVersion(gradleVersion)); | ||||||
|  |         } | ||||||
|  |         const gradleExecutable = inputOrNull("gradle-executable"); | ||||||
|  |         if (gradleExecutable != null) { | ||||||
|  |             return path.resolve(baseDirectory, gradleExecutable); | ||||||
|  |         } | ||||||
|  |         const wrapperDirectory = inputOrNull("wrapper-directory"); | ||||||
|  |         const executableDirectory = wrapperDirectory != null | ||||||
|  |             ? path.join(baseDirectory, wrapperDirectory) | ||||||
|  |             : baseDirectory; | ||||||
|  |         return path.resolve(executableDirectory, gradlew.wrapperFilename()); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function resolveBuildRootDirectory(baseDirectory) { | ||||||
|  |     let buildRootDirectory = inputOrNull("build-root-directory"); | ||||||
|  |     return buildRootDirectory == null | ||||||
|  |         ? path.resolve(baseDirectory) | ||||||
|  |         : path.resolve(baseDirectory, buildRootDirectory); | ||||||
|  | } | ||||||
|  | function parseCommandLineArguments() { | ||||||
|  |     const input = inputOrNull("arguments"); | ||||||
|  |     return input == null ? [] : string_argv_1.parseArgsStringToArgv(input); | ||||||
|  | } | ||||||
|  | function inputOrNull(name) { | ||||||
|  |     const inputString = core.getInput(name); | ||||||
|  |     if (inputString.length == 0) { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |     return inputString; | ||||||
|  | } | ||||||
							
								
								
									
										166
									
								
								lib/provision.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								lib/provision.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,166 @@ | |||||||
|  | "use strict"; | ||||||
|  | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|  |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|  |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  |         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||||
|  |         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||||
|  |         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||||
|  |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|  |     if (mod && mod.__esModule) return mod; | ||||||
|  |     var result = {}; | ||||||
|  |     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||||
|  |     result["default"] = mod; | ||||||
|  |     return result; | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const fs = __importStar(require("fs")); | ||||||
|  | const path = __importStar(require("path")); | ||||||
|  | const httpm = __importStar(require("typed-rest-client/HttpClient")); | ||||||
|  | const unzip = __importStar(require("unzipper")); | ||||||
|  | const core = __importStar(require("@actions/core")); | ||||||
|  | const io = __importStar(require("@actions/io")); | ||||||
|  | const toolCache = __importStar(require("@actions/tool-cache")); | ||||||
|  | const gradlew = __importStar(require("./gradlew")); | ||||||
|  | const httpc = new httpm.HttpClient("eskatos/gradle-command-action"); | ||||||
|  | const gradleVersionsBaseUrl = "https://services.gradle.org/versions"; | ||||||
|  | function gradleVersion(gradleVersion) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         switch (gradleVersion) { | ||||||
|  |             case "current": | ||||||
|  |                 return gradleCurrent(); | ||||||
|  |             case "rc": | ||||||
|  |                 return gradleReleaseCandidate(); | ||||||
|  |             case "nightly": | ||||||
|  |                 return gradleNightly(); | ||||||
|  |             case "release-nightly": | ||||||
|  |                 return gradleReleaseNightly(); | ||||||
|  |             default: | ||||||
|  |                 return gradle(gradleVersion); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | exports.gradleVersion = gradleVersion; | ||||||
|  | function gradleCurrent() { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const json = yield gradleVersionDeclaration(`${gradleVersionsBaseUrl}/current`); | ||||||
|  |         return provisionGradle(json.version, json.downloadUrl); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function gradleReleaseCandidate() { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const json = yield gradleVersionDeclaration(`${gradleVersionsBaseUrl}/release-candidate`); | ||||||
|  |         if (json) { | ||||||
|  |             return provisionGradle(json.version, json.downloadUrl); | ||||||
|  |         } | ||||||
|  |         return gradleCurrent(); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function gradleNightly() { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const json = yield gradleVersionDeclaration(`${gradleVersionsBaseUrl}/nightly`); | ||||||
|  |         return provisionGradle(json.version, json.downloadUrl); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function gradleReleaseNightly() { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const json = yield gradleVersionDeclaration(`${gradleVersionsBaseUrl}/release-nightly`); | ||||||
|  |         return provisionGradle(json.version, json.downloadUrl); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function gradle(version) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const declaration = yield findGradleVersionDeclaration(version); | ||||||
|  |         if (!declaration) { | ||||||
|  |             throw new Error(`Gradle version ${version} does not exists`); | ||||||
|  |         } | ||||||
|  |         return provisionGradle(declaration.version, declaration.downloadUrl); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function gradleVersionDeclaration(url) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const json = yield httpGetJson(url); | ||||||
|  |         return (json.version && json.version.length > 0) ? json : undefined; | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function findGradleVersionDeclaration(version) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const json = yield httpGetJson(`${gradleVersionsBaseUrl}/all`); | ||||||
|  |         const found = json.find((entry) => { | ||||||
|  |             return entry.version === version; | ||||||
|  |         }); | ||||||
|  |         return found ? found : undefined; | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function provisionGradle(version, url) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const cachedInstall = toolCache.find("gradle", version); | ||||||
|  |         if (cachedInstall.length > 0) { | ||||||
|  |             const cachedExecutable = executableFrom(cachedInstall); | ||||||
|  |             core.info(`Provisioned Gradle executable ${cachedExecutable}`); | ||||||
|  |             return cachedExecutable; | ||||||
|  |         } | ||||||
|  |         const home = process.env["HOME"] || ""; | ||||||
|  |         const tmpdir = path.join(home, "gradle-provision-tmpdir"); | ||||||
|  |         const downloadsDir = path.join(tmpdir, "downloads"); | ||||||
|  |         const installsDir = path.join(tmpdir, "installs"); | ||||||
|  |         yield io.mkdirP(downloadsDir); | ||||||
|  |         yield io.mkdirP(installsDir); | ||||||
|  |         core.info(`Downloading ${url}`); | ||||||
|  |         const downloadPath = path.join(downloadsDir, `gradle-${version}-bin.zip`); | ||||||
|  |         yield httpDownload(url, downloadPath); | ||||||
|  |         core.info(`Downloaded at ${downloadPath}, size ${fs.statSync(downloadPath).size}`); | ||||||
|  |         yield extractZip(downloadPath, installsDir); | ||||||
|  |         const installDir = path.join(installsDir, `gradle-${version}`); | ||||||
|  |         core.info(`Extracted in ${installDir}`); | ||||||
|  |         const executable = executableFrom(installDir); | ||||||
|  |         fs.chmodSync(executable, "755"); | ||||||
|  |         core.info(`Provisioned Gradle executable ${executable}`); | ||||||
|  |         toolCache.cacheDir(installDir, "gradle", version); | ||||||
|  |         return executable; | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function executableFrom(installDir) { | ||||||
|  |     return path.join(installDir, "bin", `${gradlew.installScriptFilename()}`); | ||||||
|  | } | ||||||
|  | function httpGetJson(url) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const response = yield httpc.get(url); | ||||||
|  |         const body = yield response.readBody(); | ||||||
|  |         return JSON.parse(body); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function httpDownload(url, path) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         return new Promise(function (resolve, reject) { | ||||||
|  |             const writeStream = fs.createWriteStream(path); | ||||||
|  |             httpc.get(url).then(response => { | ||||||
|  |                 response.message.pipe(writeStream) | ||||||
|  |                     .on("close", () => { | ||||||
|  |                     resolve(); | ||||||
|  |                 }) | ||||||
|  |                     .on("error", err => { | ||||||
|  |                     reject(err); | ||||||
|  |                 }); | ||||||
|  |             }).catch(reason => { | ||||||
|  |                 reject(reason); | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | function extractZip(zip, destination) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         return new Promise(function (resolve, reject) { | ||||||
|  |             fs.createReadStream(zip) | ||||||
|  |                 .pipe(unzip.Extract({ "path": destination })) | ||||||
|  |                 .on("close", () => { | ||||||
|  |                 resolve(); | ||||||
|  |             }) | ||||||
|  |                 .on("error", err => { | ||||||
|  |                 reject(err); | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								node_modules/.bin/mkdirp
									
									
									
										generated
									
									
										vendored
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								node_modules/.bin/mkdirp
									
									
									
										generated
									
									
										vendored
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ../mkdirp/bin/cmd.js | ||||||
							
								
								
									
										1
									
								
								node_modules/.bin/rimraf
									
									
									
										generated
									
									
										vendored
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								node_modules/.bin/rimraf
									
									
									
										generated
									
									
										vendored
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ../rimraf/bin.js | ||||||
							
								
								
									
										1
									
								
								node_modules/.bin/uuid
									
									
									
										generated
									
									
										vendored
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								node_modules/.bin/uuid
									
									
									
										generated
									
									
										vendored
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ../uuid/bin/uuid | ||||||
							
								
								
									
										97
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | |||||||
|  | # `@actions/core` | ||||||
|  |  | ||||||
|  | > Core functions for setting results, logging, registering secrets and exporting variables across actions | ||||||
|  |  | ||||||
|  | ## Usage | ||||||
|  |  | ||||||
|  | #### Inputs/Outputs | ||||||
|  |  | ||||||
|  | You can use this library to get inputs or set outputs: | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const core = require('@actions/core'); | ||||||
|  |  | ||||||
|  | const myInput = core.getInput('inputName', { required: true }); | ||||||
|  |  | ||||||
|  | // Do stuff | ||||||
|  |  | ||||||
|  | core.setOutput('outputKey', 'outputVal'); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | #### Exporting variables | ||||||
|  |  | ||||||
|  | You can also export variables for future steps. Variables get set in the environment. | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const core = require('@actions/core'); | ||||||
|  |  | ||||||
|  | // Do stuff | ||||||
|  |  | ||||||
|  | core.exportVariable('envVar', 'Val'); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | #### PATH Manipulation | ||||||
|  |  | ||||||
|  | You can explicitly add items to the path for all remaining steps in a workflow: | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const core = require('@actions/core'); | ||||||
|  |  | ||||||
|  | core.addPath('pathToTool'); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | #### Exit codes | ||||||
|  |  | ||||||
|  | You should use this library to set the failing exit code for your action: | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const core = require('@actions/core'); | ||||||
|  |  | ||||||
|  | try { | ||||||
|  |   // Do stuff | ||||||
|  | } | ||||||
|  | catch (err) { | ||||||
|  |   // setFailed logs the message and sets a failing exit code | ||||||
|  |   core.setFailed(`Action failed with error ${err}`); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | #### Logging | ||||||
|  |  | ||||||
|  | Finally, this library provides some utilities for logging. Note that debug logging is hidden from the logs by default. This behavior can be toggled by enabling the [Step Debug Logs](../../docs/action-debugging.md#step-debug-logs). | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const core = require('@actions/core'); | ||||||
|  |  | ||||||
|  | const myInput = core.getInput('input'); | ||||||
|  | try { | ||||||
|  |   core.debug('Inside try block'); | ||||||
|  |    | ||||||
|  |   if (!myInput) { | ||||||
|  |     core.warning('myInput was not set'); | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   // Do stuff | ||||||
|  | } | ||||||
|  | catch (err) { | ||||||
|  |   core.error(`Error ${err}, action may still succeed though`); | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | This library can also wrap chunks of output in foldable groups. | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const core = require('@actions/core') | ||||||
|  |  | ||||||
|  | // Manually wrap output | ||||||
|  | core.startGroup('Do some function') | ||||||
|  | doSomeFunction() | ||||||
|  | core.endGroup() | ||||||
|  |  | ||||||
|  | // Wrap an asynchronous function call | ||||||
|  | const result = await core.group('Do something async', async () => { | ||||||
|  |   const response = await doSomeHTTPRequest() | ||||||
|  |   return response | ||||||
|  | }) | ||||||
|  | ``` | ||||||
							
								
								
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | interface CommandProperties { | ||||||
|  |     [key: string]: string; | ||||||
|  | } | ||||||
|  | /** | ||||||
|  |  * Commands | ||||||
|  |  * | ||||||
|  |  * Command Format: | ||||||
|  |  *   ##[name key=value;key=value]message | ||||||
|  |  * | ||||||
|  |  * Examples: | ||||||
|  |  *   ##[warning]This is the user warning message | ||||||
|  |  *   ##[set-secret name=mypassword]definitelyNotAPassword! | ||||||
|  |  */ | ||||||
|  | export declare function issueCommand(command: string, properties: CommandProperties, message: string): void; | ||||||
|  | export declare function issue(name: string, message?: string): void; | ||||||
|  | export {}; | ||||||
							
								
								
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | |||||||
|  | "use strict"; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const os = require("os"); | ||||||
|  | /** | ||||||
|  |  * Commands | ||||||
|  |  * | ||||||
|  |  * Command Format: | ||||||
|  |  *   ##[name key=value;key=value]message | ||||||
|  |  * | ||||||
|  |  * Examples: | ||||||
|  |  *   ##[warning]This is the user warning message | ||||||
|  |  *   ##[set-secret name=mypassword]definitelyNotAPassword! | ||||||
|  |  */ | ||||||
|  | function issueCommand(command, properties, message) { | ||||||
|  |     const cmd = new Command(command, properties, message); | ||||||
|  |     process.stdout.write(cmd.toString() + os.EOL); | ||||||
|  | } | ||||||
|  | exports.issueCommand = issueCommand; | ||||||
|  | function issue(name, message = '') { | ||||||
|  |     issueCommand(name, {}, message); | ||||||
|  | } | ||||||
|  | exports.issue = issue; | ||||||
|  | const CMD_STRING = '::'; | ||||||
|  | class Command { | ||||||
|  |     constructor(command, properties, message) { | ||||||
|  |         if (!command) { | ||||||
|  |             command = 'missing.command'; | ||||||
|  |         } | ||||||
|  |         this.command = command; | ||||||
|  |         this.properties = properties; | ||||||
|  |         this.message = message; | ||||||
|  |     } | ||||||
|  |     toString() { | ||||||
|  |         let cmdStr = CMD_STRING + this.command; | ||||||
|  |         if (this.properties && Object.keys(this.properties).length > 0) { | ||||||
|  |             cmdStr += ' '; | ||||||
|  |             for (const key in this.properties) { | ||||||
|  |                 if (this.properties.hasOwnProperty(key)) { | ||||||
|  |                     const val = this.properties[key]; | ||||||
|  |                     if (val) { | ||||||
|  |                         // safely append the val - avoid blowing up when attempting to | ||||||
|  |                         // call .replace() if message is not a string for some reason | ||||||
|  |                         cmdStr += `${key}=${escape(`${val || ''}`)},`; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         cmdStr += CMD_STRING; | ||||||
|  |         // safely append the message - avoid blowing up when attempting to | ||||||
|  |         // call .replace() if message is not a string for some reason | ||||||
|  |         const message = `${this.message || ''}`; | ||||||
|  |         cmdStr += escapeData(message); | ||||||
|  |         return cmdStr; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | function escapeData(s) { | ||||||
|  |     return s.replace(/\r/g, '%0D').replace(/\n/g, '%0A'); | ||||||
|  | } | ||||||
|  | function escape(s) { | ||||||
|  |     return s | ||||||
|  |         .replace(/\r/g, '%0D') | ||||||
|  |         .replace(/\n/g, '%0A') | ||||||
|  |         .replace(/]/g, '%5D') | ||||||
|  |         .replace(/;/g, '%3B'); | ||||||
|  | } | ||||||
|  | //# sourceMappingURL=command.js.map | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | {"version":3,"file":"command.js","sourceRoot":"","sources":["../src/command.ts"],"names":[],"mappings":";;AAAA,yBAAwB;AAQxB;;;;;;;;;GASG;AACH,SAAgB,YAAY,CAC1B,OAAe,EACf,UAA6B,EAC7B,OAAe;IAEf,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,CAAC,CAAA;IACrD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAA;AAC/C,CAAC;AAPD,oCAOC;AAED,SAAgB,KAAK,CAAC,IAAY,EAAE,UAAkB,EAAE;IACtD,YAAY,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACjC,CAAC;AAFD,sBAEC;AAED,MAAM,UAAU,GAAG,IAAI,CAAA;AAEvB,MAAM,OAAO;IAKX,YAAY,OAAe,EAAE,UAA6B,EAAE,OAAe;QACzE,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,GAAG,iBAAiB,CAAA;SAC5B;QAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,QAAQ;QACN,IAAI,MAAM,GAAG,UAAU,GAAG,IAAI,CAAC,OAAO,CAAA;QAEtC,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9D,MAAM,IAAI,GAAG,CAAA;YACb,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjC,IAAI,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;oBACvC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;oBAChC,IAAI,GAAG,EAAE;wBACP,8DAA8D;wBAC9D,6DAA6D;wBAC7D,MAAM,IAAI,GAAG,GAAG,IAAI,MAAM,CAAC,GAAG,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAA;qBAC9C;iBACF;aACF;SACF;QAED,MAAM,IAAI,UAAU,CAAA;QAEpB,kEAAkE;QAClE,6DAA6D;QAC7D,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,CAAA;QACvC,MAAM,IAAI,UAAU,CAAC,OAAO,CAAC,CAAA;QAE7B,OAAO,MAAM,CAAA;IACf,CAAC;CACF;AAED,SAAS,UAAU,CAAC,CAAS;IAC3B,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;AACtD,CAAC;AAED,SAAS,MAAM,CAAC,CAAS;IACvB,OAAO,CAAC;SACL,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC;SACpB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;AACzB,CAAC"} | ||||||
							
								
								
									
										99
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | |||||||
|  | /** | ||||||
|  |  * Interface for getInput options | ||||||
|  |  */ | ||||||
|  | export interface InputOptions { | ||||||
|  |     /** Optional. Whether the input is required. If required and not present, will throw. Defaults to false */ | ||||||
|  |     required?: boolean; | ||||||
|  | } | ||||||
|  | /** | ||||||
|  |  * The code to exit an action | ||||||
|  |  */ | ||||||
|  | export declare enum ExitCode { | ||||||
|  |     /** | ||||||
|  |      * A code indicating that the action was successful | ||||||
|  |      */ | ||||||
|  |     Success = 0, | ||||||
|  |     /** | ||||||
|  |      * A code indicating that the action was a failure | ||||||
|  |      */ | ||||||
|  |     Failure = 1 | ||||||
|  | } | ||||||
|  | /** | ||||||
|  |  * sets env variable for this action and future actions in the job | ||||||
|  |  * @param name the name of the variable to set | ||||||
|  |  * @param val the value of the variable | ||||||
|  |  */ | ||||||
|  | export declare function exportVariable(name: string, val: string): void; | ||||||
|  | /** | ||||||
|  |  * exports the variable and registers a secret which will get masked from logs | ||||||
|  |  * @param name the name of the variable to set | ||||||
|  |  * @param val value of the secret | ||||||
|  |  */ | ||||||
|  | export declare function exportSecret(name: string, val: string): void; | ||||||
|  | /** | ||||||
|  |  * Prepends inputPath to the PATH (for this action and future actions) | ||||||
|  |  * @param inputPath | ||||||
|  |  */ | ||||||
|  | export declare function addPath(inputPath: string): void; | ||||||
|  | /** | ||||||
|  |  * Gets the value of an input.  The value is also trimmed. | ||||||
|  |  * | ||||||
|  |  * @param     name     name of the input to get | ||||||
|  |  * @param     options  optional. See InputOptions. | ||||||
|  |  * @returns   string | ||||||
|  |  */ | ||||||
|  | export declare function getInput(name: string, options?: InputOptions): string; | ||||||
|  | /** | ||||||
|  |  * Sets the value of an output. | ||||||
|  |  * | ||||||
|  |  * @param     name     name of the output to set | ||||||
|  |  * @param     value    value to store | ||||||
|  |  */ | ||||||
|  | export declare function setOutput(name: string, value: string): void; | ||||||
|  | /** | ||||||
|  |  * Sets the action status to failed. | ||||||
|  |  * When the action exits it will be with an exit code of 1 | ||||||
|  |  * @param message add error issue message | ||||||
|  |  */ | ||||||
|  | export declare function setFailed(message: string): void; | ||||||
|  | /** | ||||||
|  |  * Writes debug message to user log | ||||||
|  |  * @param message debug message | ||||||
|  |  */ | ||||||
|  | export declare function debug(message: string): void; | ||||||
|  | /** | ||||||
|  |  * Adds an error issue | ||||||
|  |  * @param message error issue message | ||||||
|  |  */ | ||||||
|  | export declare function error(message: string): void; | ||||||
|  | /** | ||||||
|  |  * Adds an warning issue | ||||||
|  |  * @param message warning issue message | ||||||
|  |  */ | ||||||
|  | export declare function warning(message: string): void; | ||||||
|  | /** | ||||||
|  |  * Writes info to log with console.log. | ||||||
|  |  * @param message info message | ||||||
|  |  */ | ||||||
|  | export declare function info(message: string): void; | ||||||
|  | /** | ||||||
|  |  * Begin an output group. | ||||||
|  |  * | ||||||
|  |  * Output until the next `groupEnd` will be foldable in this group | ||||||
|  |  * | ||||||
|  |  * @param name The name of the output group | ||||||
|  |  */ | ||||||
|  | export declare function startGroup(name: string): void; | ||||||
|  | /** | ||||||
|  |  * End an output group. | ||||||
|  |  */ | ||||||
|  | export declare function endGroup(): void; | ||||||
|  | /** | ||||||
|  |  * Wrap an asynchronous function call in a group. | ||||||
|  |  * | ||||||
|  |  * Returns the same type as the function itself. | ||||||
|  |  * | ||||||
|  |  * @param name The name of the group | ||||||
|  |  * @param fn The function to wrap in the group | ||||||
|  |  */ | ||||||
|  | export declare function group<T>(name: string, fn: () => Promise<T>): Promise<T>; | ||||||
							
								
								
									
										177
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										177
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,177 @@ | |||||||
|  | "use strict"; | ||||||
|  | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|  |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|  |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  |         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||||
|  |         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||||
|  |         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||||
|  |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const command_1 = require("./command"); | ||||||
|  | const os = require("os"); | ||||||
|  | const path = require("path"); | ||||||
|  | /** | ||||||
|  |  * The code to exit an action | ||||||
|  |  */ | ||||||
|  | var ExitCode; | ||||||
|  | (function (ExitCode) { | ||||||
|  |     /** | ||||||
|  |      * A code indicating that the action was successful | ||||||
|  |      */ | ||||||
|  |     ExitCode[ExitCode["Success"] = 0] = "Success"; | ||||||
|  |     /** | ||||||
|  |      * A code indicating that the action was a failure | ||||||
|  |      */ | ||||||
|  |     ExitCode[ExitCode["Failure"] = 1] = "Failure"; | ||||||
|  | })(ExitCode = exports.ExitCode || (exports.ExitCode = {})); | ||||||
|  | //----------------------------------------------------------------------- | ||||||
|  | // Variables | ||||||
|  | //----------------------------------------------------------------------- | ||||||
|  | /** | ||||||
|  |  * sets env variable for this action and future actions in the job | ||||||
|  |  * @param name the name of the variable to set | ||||||
|  |  * @param val the value of the variable | ||||||
|  |  */ | ||||||
|  | function exportVariable(name, val) { | ||||||
|  |     process.env[name] = val; | ||||||
|  |     command_1.issueCommand('set-env', { name }, val); | ||||||
|  | } | ||||||
|  | exports.exportVariable = exportVariable; | ||||||
|  | /** | ||||||
|  |  * exports the variable and registers a secret which will get masked from logs | ||||||
|  |  * @param name the name of the variable to set | ||||||
|  |  * @param val value of the secret | ||||||
|  |  */ | ||||||
|  | function exportSecret(name, val) { | ||||||
|  |     exportVariable(name, val); | ||||||
|  |     // the runner will error with not implemented | ||||||
|  |     // leaving the function but raising the error earlier | ||||||
|  |     command_1.issueCommand('set-secret', {}, val); | ||||||
|  |     throw new Error('Not implemented.'); | ||||||
|  | } | ||||||
|  | exports.exportSecret = exportSecret; | ||||||
|  | /** | ||||||
|  |  * Prepends inputPath to the PATH (for this action and future actions) | ||||||
|  |  * @param inputPath | ||||||
|  |  */ | ||||||
|  | function addPath(inputPath) { | ||||||
|  |     command_1.issueCommand('add-path', {}, inputPath); | ||||||
|  |     process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`; | ||||||
|  | } | ||||||
|  | exports.addPath = addPath; | ||||||
|  | /** | ||||||
|  |  * Gets the value of an input.  The value is also trimmed. | ||||||
|  |  * | ||||||
|  |  * @param     name     name of the input to get | ||||||
|  |  * @param     options  optional. See InputOptions. | ||||||
|  |  * @returns   string | ||||||
|  |  */ | ||||||
|  | function getInput(name, options) { | ||||||
|  |     const val = process.env[`INPUT_${name.replace(/ /g, '_').toUpperCase()}`] || ''; | ||||||
|  |     if (options && options.required && !val) { | ||||||
|  |         throw new Error(`Input required and not supplied: ${name}`); | ||||||
|  |     } | ||||||
|  |     return val.trim(); | ||||||
|  | } | ||||||
|  | exports.getInput = getInput; | ||||||
|  | /** | ||||||
|  |  * Sets the value of an output. | ||||||
|  |  * | ||||||
|  |  * @param     name     name of the output to set | ||||||
|  |  * @param     value    value to store | ||||||
|  |  */ | ||||||
|  | function setOutput(name, value) { | ||||||
|  |     command_1.issueCommand('set-output', { name }, value); | ||||||
|  | } | ||||||
|  | exports.setOutput = setOutput; | ||||||
|  | //----------------------------------------------------------------------- | ||||||
|  | // Results | ||||||
|  | //----------------------------------------------------------------------- | ||||||
|  | /** | ||||||
|  |  * Sets the action status to failed. | ||||||
|  |  * When the action exits it will be with an exit code of 1 | ||||||
|  |  * @param message add error issue message | ||||||
|  |  */ | ||||||
|  | function setFailed(message) { | ||||||
|  |     process.exitCode = ExitCode.Failure; | ||||||
|  |     error(message); | ||||||
|  | } | ||||||
|  | exports.setFailed = setFailed; | ||||||
|  | //----------------------------------------------------------------------- | ||||||
|  | // Logging Commands | ||||||
|  | //----------------------------------------------------------------------- | ||||||
|  | /** | ||||||
|  |  * Writes debug message to user log | ||||||
|  |  * @param message debug message | ||||||
|  |  */ | ||||||
|  | function debug(message) { | ||||||
|  |     command_1.issueCommand('debug', {}, message); | ||||||
|  | } | ||||||
|  | exports.debug = debug; | ||||||
|  | /** | ||||||
|  |  * Adds an error issue | ||||||
|  |  * @param message error issue message | ||||||
|  |  */ | ||||||
|  | function error(message) { | ||||||
|  |     command_1.issue('error', message); | ||||||
|  | } | ||||||
|  | exports.error = error; | ||||||
|  | /** | ||||||
|  |  * Adds an warning issue | ||||||
|  |  * @param message warning issue message | ||||||
|  |  */ | ||||||
|  | function warning(message) { | ||||||
|  |     command_1.issue('warning', message); | ||||||
|  | } | ||||||
|  | exports.warning = warning; | ||||||
|  | /** | ||||||
|  |  * Writes info to log with console.log. | ||||||
|  |  * @param message info message | ||||||
|  |  */ | ||||||
|  | function info(message) { | ||||||
|  |     process.stdout.write(message + os.EOL); | ||||||
|  | } | ||||||
|  | exports.info = info; | ||||||
|  | /** | ||||||
|  |  * Begin an output group. | ||||||
|  |  * | ||||||
|  |  * Output until the next `groupEnd` will be foldable in this group | ||||||
|  |  * | ||||||
|  |  * @param name The name of the output group | ||||||
|  |  */ | ||||||
|  | function startGroup(name) { | ||||||
|  |     command_1.issue('group', name); | ||||||
|  | } | ||||||
|  | exports.startGroup = startGroup; | ||||||
|  | /** | ||||||
|  |  * End an output group. | ||||||
|  |  */ | ||||||
|  | function endGroup() { | ||||||
|  |     command_1.issue('endgroup'); | ||||||
|  | } | ||||||
|  | exports.endGroup = endGroup; | ||||||
|  | /** | ||||||
|  |  * Wrap an asynchronous function call in a group. | ||||||
|  |  * | ||||||
|  |  * Returns the same type as the function itself. | ||||||
|  |  * | ||||||
|  |  * @param name The name of the group | ||||||
|  |  * @param fn The function to wrap in the group | ||||||
|  |  */ | ||||||
|  | function group(name, fn) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         startGroup(name); | ||||||
|  |         let result; | ||||||
|  |         try { | ||||||
|  |             result = yield fn(); | ||||||
|  |         } | ||||||
|  |         finally { | ||||||
|  |             endGroup(); | ||||||
|  |         } | ||||||
|  |         return result; | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | exports.group = group; | ||||||
|  | //# sourceMappingURL=core.js.map | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | {"version":3,"file":"core.js","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,uCAA6C;AAE7C,yBAAwB;AACxB,6BAA4B;AAU5B;;GAEG;AACH,IAAY,QAUX;AAVD,WAAY,QAAQ;IAClB;;OAEG;IACH,6CAAW,CAAA;IAEX;;OAEG;IACH,6CAAW,CAAA;AACb,CAAC,EAVW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAUnB;AAED,yEAAyE;AACzE,YAAY;AACZ,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,cAAc,CAAC,IAAY,EAAE,GAAW;IACtD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,CAAA;IACvB,sBAAY,CAAC,SAAS,EAAE,EAAC,IAAI,EAAC,EAAE,GAAG,CAAC,CAAA;AACtC,CAAC;AAHD,wCAGC;AAED;;;;GAIG;AACH,SAAgB,YAAY,CAAC,IAAY,EAAE,GAAW;IACpD,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;IAEzB,6CAA6C;IAC7C,qDAAqD;IACrD,sBAAY,CAAC,YAAY,EAAE,EAAE,EAAE,GAAG,CAAC,CAAA;IACnC,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;AACrC,CAAC;AAPD,oCAOC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,SAAiB;IACvC,sBAAY,CAAC,UAAU,EAAE,EAAE,EAAE,SAAS,CAAC,CAAA;IACvC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,GAAG,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAA;AAC7E,CAAC;AAHD,0BAGC;AAED;;;;;;GAMG;AACH,SAAgB,QAAQ,CAAC,IAAY,EAAE,OAAsB;IAC3D,MAAM,GAAG,GACP,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAI,EAAE,CAAA;IACrE,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,IAAI,CAAC,GAAG,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,oCAAoC,IAAI,EAAE,CAAC,CAAA;KAC5D;IAED,OAAO,GAAG,CAAC,IAAI,EAAE,CAAA;AACnB,CAAC;AARD,4BAQC;AAED;;;;;GAKG;AACH,SAAgB,SAAS,CAAC,IAAY,EAAE,KAAa;IACnD,sBAAY,CAAC,YAAY,EAAE,EAAC,IAAI,EAAC,EAAE,KAAK,CAAC,CAAA;AAC3C,CAAC;AAFD,8BAEC;AAED,yEAAyE;AACzE,UAAU;AACV,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,SAAS,CAAC,OAAe;IACvC,OAAO,CAAC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAA;IACnC,KAAK,CAAC,OAAO,CAAC,CAAA;AAChB,CAAC;AAHD,8BAGC;AAED,yEAAyE;AACzE,mBAAmB;AACnB,yEAAyE;AAEzE;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,sBAAY,CAAC,OAAO,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACpC,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,eAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;AACzB,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,OAAe;IACrC,eAAK,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;AAC3B,CAAC;AAFD,0BAEC;AAED;;;GAGG;AACH,SAAgB,IAAI,CAAC,OAAe;IAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,GAAG,CAAC,CAAA;AACxC,CAAC;AAFD,oBAEC;AAED;;;;;;GAMG;AACH,SAAgB,UAAU,CAAC,IAAY;IACrC,eAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;AACtB,CAAC;AAFD,gCAEC;AAED;;GAEG;AACH,SAAgB,QAAQ;IACtB,eAAK,CAAC,UAAU,CAAC,CAAA;AACnB,CAAC;AAFD,4BAEC;AAED;;;;;;;GAOG;AACH,SAAsB,KAAK,CAAI,IAAY,EAAE,EAAoB;;QAC/D,UAAU,CAAC,IAAI,CAAC,CAAA;QAEhB,IAAI,MAAS,CAAA;QAEb,IAAI;YACF,MAAM,GAAG,MAAM,EAAE,EAAE,CAAA;SACpB;gBAAS;YACR,QAAQ,EAAE,CAAA;SACX;QAED,OAAO,MAAM,CAAA;IACf,CAAC;CAAA;AAZD,sBAYC"} | ||||||
							
								
								
									
										67
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | { | ||||||
|  |   "_args": [ | ||||||
|  |     [ | ||||||
|  |       "@actions/core@1.1.1", | ||||||
|  |       "/Users/paul/src/codeartisans/gradle-command-action" | ||||||
|  |     ] | ||||||
|  |   ], | ||||||
|  |   "_from": "@actions/core@1.1.1", | ||||||
|  |   "_id": "@actions/core@1.1.1", | ||||||
|  |   "_inBundle": false, | ||||||
|  |   "_integrity": "sha512-O5G6EmlzTVsng7VSpNtszIoQq6kOgMGNTFB/hmwKNNA4V71JyxImCIrL27vVHCt2Cb3ImkaCr6o27C2MV9Ylwg==", | ||||||
|  |   "_location": "/@actions/core", | ||||||
|  |   "_phantomChildren": {}, | ||||||
|  |   "_requested": { | ||||||
|  |     "type": "version", | ||||||
|  |     "registry": true, | ||||||
|  |     "raw": "@actions/core@1.1.1", | ||||||
|  |     "name": "@actions/core", | ||||||
|  |     "escapedName": "@actions%2fcore", | ||||||
|  |     "scope": "@actions", | ||||||
|  |     "rawSpec": "1.1.1", | ||||||
|  |     "saveSpec": null, | ||||||
|  |     "fetchSpec": "1.1.1" | ||||||
|  |   }, | ||||||
|  |   "_requiredBy": [ | ||||||
|  |     "/", | ||||||
|  |     "/@actions/tool-cache" | ||||||
|  |   ], | ||||||
|  |   "_resolved": "https://registry.npmjs.org/@actions/core/-/core-1.1.1.tgz", | ||||||
|  |   "_spec": "1.1.1", | ||||||
|  |   "_where": "/Users/paul/src/codeartisans/gradle-command-action", | ||||||
|  |   "bugs": { | ||||||
|  |     "url": "https://github.com/actions/toolkit/issues" | ||||||
|  |   }, | ||||||
|  |   "description": "Actions core lib", | ||||||
|  |   "devDependencies": { | ||||||
|  |     "@types/node": "^12.0.2" | ||||||
|  |   }, | ||||||
|  |   "directories": { | ||||||
|  |     "lib": "lib", | ||||||
|  |     "test": "__tests__" | ||||||
|  |   }, | ||||||
|  |   "files": [ | ||||||
|  |     "lib" | ||||||
|  |   ], | ||||||
|  |   "homepage": "https://github.com/actions/toolkit/tree/master/packages/core", | ||||||
|  |   "keywords": [ | ||||||
|  |     "github", | ||||||
|  |     "actions", | ||||||
|  |     "core" | ||||||
|  |   ], | ||||||
|  |   "license": "MIT", | ||||||
|  |   "main": "lib/core.js", | ||||||
|  |   "name": "@actions/core", | ||||||
|  |   "publishConfig": { | ||||||
|  |     "access": "public" | ||||||
|  |   }, | ||||||
|  |   "repository": { | ||||||
|  |     "type": "git", | ||||||
|  |     "url": "git+https://github.com/actions/toolkit.git" | ||||||
|  |   }, | ||||||
|  |   "scripts": { | ||||||
|  |     "test": "echo \"Error: run tests from root\" && exit 1", | ||||||
|  |     "tsc": "tsc" | ||||||
|  |   }, | ||||||
|  |   "version": "1.1.1" | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								node_modules/@actions/exec/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/exec/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | Copyright 2019 GitHub | ||||||
|  |  | ||||||
|  | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||||
|  |  | ||||||
|  | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||||
|  |  | ||||||
|  | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||||
							
								
								
									
										60
									
								
								node_modules/@actions/exec/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								node_modules/@actions/exec/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | |||||||
|  | # `@actions/exec` | ||||||
|  |  | ||||||
|  | ## Usage | ||||||
|  |  | ||||||
|  | #### Basic | ||||||
|  |  | ||||||
|  | You can use this package to execute your tools on the command line in a cross platform way: | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const exec = require('@actions/exec'); | ||||||
|  |  | ||||||
|  | await exec.exec('node index.js'); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | #### Args | ||||||
|  |  | ||||||
|  | You can also pass in arg arrays: | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const exec = require('@actions/exec'); | ||||||
|  |  | ||||||
|  | await exec.exec('node', ['index.js', 'foo=bar']); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | #### Output/options | ||||||
|  |  | ||||||
|  | Capture output or specify [other options](https://github.com/actions/toolkit/blob/d9347d4ab99fd507c0b9104b2cf79fb44fcc827d/packages/exec/src/interfaces.ts#L5): | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const exec = require('@actions/exec'); | ||||||
|  |  | ||||||
|  | let myOutput = ''; | ||||||
|  | let myError = ''; | ||||||
|  |  | ||||||
|  | const options = {}; | ||||||
|  | options.listeners = { | ||||||
|  |   stdout: (data: Buffer) => { | ||||||
|  |     myOutput += data.toString(); | ||||||
|  |   }, | ||||||
|  |   stderr: (data: Buffer) => { | ||||||
|  |     myError += data.toString(); | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  | options.cwd = './lib'; | ||||||
|  |  | ||||||
|  | await exec.exec('node', ['index.js', 'foo=bar'], options); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | #### Exec tools not in the PATH | ||||||
|  |  | ||||||
|  | You can use it in conjunction with the `which` function from `@actions/io` to execute tools that are not in the PATH: | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | const exec = require('@actions/exec'); | ||||||
|  | const io = require('@actions/io'); | ||||||
|  |  | ||||||
|  | const pythonPath: string = await io.which('python', true) | ||||||
|  |  | ||||||
|  | await exec.exec(`"${pythonPath}"`, ['main.py']); | ||||||
|  | ``` | ||||||
							
								
								
									
										12
									
								
								node_modules/@actions/exec/lib/exec.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								node_modules/@actions/exec/lib/exec.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | import * as im from './interfaces'; | ||||||
|  | /** | ||||||
|  |  * Exec a command. | ||||||
|  |  * Output will be streamed to the live console. | ||||||
|  |  * Returns promise with return code | ||||||
|  |  * | ||||||
|  |  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped. | ||||||
|  |  * @param     args               optional arguments for tool. Escaping is handled by the lib. | ||||||
|  |  * @param     options            optional exec options.  See ExecOptions | ||||||
|  |  * @returns   Promise<number>    exit code | ||||||
|  |  */ | ||||||
|  | export declare function exec(commandLine: string, args?: string[], options?: im.ExecOptions): Promise<number>; | ||||||
							
								
								
									
										37
									
								
								node_modules/@actions/exec/lib/exec.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								node_modules/@actions/exec/lib/exec.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | "use strict"; | ||||||
|  | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|  |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|  |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  |         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||||
|  |         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||||
|  |         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||||
|  |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const tr = require("./toolrunner"); | ||||||
|  | /** | ||||||
|  |  * Exec a command. | ||||||
|  |  * Output will be streamed to the live console. | ||||||
|  |  * Returns promise with return code | ||||||
|  |  * | ||||||
|  |  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped. | ||||||
|  |  * @param     args               optional arguments for tool. Escaping is handled by the lib. | ||||||
|  |  * @param     options            optional exec options.  See ExecOptions | ||||||
|  |  * @returns   Promise<number>    exit code | ||||||
|  |  */ | ||||||
|  | function exec(commandLine, args, options) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         const commandArgs = tr.argStringToArray(commandLine); | ||||||
|  |         if (commandArgs.length === 0) { | ||||||
|  |             throw new Error(`Parameter 'commandLine' cannot be null or empty.`); | ||||||
|  |         } | ||||||
|  |         // Path to tool to execute should be first arg | ||||||
|  |         const toolPath = commandArgs[0]; | ||||||
|  |         args = commandArgs.slice(1).concat(args || []); | ||||||
|  |         const runner = new tr.ToolRunner(toolPath, args, options); | ||||||
|  |         return runner.exec(); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | exports.exec = exec; | ||||||
|  | //# sourceMappingURL=exec.js.map | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/exec.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/exec.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | {"version":3,"file":"exec.js","sourceRoot":"","sources":["../src/exec.ts"],"names":[],"mappings":";;;;;;;;;;;AACA,mCAAkC;AAElC;;;;;;;;;GASG;AACH,SAAsB,IAAI,CACxB,WAAmB,EACnB,IAAe,EACf,OAAwB;;QAExB,MAAM,WAAW,GAAG,EAAE,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAA;QACpD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;SACpE;QACD,8CAA8C;QAC9C,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAA;QAC/B,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;QAC9C,MAAM,MAAM,GAAkB,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,CAAA;QACxE,OAAO,MAAM,CAAC,IAAI,EAAE,CAAA;IACtB,CAAC;CAAA;AAdD,oBAcC"} | ||||||
							
								
								
									
										35
									
								
								node_modules/@actions/exec/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								node_modules/@actions/exec/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | /// <reference types="node" /> | ||||||
|  | import * as stream from 'stream'; | ||||||
|  | /** | ||||||
|  |  * Interface for exec options | ||||||
|  |  */ | ||||||
|  | export interface ExecOptions { | ||||||
|  |     /** optional working directory.  defaults to current */ | ||||||
|  |     cwd?: string; | ||||||
|  |     /** optional envvar dictionary.  defaults to current process's env */ | ||||||
|  |     env?: { | ||||||
|  |         [key: string]: string; | ||||||
|  |     }; | ||||||
|  |     /** optional.  defaults to false */ | ||||||
|  |     silent?: boolean; | ||||||
|  |     /** optional out stream to use. Defaults to process.stdout */ | ||||||
|  |     outStream?: stream.Writable; | ||||||
|  |     /** optional err stream to use. Defaults to process.stderr */ | ||||||
|  |     errStream?: stream.Writable; | ||||||
|  |     /** optional. whether to skip quoting/escaping arguments if needed.  defaults to false. */ | ||||||
|  |     windowsVerbatimArguments?: boolean; | ||||||
|  |     /** optional.  whether to fail if output to stderr.  defaults to false */ | ||||||
|  |     failOnStdErr?: boolean; | ||||||
|  |     /** optional.  defaults to failing on non zero.  ignore will not fail leaving it up to the caller */ | ||||||
|  |     ignoreReturnCode?: boolean; | ||||||
|  |     /** optional. How long in ms to wait for STDIO streams to close after the exit event of the process before terminating. defaults to 10000 */ | ||||||
|  |     delay?: number; | ||||||
|  |     /** optional. Listeners for output. Callback functions that will be called on these events */ | ||||||
|  |     listeners?: { | ||||||
|  |         stdout?: (data: Buffer) => void; | ||||||
|  |         stderr?: (data: Buffer) => void; | ||||||
|  |         stdline?: (data: string) => void; | ||||||
|  |         errline?: (data: string) => void; | ||||||
|  |         debug?: (data: string) => void; | ||||||
|  |     }; | ||||||
|  | } | ||||||
							
								
								
									
										3
									
								
								node_modules/@actions/exec/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								node_modules/@actions/exec/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | "use strict"; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | //# sourceMappingURL=interfaces.js.map | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../src/interfaces.ts"],"names":[],"mappings":""} | ||||||
							
								
								
									
										37
									
								
								node_modules/@actions/exec/lib/toolrunner.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								node_modules/@actions/exec/lib/toolrunner.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | /// <reference types="node" /> | ||||||
|  | import * as events from 'events'; | ||||||
|  | import * as im from './interfaces'; | ||||||
|  | export declare class ToolRunner extends events.EventEmitter { | ||||||
|  |     constructor(toolPath: string, args?: string[], options?: im.ExecOptions); | ||||||
|  |     private toolPath; | ||||||
|  |     private args; | ||||||
|  |     private options; | ||||||
|  |     private _debug; | ||||||
|  |     private _getCommandString; | ||||||
|  |     private _processLineBuffer; | ||||||
|  |     private _getSpawnFileName; | ||||||
|  |     private _getSpawnArgs; | ||||||
|  |     private _endsWith; | ||||||
|  |     private _isCmdFile; | ||||||
|  |     private _windowsQuoteCmdArg; | ||||||
|  |     private _uvQuoteCmdArg; | ||||||
|  |     private _cloneExecOptions; | ||||||
|  |     private _getSpawnOptions; | ||||||
|  |     /** | ||||||
|  |      * Exec a tool. | ||||||
|  |      * Output will be streamed to the live console. | ||||||
|  |      * Returns promise with return code | ||||||
|  |      * | ||||||
|  |      * @param     tool     path to tool to exec | ||||||
|  |      * @param     options  optional exec options.  See ExecOptions | ||||||
|  |      * @returns   number | ||||||
|  |      */ | ||||||
|  |     exec(): Promise<number>; | ||||||
|  | } | ||||||
|  | /** | ||||||
|  |  * Convert an arg string to an array of args. Handles escaping | ||||||
|  |  * | ||||||
|  |  * @param    argString   string of arguments | ||||||
|  |  * @returns  string[]    array of arguments | ||||||
|  |  */ | ||||||
|  | export declare function argStringToArray(argString: string): string[]; | ||||||
							
								
								
									
										574
									
								
								node_modules/@actions/exec/lib/toolrunner.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										574
									
								
								node_modules/@actions/exec/lib/toolrunner.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,574 @@ | |||||||
|  | "use strict"; | ||||||
|  | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|  |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|  |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  |         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||||
|  |         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||||
|  |         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||||
|  |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const os = require("os"); | ||||||
|  | const events = require("events"); | ||||||
|  | const child = require("child_process"); | ||||||
|  | /* eslint-disable @typescript-eslint/unbound-method */ | ||||||
|  | const IS_WINDOWS = process.platform === 'win32'; | ||||||
|  | /* | ||||||
|  |  * Class for running command line tools. Handles quoting and arg parsing in a platform agnostic way. | ||||||
|  |  */ | ||||||
|  | class ToolRunner extends events.EventEmitter { | ||||||
|  |     constructor(toolPath, args, options) { | ||||||
|  |         super(); | ||||||
|  |         if (!toolPath) { | ||||||
|  |             throw new Error("Parameter 'toolPath' cannot be null or empty."); | ||||||
|  |         } | ||||||
|  |         this.toolPath = toolPath; | ||||||
|  |         this.args = args || []; | ||||||
|  |         this.options = options || {}; | ||||||
|  |     } | ||||||
|  |     _debug(message) { | ||||||
|  |         if (this.options.listeners && this.options.listeners.debug) { | ||||||
|  |             this.options.listeners.debug(message); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     _getCommandString(options, noPrefix) { | ||||||
|  |         const toolPath = this._getSpawnFileName(); | ||||||
|  |         const args = this._getSpawnArgs(options); | ||||||
|  |         let cmd = noPrefix ? '' : '[command]'; // omit prefix when piped to a second tool | ||||||
|  |         if (IS_WINDOWS) { | ||||||
|  |             // Windows + cmd file | ||||||
|  |             if (this._isCmdFile()) { | ||||||
|  |                 cmd += toolPath; | ||||||
|  |                 for (const a of args) { | ||||||
|  |                     cmd += ` ${a}`; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             // Windows + verbatim | ||||||
|  |             else if (options.windowsVerbatimArguments) { | ||||||
|  |                 cmd += `"${toolPath}"`; | ||||||
|  |                 for (const a of args) { | ||||||
|  |                     cmd += ` ${a}`; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             // Windows (regular) | ||||||
|  |             else { | ||||||
|  |                 cmd += this._windowsQuoteCmdArg(toolPath); | ||||||
|  |                 for (const a of args) { | ||||||
|  |                     cmd += ` ${this._windowsQuoteCmdArg(a)}`; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             // OSX/Linux - this can likely be improved with some form of quoting. | ||||||
|  |             // creating processes on Unix is fundamentally different than Windows. | ||||||
|  |             // on Unix, execvp() takes an arg array. | ||||||
|  |             cmd += toolPath; | ||||||
|  |             for (const a of args) { | ||||||
|  |                 cmd += ` ${a}`; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return cmd; | ||||||
|  |     } | ||||||
|  |     _processLineBuffer(data, strBuffer, onLine) { | ||||||
|  |         try { | ||||||
|  |             let s = strBuffer + data.toString(); | ||||||
|  |             let n = s.indexOf(os.EOL); | ||||||
|  |             while (n > -1) { | ||||||
|  |                 const line = s.substring(0, n); | ||||||
|  |                 onLine(line); | ||||||
|  |                 // the rest of the string ... | ||||||
|  |                 s = s.substring(n + os.EOL.length); | ||||||
|  |                 n = s.indexOf(os.EOL); | ||||||
|  |             } | ||||||
|  |             strBuffer = s; | ||||||
|  |         } | ||||||
|  |         catch (err) { | ||||||
|  |             // streaming lines to console is best effort.  Don't fail a build. | ||||||
|  |             this._debug(`error processing line. Failed with error ${err}`); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     _getSpawnFileName() { | ||||||
|  |         if (IS_WINDOWS) { | ||||||
|  |             if (this._isCmdFile()) { | ||||||
|  |                 return process.env['COMSPEC'] || 'cmd.exe'; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return this.toolPath; | ||||||
|  |     } | ||||||
|  |     _getSpawnArgs(options) { | ||||||
|  |         if (IS_WINDOWS) { | ||||||
|  |             if (this._isCmdFile()) { | ||||||
|  |                 let argline = `/D /S /C "${this._windowsQuoteCmdArg(this.toolPath)}`; | ||||||
|  |                 for (const a of this.args) { | ||||||
|  |                     argline += ' '; | ||||||
|  |                     argline += options.windowsVerbatimArguments | ||||||
|  |                         ? a | ||||||
|  |                         : this._windowsQuoteCmdArg(a); | ||||||
|  |                 } | ||||||
|  |                 argline += '"'; | ||||||
|  |                 return [argline]; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return this.args; | ||||||
|  |     } | ||||||
|  |     _endsWith(str, end) { | ||||||
|  |         return str.endsWith(end); | ||||||
|  |     } | ||||||
|  |     _isCmdFile() { | ||||||
|  |         const upperToolPath = this.toolPath.toUpperCase(); | ||||||
|  |         return (this._endsWith(upperToolPath, '.CMD') || | ||||||
|  |             this._endsWith(upperToolPath, '.BAT')); | ||||||
|  |     } | ||||||
|  |     _windowsQuoteCmdArg(arg) { | ||||||
|  |         // for .exe, apply the normal quoting rules that libuv applies | ||||||
|  |         if (!this._isCmdFile()) { | ||||||
|  |             return this._uvQuoteCmdArg(arg); | ||||||
|  |         } | ||||||
|  |         // otherwise apply quoting rules specific to the cmd.exe command line parser. | ||||||
|  |         // the libuv rules are generic and are not designed specifically for cmd.exe | ||||||
|  |         // command line parser. | ||||||
|  |         // | ||||||
|  |         // for a detailed description of the cmd.exe command line parser, refer to | ||||||
|  |         // http://stackoverflow.com/questions/4094699/how-does-the-windows-command-interpreter-cmd-exe-parse-scripts/7970912#7970912 | ||||||
|  |         // need quotes for empty arg | ||||||
|  |         if (!arg) { | ||||||
|  |             return '""'; | ||||||
|  |         } | ||||||
|  |         // determine whether the arg needs to be quoted | ||||||
|  |         const cmdSpecialChars = [ | ||||||
|  |             ' ', | ||||||
|  |             '\t', | ||||||
|  |             '&', | ||||||
|  |             '(', | ||||||
|  |             ')', | ||||||
|  |             '[', | ||||||
|  |             ']', | ||||||
|  |             '{', | ||||||
|  |             '}', | ||||||
|  |             '^', | ||||||
|  |             '=', | ||||||
|  |             ';', | ||||||
|  |             '!', | ||||||
|  |             "'", | ||||||
|  |             '+', | ||||||
|  |             ',', | ||||||
|  |             '`', | ||||||
|  |             '~', | ||||||
|  |             '|', | ||||||
|  |             '<', | ||||||
|  |             '>', | ||||||
|  |             '"' | ||||||
|  |         ]; | ||||||
|  |         let needsQuotes = false; | ||||||
|  |         for (const char of arg) { | ||||||
|  |             if (cmdSpecialChars.some(x => x === char)) { | ||||||
|  |                 needsQuotes = true; | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         // short-circuit if quotes not needed | ||||||
|  |         if (!needsQuotes) { | ||||||
|  |             return arg; | ||||||
|  |         } | ||||||
|  |         // the following quoting rules are very similar to the rules that by libuv applies. | ||||||
|  |         // | ||||||
|  |         // 1) wrap the string in quotes | ||||||
|  |         // | ||||||
|  |         // 2) double-up quotes - i.e. " => "" | ||||||
|  |         // | ||||||
|  |         //    this is different from the libuv quoting rules. libuv replaces " with \", which unfortunately | ||||||
|  |         //    doesn't work well with a cmd.exe command line. | ||||||
|  |         // | ||||||
|  |         //    note, replacing " with "" also works well if the arg is passed to a downstream .NET console app. | ||||||
|  |         //    for example, the command line: | ||||||
|  |         //          foo.exe "myarg:""my val""" | ||||||
|  |         //    is parsed by a .NET console app into an arg array: | ||||||
|  |         //          [ "myarg:\"my val\"" ] | ||||||
|  |         //    which is the same end result when applying libuv quoting rules. although the actual | ||||||
|  |         //    command line from libuv quoting rules would look like: | ||||||
|  |         //          foo.exe "myarg:\"my val\"" | ||||||
|  |         // | ||||||
|  |         // 3) double-up slashes that precede a quote, | ||||||
|  |         //    e.g.  hello \world    => "hello \world" | ||||||
|  |         //          hello\"world    => "hello\\""world" | ||||||
|  |         //          hello\\"world   => "hello\\\\""world" | ||||||
|  |         //          hello world\    => "hello world\\" | ||||||
|  |         // | ||||||
|  |         //    technically this is not required for a cmd.exe command line, or the batch argument parser. | ||||||
|  |         //    the reasons for including this as a .cmd quoting rule are: | ||||||
|  |         // | ||||||
|  |         //    a) this is optimized for the scenario where the argument is passed from the .cmd file to an | ||||||
|  |         //       external program. many programs (e.g. .NET console apps) rely on the slash-doubling rule. | ||||||
|  |         // | ||||||
|  |         //    b) it's what we've been doing previously (by deferring to node default behavior) and we | ||||||
|  |         //       haven't heard any complaints about that aspect. | ||||||
|  |         // | ||||||
|  |         // note, a weakness of the quoting rules chosen here, is that % is not escaped. in fact, % cannot be | ||||||
|  |         // escaped when used on the command line directly - even though within a .cmd file % can be escaped | ||||||
|  |         // by using %%. | ||||||
|  |         // | ||||||
|  |         // the saving grace is, on the command line, %var% is left as-is if var is not defined. this contrasts | ||||||
|  |         // the line parsing rules within a .cmd file, where if var is not defined it is replaced with nothing. | ||||||
|  |         // | ||||||
|  |         // one option that was explored was replacing % with ^% - i.e. %var% => ^%var^%. this hack would | ||||||
|  |         // often work, since it is unlikely that var^ would exist, and the ^ character is removed when the | ||||||
|  |         // variable is used. the problem, however, is that ^ is not removed when %* is used to pass the args | ||||||
|  |         // to an external program. | ||||||
|  |         // | ||||||
|  |         // an unexplored potential solution for the % escaping problem, is to create a wrapper .cmd file. | ||||||
|  |         // % can be escaped within a .cmd file. | ||||||
|  |         let reverse = '"'; | ||||||
|  |         let quoteHit = true; | ||||||
|  |         for (let i = arg.length; i > 0; i--) { | ||||||
|  |             // walk the string in reverse | ||||||
|  |             reverse += arg[i - 1]; | ||||||
|  |             if (quoteHit && arg[i - 1] === '\\') { | ||||||
|  |                 reverse += '\\'; // double the slash | ||||||
|  |             } | ||||||
|  |             else if (arg[i - 1] === '"') { | ||||||
|  |                 quoteHit = true; | ||||||
|  |                 reverse += '"'; // double the quote | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 quoteHit = false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         reverse += '"'; | ||||||
|  |         return reverse | ||||||
|  |             .split('') | ||||||
|  |             .reverse() | ||||||
|  |             .join(''); | ||||||
|  |     } | ||||||
|  |     _uvQuoteCmdArg(arg) { | ||||||
|  |         // Tool runner wraps child_process.spawn() and needs to apply the same quoting as | ||||||
|  |         // Node in certain cases where the undocumented spawn option windowsVerbatimArguments | ||||||
|  |         // is used. | ||||||
|  |         // | ||||||
|  |         // Since this function is a port of quote_cmd_arg from Node 4.x (technically, lib UV, | ||||||
|  |         // see https://github.com/nodejs/node/blob/v4.x/deps/uv/src/win/process.c for details), | ||||||
|  |         // pasting copyright notice from Node within this function: | ||||||
|  |         // | ||||||
|  |         //      Copyright Joyent, Inc. and other Node contributors. All rights reserved. | ||||||
|  |         // | ||||||
|  |         //      Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |         //      of this software and associated documentation files (the "Software"), to | ||||||
|  |         //      deal in the Software without restriction, including without limitation the | ||||||
|  |         //      rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | ||||||
|  |         //      sell copies of the Software, and to permit persons to whom the Software is | ||||||
|  |         //      furnished to do so, subject to the following conditions: | ||||||
|  |         // | ||||||
|  |         //      The above copyright notice and this permission notice shall be included in | ||||||
|  |         //      all copies or substantial portions of the Software. | ||||||
|  |         // | ||||||
|  |         //      THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |         //      IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |         //      FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |         //      AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |         //      LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||||
|  |         //      FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | ||||||
|  |         //      IN THE SOFTWARE. | ||||||
|  |         if (!arg) { | ||||||
|  |             // Need double quotation for empty argument | ||||||
|  |             return '""'; | ||||||
|  |         } | ||||||
|  |         if (!arg.includes(' ') && !arg.includes('\t') && !arg.includes('"')) { | ||||||
|  |             // No quotation needed | ||||||
|  |             return arg; | ||||||
|  |         } | ||||||
|  |         if (!arg.includes('"') && !arg.includes('\\')) { | ||||||
|  |             // No embedded double quotes or backslashes, so I can just wrap | ||||||
|  |             // quote marks around the whole thing. | ||||||
|  |             return `"${arg}"`; | ||||||
|  |         } | ||||||
|  |         // Expected input/output: | ||||||
|  |         //   input : hello"world | ||||||
|  |         //   output: "hello\"world" | ||||||
|  |         //   input : hello""world | ||||||
|  |         //   output: "hello\"\"world" | ||||||
|  |         //   input : hello\world | ||||||
|  |         //   output: hello\world | ||||||
|  |         //   input : hello\\world | ||||||
|  |         //   output: hello\\world | ||||||
|  |         //   input : hello\"world | ||||||
|  |         //   output: "hello\\\"world" | ||||||
|  |         //   input : hello\\"world | ||||||
|  |         //   output: "hello\\\\\"world" | ||||||
|  |         //   input : hello world\ | ||||||
|  |         //   output: "hello world\\" - note the comment in libuv actually reads "hello world\" | ||||||
|  |         //                             but it appears the comment is wrong, it should be "hello world\\" | ||||||
|  |         let reverse = '"'; | ||||||
|  |         let quoteHit = true; | ||||||
|  |         for (let i = arg.length; i > 0; i--) { | ||||||
|  |             // walk the string in reverse | ||||||
|  |             reverse += arg[i - 1]; | ||||||
|  |             if (quoteHit && arg[i - 1] === '\\') { | ||||||
|  |                 reverse += '\\'; | ||||||
|  |             } | ||||||
|  |             else if (arg[i - 1] === '"') { | ||||||
|  |                 quoteHit = true; | ||||||
|  |                 reverse += '\\'; | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 quoteHit = false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         reverse += '"'; | ||||||
|  |         return reverse | ||||||
|  |             .split('') | ||||||
|  |             .reverse() | ||||||
|  |             .join(''); | ||||||
|  |     } | ||||||
|  |     _cloneExecOptions(options) { | ||||||
|  |         options = options || {}; | ||||||
|  |         const result = { | ||||||
|  |             cwd: options.cwd || process.cwd(), | ||||||
|  |             env: options.env || process.env, | ||||||
|  |             silent: options.silent || false, | ||||||
|  |             windowsVerbatimArguments: options.windowsVerbatimArguments || false, | ||||||
|  |             failOnStdErr: options.failOnStdErr || false, | ||||||
|  |             ignoreReturnCode: options.ignoreReturnCode || false, | ||||||
|  |             delay: options.delay || 10000 | ||||||
|  |         }; | ||||||
|  |         result.outStream = options.outStream || process.stdout; | ||||||
|  |         result.errStream = options.errStream || process.stderr; | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |     _getSpawnOptions(options, toolPath) { | ||||||
|  |         options = options || {}; | ||||||
|  |         const result = {}; | ||||||
|  |         result.cwd = options.cwd; | ||||||
|  |         result.env = options.env; | ||||||
|  |         result['windowsVerbatimArguments'] = | ||||||
|  |             options.windowsVerbatimArguments || this._isCmdFile(); | ||||||
|  |         if (options.windowsVerbatimArguments) { | ||||||
|  |             result.argv0 = `"${toolPath}"`; | ||||||
|  |         } | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Exec a tool. | ||||||
|  |      * Output will be streamed to the live console. | ||||||
|  |      * Returns promise with return code | ||||||
|  |      * | ||||||
|  |      * @param     tool     path to tool to exec | ||||||
|  |      * @param     options  optional exec options.  See ExecOptions | ||||||
|  |      * @returns   number | ||||||
|  |      */ | ||||||
|  |     exec() { | ||||||
|  |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |             return new Promise((resolve, reject) => { | ||||||
|  |                 this._debug(`exec tool: ${this.toolPath}`); | ||||||
|  |                 this._debug('arguments:'); | ||||||
|  |                 for (const arg of this.args) { | ||||||
|  |                     this._debug(`   ${arg}`); | ||||||
|  |                 } | ||||||
|  |                 const optionsNonNull = this._cloneExecOptions(this.options); | ||||||
|  |                 if (!optionsNonNull.silent && optionsNonNull.outStream) { | ||||||
|  |                     optionsNonNull.outStream.write(this._getCommandString(optionsNonNull) + os.EOL); | ||||||
|  |                 } | ||||||
|  |                 const state = new ExecState(optionsNonNull, this.toolPath); | ||||||
|  |                 state.on('debug', (message) => { | ||||||
|  |                     this._debug(message); | ||||||
|  |                 }); | ||||||
|  |                 const fileName = this._getSpawnFileName(); | ||||||
|  |                 const cp = child.spawn(fileName, this._getSpawnArgs(optionsNonNull), this._getSpawnOptions(this.options, fileName)); | ||||||
|  |                 const stdbuffer = ''; | ||||||
|  |                 if (cp.stdout) { | ||||||
|  |                     cp.stdout.on('data', (data) => { | ||||||
|  |                         if (this.options.listeners && this.options.listeners.stdout) { | ||||||
|  |                             this.options.listeners.stdout(data); | ||||||
|  |                         } | ||||||
|  |                         if (!optionsNonNull.silent && optionsNonNull.outStream) { | ||||||
|  |                             optionsNonNull.outStream.write(data); | ||||||
|  |                         } | ||||||
|  |                         this._processLineBuffer(data, stdbuffer, (line) => { | ||||||
|  |                             if (this.options.listeners && this.options.listeners.stdline) { | ||||||
|  |                                 this.options.listeners.stdline(line); | ||||||
|  |                             } | ||||||
|  |                         }); | ||||||
|  |                     }); | ||||||
|  |                 } | ||||||
|  |                 const errbuffer = ''; | ||||||
|  |                 if (cp.stderr) { | ||||||
|  |                     cp.stderr.on('data', (data) => { | ||||||
|  |                         state.processStderr = true; | ||||||
|  |                         if (this.options.listeners && this.options.listeners.stderr) { | ||||||
|  |                             this.options.listeners.stderr(data); | ||||||
|  |                         } | ||||||
|  |                         if (!optionsNonNull.silent && | ||||||
|  |                             optionsNonNull.errStream && | ||||||
|  |                             optionsNonNull.outStream) { | ||||||
|  |                             const s = optionsNonNull.failOnStdErr | ||||||
|  |                                 ? optionsNonNull.errStream | ||||||
|  |                                 : optionsNonNull.outStream; | ||||||
|  |                             s.write(data); | ||||||
|  |                         } | ||||||
|  |                         this._processLineBuffer(data, errbuffer, (line) => { | ||||||
|  |                             if (this.options.listeners && this.options.listeners.errline) { | ||||||
|  |                                 this.options.listeners.errline(line); | ||||||
|  |                             } | ||||||
|  |                         }); | ||||||
|  |                     }); | ||||||
|  |                 } | ||||||
|  |                 cp.on('error', (err) => { | ||||||
|  |                     state.processError = err.message; | ||||||
|  |                     state.processExited = true; | ||||||
|  |                     state.processClosed = true; | ||||||
|  |                     state.CheckComplete(); | ||||||
|  |                 }); | ||||||
|  |                 cp.on('exit', (code) => { | ||||||
|  |                     state.processExitCode = code; | ||||||
|  |                     state.processExited = true; | ||||||
|  |                     this._debug(`Exit code ${code} received from tool '${this.toolPath}'`); | ||||||
|  |                     state.CheckComplete(); | ||||||
|  |                 }); | ||||||
|  |                 cp.on('close', (code) => { | ||||||
|  |                     state.processExitCode = code; | ||||||
|  |                     state.processExited = true; | ||||||
|  |                     state.processClosed = true; | ||||||
|  |                     this._debug(`STDIO streams have closed for tool '${this.toolPath}'`); | ||||||
|  |                     state.CheckComplete(); | ||||||
|  |                 }); | ||||||
|  |                 state.on('done', (error, exitCode) => { | ||||||
|  |                     if (stdbuffer.length > 0) { | ||||||
|  |                         this.emit('stdline', stdbuffer); | ||||||
|  |                     } | ||||||
|  |                     if (errbuffer.length > 0) { | ||||||
|  |                         this.emit('errline', errbuffer); | ||||||
|  |                     } | ||||||
|  |                     cp.removeAllListeners(); | ||||||
|  |                     if (error) { | ||||||
|  |                         reject(error); | ||||||
|  |                     } | ||||||
|  |                     else { | ||||||
|  |                         resolve(exitCode); | ||||||
|  |                     } | ||||||
|  |                 }); | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | exports.ToolRunner = ToolRunner; | ||||||
|  | /** | ||||||
|  |  * Convert an arg string to an array of args. Handles escaping | ||||||
|  |  * | ||||||
|  |  * @param    argString   string of arguments | ||||||
|  |  * @returns  string[]    array of arguments | ||||||
|  |  */ | ||||||
|  | function argStringToArray(argString) { | ||||||
|  |     const args = []; | ||||||
|  |     let inQuotes = false; | ||||||
|  |     let escaped = false; | ||||||
|  |     let arg = ''; | ||||||
|  |     function append(c) { | ||||||
|  |         // we only escape double quotes. | ||||||
|  |         if (escaped && c !== '"') { | ||||||
|  |             arg += '\\'; | ||||||
|  |         } | ||||||
|  |         arg += c; | ||||||
|  |         escaped = false; | ||||||
|  |     } | ||||||
|  |     for (let i = 0; i < argString.length; i++) { | ||||||
|  |         const c = argString.charAt(i); | ||||||
|  |         if (c === '"') { | ||||||
|  |             if (!escaped) { | ||||||
|  |                 inQuotes = !inQuotes; | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 append(c); | ||||||
|  |             } | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |         if (c === '\\' && escaped) { | ||||||
|  |             append(c); | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |         if (c === '\\' && inQuotes) { | ||||||
|  |             escaped = true; | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |         if (c === ' ' && !inQuotes) { | ||||||
|  |             if (arg.length > 0) { | ||||||
|  |                 args.push(arg); | ||||||
|  |                 arg = ''; | ||||||
|  |             } | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |         append(c); | ||||||
|  |     } | ||||||
|  |     if (arg.length > 0) { | ||||||
|  |         args.push(arg.trim()); | ||||||
|  |     } | ||||||
|  |     return args; | ||||||
|  | } | ||||||
|  | exports.argStringToArray = argStringToArray; | ||||||
|  | class ExecState extends events.EventEmitter { | ||||||
|  |     constructor(options, toolPath) { | ||||||
|  |         super(); | ||||||
|  |         this.processClosed = false; // tracks whether the process has exited and stdio is closed | ||||||
|  |         this.processError = ''; | ||||||
|  |         this.processExitCode = 0; | ||||||
|  |         this.processExited = false; // tracks whether the process has exited | ||||||
|  |         this.processStderr = false; // tracks whether stderr was written to | ||||||
|  |         this.delay = 10000; // 10 seconds | ||||||
|  |         this.done = false; | ||||||
|  |         this.timeout = null; | ||||||
|  |         if (!toolPath) { | ||||||
|  |             throw new Error('toolPath must not be empty'); | ||||||
|  |         } | ||||||
|  |         this.options = options; | ||||||
|  |         this.toolPath = toolPath; | ||||||
|  |         if (options.delay) { | ||||||
|  |             this.delay = options.delay; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     CheckComplete() { | ||||||
|  |         if (this.done) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (this.processClosed) { | ||||||
|  |             this._setResult(); | ||||||
|  |         } | ||||||
|  |         else if (this.processExited) { | ||||||
|  |             this.timeout = setTimeout(ExecState.HandleTimeout, this.delay, this); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     _debug(message) { | ||||||
|  |         this.emit('debug', message); | ||||||
|  |     } | ||||||
|  |     _setResult() { | ||||||
|  |         // determine whether there is an error | ||||||
|  |         let error; | ||||||
|  |         if (this.processExited) { | ||||||
|  |             if (this.processError) { | ||||||
|  |                 error = new Error(`There was an error when attempting to execute the process '${this.toolPath}'. This may indicate the process failed to start. Error: ${this.processError}`); | ||||||
|  |             } | ||||||
|  |             else if (this.processExitCode !== 0 && !this.options.ignoreReturnCode) { | ||||||
|  |                 error = new Error(`The process '${this.toolPath}' failed with exit code ${this.processExitCode}`); | ||||||
|  |             } | ||||||
|  |             else if (this.processStderr && this.options.failOnStdErr) { | ||||||
|  |                 error = new Error(`The process '${this.toolPath}' failed because one or more lines were written to the STDERR stream`); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         // clear the timeout | ||||||
|  |         if (this.timeout) { | ||||||
|  |             clearTimeout(this.timeout); | ||||||
|  |             this.timeout = null; | ||||||
|  |         } | ||||||
|  |         this.done = true; | ||||||
|  |         this.emit('done', error, this.processExitCode); | ||||||
|  |     } | ||||||
|  |     static HandleTimeout(state) { | ||||||
|  |         if (state.done) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (!state.processClosed && state.processExited) { | ||||||
|  |             const message = `The STDIO streams did not close within ${state.delay / | ||||||
|  |                 1000} seconds of the exit event from process '${state.toolPath}'. This may indicate a child process inherited the STDIO streams and has not yet exited.`; | ||||||
|  |             state._debug(message); | ||||||
|  |         } | ||||||
|  |         state._setResult(); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | //# sourceMappingURL=toolrunner.js.map | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/toolrunner.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/toolrunner.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										68
									
								
								node_modules/@actions/exec/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								node_modules/@actions/exec/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | { | ||||||
|  |   "_args": [ | ||||||
|  |     [ | ||||||
|  |       "@actions/exec@1.0.1", | ||||||
|  |       "/Users/paul/src/codeartisans/gradle-command-action" | ||||||
|  |     ] | ||||||
|  |   ], | ||||||
|  |   "_from": "@actions/exec@1.0.1", | ||||||
|  |   "_id": "@actions/exec@1.0.1", | ||||||
|  |   "_inBundle": false, | ||||||
|  |   "_integrity": "sha512-nvFkxwiicvpzNiCBF4wFBDfnBvi7xp/as7LE1hBxBxKG2L29+gkIPBiLKMVORL+Hg3JNf07AKRfl0V5djoypjQ==", | ||||||
|  |   "_location": "/@actions/exec", | ||||||
|  |   "_phantomChildren": {}, | ||||||
|  |   "_requested": { | ||||||
|  |     "type": "version", | ||||||
|  |     "registry": true, | ||||||
|  |     "raw": "@actions/exec@1.0.1", | ||||||
|  |     "name": "@actions/exec", | ||||||
|  |     "escapedName": "@actions%2fexec", | ||||||
|  |     "scope": "@actions", | ||||||
|  |     "rawSpec": "1.0.1", | ||||||
|  |     "saveSpec": null, | ||||||
|  |     "fetchSpec": "1.0.1" | ||||||
|  |   }, | ||||||
|  |   "_requiredBy": [ | ||||||
|  |     "/", | ||||||
|  |     "/@actions/tool-cache" | ||||||
|  |   ], | ||||||
|  |   "_resolved": "https://registry.npmjs.org/@actions/exec/-/exec-1.0.1.tgz", | ||||||
|  |   "_spec": "1.0.1", | ||||||
|  |   "_where": "/Users/paul/src/codeartisans/gradle-command-action", | ||||||
|  |   "bugs": { | ||||||
|  |     "url": "https://github.com/actions/toolkit/issues" | ||||||
|  |   }, | ||||||
|  |   "description": "Actions exec lib", | ||||||
|  |   "devDependencies": { | ||||||
|  |     "@actions/io": "^1.0.1" | ||||||
|  |   }, | ||||||
|  |   "directories": { | ||||||
|  |     "lib": "lib", | ||||||
|  |     "test": "__tests__" | ||||||
|  |   }, | ||||||
|  |   "files": [ | ||||||
|  |     "lib" | ||||||
|  |   ], | ||||||
|  |   "gitHead": "a2ab4bcf78e4f7080f0d45856e6eeba16f0bbc52", | ||||||
|  |   "homepage": "https://github.com/actions/toolkit/tree/master/packages/exec", | ||||||
|  |   "keywords": [ | ||||||
|  |     "github", | ||||||
|  |     "actions", | ||||||
|  |     "exec" | ||||||
|  |   ], | ||||||
|  |   "license": "MIT", | ||||||
|  |   "main": "lib/exec.js", | ||||||
|  |   "name": "@actions/exec", | ||||||
|  |   "publishConfig": { | ||||||
|  |     "access": "public" | ||||||
|  |   }, | ||||||
|  |   "repository": { | ||||||
|  |     "type": "git", | ||||||
|  |     "url": "git+https://github.com/actions/toolkit.git" | ||||||
|  |   }, | ||||||
|  |   "scripts": { | ||||||
|  |     "test": "echo \"Error: run tests from root\" && exit 1", | ||||||
|  |     "tsc": "tsc" | ||||||
|  |   }, | ||||||
|  |   "version": "1.0.1" | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								node_modules/@actions/io/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/io/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | Copyright 2019 GitHub | ||||||
|  |  | ||||||
|  | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||||
|  |  | ||||||
|  | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||||
|  |  | ||||||
|  | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user