2019-10-30 19:48:49 +01:00
|
|
|
import * as core from "@actions/core";
|
|
|
|
import * as path from "path";
|
2020-03-18 14:35:13 +01:00
|
|
|
|
2019-10-30 19:48:49 +01:00
|
|
|
import * as cacheHttpClient from "./cacheHttpClient";
|
2020-04-22 22:36:34 +02:00
|
|
|
import { Events, Inputs, State } from "./constants";
|
2019-12-13 23:24:37 +01:00
|
|
|
import { createTar } from "./tar";
|
2019-10-30 19:48:49 +01:00
|
|
|
import * as utils from "./utils/actionUtils";
|
|
|
|
|
2019-11-12 22:48:02 +01:00
|
|
|
async function run(): Promise<void> {
|
2019-10-30 19:48:49 +01:00
|
|
|
try {
|
2019-11-21 20:37:54 +01:00
|
|
|
if (!utils.isValidEvent()) {
|
|
|
|
utils.logWarning(
|
|
|
|
`Event Validation Error: The event type ${
|
|
|
|
process.env[Events.Key]
|
|
|
|
} is not supported. Only ${utils
|
|
|
|
.getSupportedEvents()
|
|
|
|
.join(", ")} events are supported at this time.`
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-10-30 19:48:49 +01:00
|
|
|
const state = utils.getCacheState();
|
|
|
|
|
|
|
|
// Inputs are re-evaluted before the post action, so we want the original key used for restore
|
|
|
|
const primaryKey = core.getState(State.CacheKey);
|
|
|
|
if (!primaryKey) {
|
2019-11-21 20:37:54 +01:00
|
|
|
utils.logWarning(`Error retrieving key from state.`);
|
2019-10-30 19:48:49 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (utils.isExactKeyMatch(primaryKey, state)) {
|
|
|
|
core.info(
|
|
|
|
`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-04-22 22:36:34 +02:00
|
|
|
const compressionMethod = await utils.getCompressionMethod();
|
|
|
|
|
2020-01-06 19:05:50 +01:00
|
|
|
core.debug("Reserving Cache");
|
2020-04-22 22:36:34 +02:00
|
|
|
const cacheId = await cacheHttpClient.reserveCache(primaryKey, {
|
|
|
|
compressionMethod: compressionMethod
|
|
|
|
});
|
2020-01-06 19:05:50 +01:00
|
|
|
if (cacheId == -1) {
|
|
|
|
core.info(
|
|
|
|
`Unable to reserve cache with key ${primaryKey}, another job may be creating this cache.`
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
core.debug(`Cache ID: ${cacheId}`);
|
2020-03-20 21:02:11 +01:00
|
|
|
const cachePaths = await utils.resolvePaths(
|
|
|
|
core
|
|
|
|
.getInput(Inputs.Path, { required: true })
|
|
|
|
.split("\n")
|
|
|
|
.filter(x => x !== "")
|
2019-10-30 19:48:49 +01:00
|
|
|
);
|
|
|
|
|
2020-03-20 21:02:11 +01:00
|
|
|
core.debug("Cache Paths:");
|
|
|
|
core.debug(`${JSON.stringify(cachePaths)}`);
|
|
|
|
|
|
|
|
const archiveFolder = await utils.createTempDirectory();
|
2020-04-22 22:36:34 +02:00
|
|
|
const archivePath = path.join(
|
|
|
|
archiveFolder,
|
|
|
|
utils.getCacheFileName(compressionMethod)
|
|
|
|
);
|
|
|
|
|
2019-10-30 19:48:49 +01:00
|
|
|
core.debug(`Archive Path: ${archivePath}`);
|
|
|
|
|
2020-04-22 22:36:34 +02:00
|
|
|
await createTar(archiveFolder, cachePaths, compressionMethod);
|
2019-10-30 19:48:49 +01:00
|
|
|
|
2020-02-01 22:11:02 +01:00
|
|
|
const fileSizeLimit = 5 * 1024 * 1024 * 1024; // 5GB per repo limit
|
2019-11-14 23:14:16 +01:00
|
|
|
const archiveFileSize = utils.getArchiveFileSize(archivePath);
|
2019-10-30 19:48:49 +01:00
|
|
|
core.debug(`File Size: ${archiveFileSize}`);
|
|
|
|
if (archiveFileSize > fileSizeLimit) {
|
2019-11-21 20:37:54 +01:00
|
|
|
utils.logWarning(
|
2019-11-13 17:00:46 +01:00
|
|
|
`Cache size of ~${Math.round(
|
|
|
|
archiveFileSize / (1024 * 1024)
|
2020-02-01 22:11:02 +01:00
|
|
|
)} MB (${archiveFileSize} B) is over the 5GB limit, not saving cache.`
|
2019-10-30 19:48:49 +01:00
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-01-06 19:05:50 +01:00
|
|
|
core.debug(`Saving Cache (ID: ${cacheId})`);
|
|
|
|
await cacheHttpClient.saveCache(cacheId, archivePath);
|
2019-10-30 19:48:49 +01:00
|
|
|
} catch (error) {
|
2019-11-21 20:37:54 +01:00
|
|
|
utils.logWarning(error.message);
|
2019-10-30 19:48:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
run();
|
|
|
|
|
|
|
|
export default run;
|