mirror of
https://github.com/gradle/gradle-build-action.git
synced 2024-11-25 01:31:06 -05:00
42452daeb5
When using the `@actions/cache` library to save cache entries, it seems that one or more Promises remain unresolved after the save completes. With Node20 this causes a delay when exiting the process: the default behaviour now wait for these Promises to complete. Adding an explicit `Process.exit()` removes the delay, returning to the Node 16 behaviour. Fixes #1038
35 lines
1.2 KiB
TypeScript
35 lines
1.2 KiB
TypeScript
import * as core from '@actions/core'
|
|
import * as setupGradle from './setup-gradle'
|
|
import {PostActionJobFailure} from './errors'
|
|
|
|
// Catch and log any unhandled exceptions. These exceptions can leak out of the uploadChunk method in
|
|
// @actions/toolkit when a failed upload closes the file descriptor causing any in-process reads to
|
|
// throw an uncaught exception. Instead of failing this action, just warn.
|
|
process.on('uncaughtException', e => handleFailure(e))
|
|
|
|
/**
|
|
* The post-execution entry point for the action, called by Github Actions after completing all steps for the Job.
|
|
*/
|
|
export async function run(): Promise<void> {
|
|
try {
|
|
await setupGradle.complete()
|
|
} catch (error) {
|
|
if (error instanceof PostActionJobFailure) {
|
|
core.setFailed(String(error))
|
|
} else {
|
|
handleFailure(error)
|
|
}
|
|
}
|
|
|
|
// Explicit process.exit() to prevent waiting for promises left hanging by `@actions/cache` on save.
|
|
process.exit()
|
|
}
|
|
|
|
function handleFailure(error: unknown): void {
|
|
core.warning(`Unhandled error in Gradle post-action - job will continue: ${error}`)
|
|
if (error instanceof Error && error.stack) {
|
|
core.info(error.stack)
|
|
}
|
|
}
|
|
|
|
run()
|