Allow job-summary only on failure
Instead of a binary true/false option, it is now possible to only add a Job Summary when the build failed. This applies both to the overall Job Summary added to the workflow run, and to the new PR comment feature.
This commit is contained in:
		
							parent
							
								
									34a07dced0
								
							
						
					
					
						commit
						333078158e
					
				
							
								
								
									
										23
									
								
								.github/workflows/demo-job-summary.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/demo-job-summary.yml
									
									
									
									
										vendored
									
									
								
							| @ -8,7 +8,7 @@ env: | |||||||
|   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
| 
 | 
 | ||||||
| jobs: | jobs: | ||||||
|   run-gradle-builds: |   many-gradle-builds: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout sources |     - name: Checkout sources | ||||||
| @ -42,6 +42,27 @@ jobs: | |||||||
|       continue-on-error: true |       continue-on-error: true | ||||||
|       run: ./gradlew not-a-real-task |       run: ./gradlew not-a-real-task | ||||||
| 
 | 
 | ||||||
|  |   successful-builds-with-no-summary: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v4 | ||||||
|  |     - name: Build distribution | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         npm install | ||||||
|  |         npm run build | ||||||
|  |     - 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: |   pre-existing-gradle-home: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|  | |||||||
							
								
								
									
										33
									
								
								.github/workflows/demo-pr-build-scan-comment.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										33
									
								
								.github/workflows/demo-pr-build-scan-comment.yml
									
									
									
									
										vendored
									
									
								
							| @ -3,7 +3,7 @@ on: | |||||||
|   pull_request: |   pull_request: | ||||||
|     types: [assigned, review_requested] |     types: [assigned, review_requested] | ||||||
| jobs: | jobs: | ||||||
|   gradle: |   successful-build-with-always-comment: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout project sources |     - name: Checkout project sources | ||||||
| @ -11,8 +11,37 @@ jobs: | |||||||
|     - name: Setup Gradle |     - name: Setup Gradle | ||||||
|       uses: ./ |       uses: ./ | ||||||
|       with: |       with: | ||||||
|         add-pr-comment: true |         add-job-summary-as-pr-comment: always | ||||||
|     - name: Run build with Gradle wrapper |     - name: Run build with Gradle wrapper | ||||||
|       id: gradle |       id: gradle | ||||||
|       working-directory: .github/workflow-samples/kotlin-dsl |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|       run: ./gradlew build --scan |       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 | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								action.yml
									
									
									
									
									
								
							| @ -58,15 +58,15 @@ inputs: | |||||||
|     required: false |     required: false | ||||||
|     default: false |     default: false | ||||||
| 
 | 
 | ||||||
|   generate-job-summary: |   add-job-summary: | ||||||
|     description: When 'false', no Job Summary will be generated for the Job. |     description: Specifies when a Job Summary should be inluded in the action results. Valid values are 'never', 'always' (default), and 'on-failure'. | ||||||
|     required: false |     required: false | ||||||
|     default: true |     default: 'always' | ||||||
| 
 | 
 | ||||||
|   add-pr-comment: |   add-job-summary-as-pr-comment: | ||||||
|     description: When 'true', a summary of the Gradle builds will be added as a PR comment. No action will be taken if the workflow was not triggered from a pull request. |     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 |     required: false | ||||||
|     default: false |     default: 'never' | ||||||
| 
 | 
 | ||||||
|   dependency-graph: |   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' and 'download-and-submit'. |     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' and 'download-and-submit'. | ||||||
| @ -93,6 +93,12 @@ inputs: | |||||||
|     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. See https://github.com/gradle/gradle-build-action?tab=readme-ov-file#use-the-action-to-setup-gradle.  |     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. See https://github.com/gradle/gradle-build-action?tab=readme-ov-file#use-the-action-to-setup-gradle.  | ||||||
| 
 | 
 | ||||||
|  |   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. | ||||||
|  | 
 | ||||||
