1
0
Fork 0
mirror of https://code.forgejo.org/actions/cache.git synced 2025-04-05 05:47:48 +02:00

Added logic fo saving cache on any failure

This commit is contained in:
Sankalp Kotewar 2022-11-21 08:35:34 +00:00 committed by GitHub
parent d3ebc46a6f
commit 885d768356
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 22 additions and 2 deletions

View file

@ -4948,6 +4948,7 @@ var Inputs;
Inputs["RestoreKeys"] = "restore-keys";
Inputs["UploadChunkSize"] = "upload-chunk-size";
Inputs["StrictRestore"] = "strict-restore";
Inputs["SaveCacheOnAnyFailure"] = "save-cache-on-any-failure";
})(Inputs = exports.Inputs || (exports.Inputs = {}));
var Outputs;
(function (Outputs) {
@ -4957,6 +4958,7 @@ var State;
(function (State) {
State["CachePrimaryKey"] = "CACHE_KEY";
State["CacheMatchedKey"] = "CACHE_RESULT";
State["SaveCache"] = "SAVE_CACHE";
})(State = exports.State || (exports.State = {}));
var Events;
(function (Events) {
@ -49003,6 +49005,11 @@ function run() {
throw new Error(`Restored cache key doesn't match the given input key ${primaryKey}, hence exiting the workflow as the strict-restore requirement is not met.`);
}
core.info(`Cache restored from key: ${cacheKey}`);
const saveCache = core.getInput(constants_1.Inputs.SaveCacheOnAnyFailure);
if (saveCache === "yes") {
core.saveState(constants_1.State.SaveCache, saveCache);
core.info(`Input save-cache-on-any-failure is set to yes, the cache will be saved despite of any failure in the build.`);
}
}
catch (error) {
core.setFailed(error.message);

2
dist/save/index.js vendored
View file

@ -4948,6 +4948,7 @@ var Inputs;
Inputs["RestoreKeys"] = "restore-keys";
Inputs["UploadChunkSize"] = "upload-chunk-size";
Inputs["StrictRestore"] = "strict-restore";
Inputs["SaveCacheOnAnyFailure"] = "save-cache-on-any-failure";
})(Inputs = exports.Inputs || (exports.Inputs = {}));
var Outputs;
(function (Outputs) {
@ -4957,6 +4958,7 @@ var State;
(function (State) {
State["CachePrimaryKey"] = "CACHE_KEY";
State["CacheMatchedKey"] = "CACHE_RESULT";
State["SaveCache"] = "SAVE_CACHE";
})(State = exports.State || (exports.State = {}));
var Events;
(function (Events) {

View file

@ -3,7 +3,8 @@ export enum Inputs {
Path = "path",
RestoreKeys = "restore-keys",
UploadChunkSize = "upload-chunk-size",
StrictRestore = "strict-restore"
StrictRestore = "strict-restore",
SaveCacheOnAnyFailure = "save-cache-on-any-failure"
}
export enum Outputs {
@ -12,7 +13,8 @@ export enum Outputs {
export enum State {
CachePrimaryKey = "CACHE_KEY",
CacheMatchedKey = "CACHE_RESULT"
CacheMatchedKey = "CACHE_RESULT",
SaveCache = "SAVE_CACHE"
}
export enum Events {

View file

@ -63,6 +63,15 @@ async function run(): Promise<void> {
);
}
core.info(`Cache restored from key: ${cacheKey}`);
const saveCache = core.getInput(Inputs.SaveCacheOnAnyFailure);
if (saveCache === "yes") {
core.saveState(State.SaveCache, saveCache);
core.info(
`Input save-cache-on-any-failure is set to yes, the cache will be saved despite of any failure in the build.`
);
}
} catch (error: unknown) {
core.setFailed((error as Error).message);
}