mirror of
https://github.com/astral-sh/setup-uv.git
synced 2025-01-23 02:22:49 +08:00
9b71657bb2
Copied from https://github.com/actions/cache/pull/1217
65 lines
1.6 KiB
TypeScript
65 lines
1.6 KiB
TypeScript
import * as cache from "@actions/cache";
|
|
import * as core from "@actions/core";
|
|
import * as exec from "@actions/exec";
|
|
import {
|
|
STATE_CACHE_MATCHED_KEY,
|
|
STATE_CACHE_KEY,
|
|
} from "./cache/restore-cache";
|
|
import {
|
|
cacheLocalPath,
|
|
enableCache,
|
|
pruneCache as shouldPruneCache,
|
|
} from "./utils/inputs";
|
|
|
|
export async function run(): Promise<void> {
|
|
try {
|
|
if (enableCache) {
|
|
await saveCache();
|
|
}
|
|
} catch (error) {
|
|
const err = error as Error;
|
|
core.setFailed(err.message);
|
|
}
|
|
// node will stay alive if any promises are not resolved,
|
|
// which is a possibility if HTTP requests are dangling
|
|
// due to retries or timeouts. We know that if we got here
|
|
// that all promises that we care about have successfully
|
|
// resolved, so simply exit with success.
|
|
process.exit(0);
|
|
}
|
|
|
|
async function saveCache(): Promise<void> {
|
|
const cacheKey = core.getState(STATE_CACHE_KEY);
|
|
const matchedKey = core.getState(STATE_CACHE_MATCHED_KEY);
|
|
|
|
if (!cacheKey) {
|
|
core.warning("Error retrieving cache key from state.");
|
|
return;
|
|
}
|
|
if (matchedKey === cacheKey) {
|
|
core.info(`Cache hit occurred on key ${cacheKey}, not saving cache.`);
|
|
return;
|
|
}
|
|
|
|
if (shouldPruneCache) {
|
|
await pruneCache();
|
|
}
|
|
|
|
core.info(`Saving cache path: ${cacheLocalPath}`);
|
|
await cache.saveCache([cacheLocalPath], cacheKey);
|
|
|
|
core.info(`cache saved with the key: ${cacheKey}`);
|
|
}
|
|
|
|
async function pruneCache(): Promise<void> {
|
|
const options: exec.ExecOptions = {
|
|
silent: !core.isDebug(),
|
|
};
|
|
const execArgs = ["cache", "prune", "--ci"];
|
|
|
|
core.info("Pruning cache...");
|
|
await exec.exec("uv", execArgs, options);
|
|
}
|
|
|
|
run();
|