|   # EXPERIMENTAL & INTERNAL ACTION INPUTS |   # EXPERIMENTAL & INTERNAL ACTION INPUTS | ||||||
|   # The following action properties allow fine-grained tweaking of the action caching behaviour. |   # 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 `gradle-build-action`. |   # These properties are experimental and not (yet) designed for production use, and may change without notice in a subsequent release of `gradle-build-action`. | ||||||
|  | |||||||
| @ -71,12 +71,25 @@ export function isJobSummaryEnabled(): boolean { | |||||||
|     return getBooleanInput('generate-job-summary', true) |     return getBooleanInput('generate-job-summary', true) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export function isPRCommentEnabled(): boolean { | export function getJobSummaryOption(): JobSummaryOption { | ||||||
|     return getBooleanInput('add-pr-comment', false) |     return parseJobSummaryOption('add-job-summary') | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export function isDependencyGraphEnabled(): boolean { | export function getPRCommentOption(): JobSummaryOption { | ||||||
|     return getBooleanInput('generate-dependency-graph', true) |     return parseJobSummaryOption('add-job-summary-as-pr-comment') | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function parseJobSummaryOption(paramName: string): JobSummaryOption { | ||||||
|  |     const val = core.getInput(paramName) | ||||||
|  |     switch (val.toLowerCase().trim()) { | ||||||
|  |         case 'never': | ||||||
|  |             return JobSummaryOption.Never | ||||||
|  |         case 'always': | ||||||
|  |             return JobSummaryOption.Always | ||||||
|  |         case 'on-failure': | ||||||
|  |             return JobSummaryOption.OnFailure | ||||||
|  |     } | ||||||
|  |     throw TypeError(`The value '${val}' is not valid for ${paramName}. Valid values are: [never, always, on-failure].`) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export function getDependencyGraphOption(): DependencyGraphOption { | export function getDependencyGraphOption(): DependencyGraphOption { | ||||||
| @ -94,7 +107,7 @@ export function getDependencyGraphOption(): DependencyGraphOption { | |||||||
|             return DependencyGraphOption.DownloadAndSubmit |             return DependencyGraphOption.DownloadAndSubmit | ||||||
|     } |     } | ||||||
|     throw TypeError( |     throw TypeError( | ||||||
|         `The value '${val} is not valid for 'dependency-graph. Valid values are: [disabled, generate, generate-and-submit, generate-and-upload, download-and-submit]. The default value is 'disabled'.` |         `The value '${val}' is not valid for 'dependency-graph'. Valid values are: [disabled, generate, generate-and-submit, generate-and-upload, download-and-submit]. The default value is 'disabled'.` | ||||||
|     ) |     ) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -135,3 +148,9 @@ export enum DependencyGraphOption { | |||||||
|     GenerateAndUpload = 'generate-and-upload', |     GenerateAndUpload = 'generate-and-upload', | ||||||
|     DownloadAndSubmit = 'download-and-submit' |     DownloadAndSubmit = 'download-and-submit' | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | export enum JobSummaryOption { | ||||||
|  |     Never = 'never', | ||||||
|  |     Always = 'always', | ||||||
|  |     OnFailure = 'on-failure' | ||||||
|  | } | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ export async function generateJobSummary(buildResults: BuildResult[], cacheListe | |||||||
|     const summaryTable = renderSummaryTable(buildResults) |     const summaryTable = renderSummaryTable(buildResults) | ||||||
|     const cachingReport = generateCachingReport(cacheListener) |     const cachingReport = generateCachingReport(cacheListener) | ||||||
| 
 | 
 | ||||||
|     if (shouldGenerateJobSummary()) { |     if (shouldGenerateJobSummary(buildResults)) { | ||||||
|         core.info('Generating Job Summary') |         core.info('Generating Job Summary') | ||||||
| 
 | 
 | ||||||
|         core.summary.addRaw(summaryTable) |         core.summary.addRaw(summaryTable) | ||||||
| @ -24,7 +24,7 @@ export async function generateJobSummary(buildResults: BuildResult[], cacheListe | |||||||
|         core.info('============================') |         core.info('============================') | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (shouldAddPRComment()) { |     if (shouldAddPRComment(buildResults)) { | ||||||
|         await addPRComment(summaryTable) |         await addPRComment(summaryTable) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -111,15 +111,32 @@ function renderBuildScanBadge(outcomeText: string, outcomeColor: string, targetU | |||||||
|     return `<a href="${targetUrl}" rel="nofollow">${badgeHtml}</a>` |     return `<a href="${targetUrl}" rel="nofollow">${badgeHtml}</a>` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function shouldGenerateJobSummary(): boolean { | function shouldGenerateJobSummary(buildResults: BuildResult[]): boolean { | ||||||
|     // Check if Job Summary is supported on this platform
 |     // Check if Job Summary is supported on this platform
 | ||||||
|     if (!process.env[SUMMARY_ENV_VAR]) { |     if (!process.env[SUMMARY_ENV_VAR]) { | ||||||
|         return false |         return false | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return params.isJobSummaryEnabled() |     // Check if Job Summary is disabled using the deprecated input
 | ||||||
|  |     if (!params.isJobSummaryEnabled()) { | ||||||
|  |         return false | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return shouldAddJobSummary(params.getJobSummaryOption(), buildResults) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function shouldAddPRComment(): boolean { | function shouldAddPRComment(buildResults: BuildResult[]): boolean { | ||||||
|     return params.isPRCommentEnabled() |     return shouldAddJobSummary(params.getPRCommentOption(), buildResults) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function shouldAddJobSummary(option: params.JobSummaryOption, buildResults: BuildResult[]): boolean { | ||||||
|  |     switch (option) { | ||||||
|  |         case params.JobSummaryOption.Always: | ||||||
|  |             return true | ||||||
|  |         case params.JobSummaryOption.Never: | ||||||
|  |             return false | ||||||
|  |         case params.JobSummaryOption.OnFailure: | ||||||
|  |             core.info(`Got these build results: ${JSON.stringify(buildResults)}`) | ||||||
|  |             return buildResults.some(result => result.buildFailed) | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user