mirror of
https://github.com/Swatinem/rust-cache
synced 2025-04-05 21:24:07 +00:00
support working-directory input, cleanup
This commit is contained in:
parent
fb2efae33d
commit
9e10a44ea3
|
@ -1,5 +1,11 @@
|
||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## 1.1.0
|
||||||
|
|
||||||
|
- Add a new `working-directory` input.
|
||||||
|
- Support caching git dependencies.
|
||||||
|
- Lots of other improvements.
|
||||||
|
|
||||||
## 1.0.2
|
## 1.0.2
|
||||||
|
|
||||||
- Don’t prune targets that have a different name from the crate, but do prune targets from the workspace.
|
- Don’t prune targets that have a different name from the crate, but do prune targets from the workspace.
|
||||||
|
|
18
README.md
18
README.md
|
@ -6,10 +6,26 @@ sensible defaults.
|
||||||
## Example usage
|
## Example usage
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
|
# selecting a toolchain either by action or manual `rustup` calls should happen
|
||||||
|
# before the plugin, as it uses the current rustc version as its cache key
|
||||||
|
- uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
|
||||||
- uses: Swatinem/rust-cache@v1
|
- uses: Swatinem/rust-cache@v1
|
||||||
```
|
```
|
||||||
|
|
||||||
### Cache Details
|
## Inputs
|
||||||
|
|
||||||
|
: `key`
|
||||||
|
An optional key that is added to the automatic cache key.
|
||||||
|
|
||||||
|
: `working-directory`
|
||||||
|
The working directory the action operates in, is case the cargo project is not
|
||||||
|
located in the repo root.
|
||||||
|
|
||||||
|
## Cache Details
|
||||||
|
|
||||||
The cache currently caches the following directories:
|
The cache currently caches the following directories:
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,9 @@ inputs:
|
||||||
key:
|
key:
|
||||||
description: "An additional key for the cache"
|
description: "An additional key for the cache"
|
||||||
required: false
|
required: false
|
||||||
|
working-directory:
|
||||||
|
description: "The working directory this action should operate in"
|
||||||
|
required: false
|
||||||
runs:
|
runs:
|
||||||
using: "node12"
|
using: "node12"
|
||||||
main: "dist/restore/index.js"
|
main: "dist/restore/index.js"
|
||||||
|
|
|
@ -11,6 +11,11 @@ process.on("uncaughtException", (e) => {
|
||||||
core.info(`[warning] ${e.message}`);
|
core.info(`[warning] ${e.message}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const cwd = core.getInput("working-directory");
|
||||||
|
if (cwd) {
|
||||||
|
process.chdir(cwd);
|
||||||
|
}
|
||||||
|
|
||||||
export const stateKey = "RUST_CACHE_KEY";
|
export const stateKey = "RUST_CACHE_KEY";
|
||||||
const stateHash = "RUST_CACHE_HASH";
|
const stateHash = "RUST_CACHE_HASH";
|
||||||
|
|
||||||
|
@ -196,11 +201,13 @@ export async function rmExcept(dirName: string, keepPrefix: Set<string>) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function rm(parent: string, dirent: fs.Dirent) {
|
export async function rm(parent: string, dirent: fs.Dirent) {
|
||||||
const fileName = path.join(parent, dirent.name);
|
try {
|
||||||
core.debug(`deleting "${fileName}"`);
|
const fileName = path.join(parent, dirent.name);
|
||||||
if (dirent.isFile()) {
|
core.debug(`deleting "${fileName}"`);
|
||||||
await fs.promises.unlink(fileName);
|
if (dirent.isFile()) {
|
||||||
} else if (dirent.isDirectory()) {
|
await fs.promises.unlink(fileName);
|
||||||
await io.rmRF(fileName);
|
} else if (dirent.isDirectory()) {
|
||||||
}
|
await io.rmRF(fileName);
|
||||||
|
}
|
||||||
|
} catch {}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,42 +1,28 @@
|
||||||
import * as cache from "@actions/cache";
|
import * as cache from "@actions/cache";
|
||||||
import * as core from "@actions/core";
|
import * as core from "@actions/core";
|
||||||
import { cleanTarget, getCacheConfig, getPackages, isValidEvent, stateKey } from "./common";
|
import { cleanTarget, getCacheConfig, getPackages, stateKey } from "./common";
|
||||||
|
|
||||||
async function run() {
|
async function run() {
|
||||||
if (!isValidEvent()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
core.exportVariable("CARGO_INCREMENTAL", 0);
|
core.exportVariable("CARGO_INCREMENTAL", 0);
|
||||||
|
|
||||||
const start = Date.now();
|
|
||||||
const { paths, key, restoreKeys } = await getCacheConfig();
|
const { paths, key, restoreKeys } = await getCacheConfig();
|
||||||
|
|
||||||
core.info(`Restoring paths:\n ${paths.join("\n ")}`);
|
core.info(`Restoring paths:\n ${paths.join("\n ")}`);
|
||||||
core.info(`Using keys:\n ${[key, ...restoreKeys].join("\n ")}`);
|
core.info(`Using keys:\n ${[key, ...restoreKeys].join("\n ")}`);
|
||||||
try {
|
const restoreKey = await cache.restoreCache(paths, key, restoreKeys);
|
||||||
const restoreKey = await cache.restoreCache(paths, key, restoreKeys);
|
if (restoreKey) {
|
||||||
if (restoreKey) {
|
core.info(`Restored from cache key "${restoreKey}".`);
|
||||||
core.info(`Restored from cache key "${restoreKey}".`);
|
core.saveState(stateKey, restoreKey);
|
||||||
core.saveState(stateKey, restoreKey);
|
|
||||||
|
|
||||||
if (restoreKey !== key) {
|
if (restoreKey !== key) {
|
||||||
// pre-clean the target directory on cache mismatch
|
// pre-clean the target directory on cache mismatch
|
||||||
const packages = await getPackages();
|
const packages = await getPackages();
|
||||||
|
|
||||||
await cleanTarget(packages);
|
await cleanTarget(packages);
|
||||||
}
|
|
||||||
} else {
|
|
||||||
core.info("No cache found.");
|
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} else {
|
||||||
core.info(`[warning] ${e.message}`);
|
core.info("No cache found.");
|
||||||
}
|
|
||||||
|
|
||||||
const duration = Math.round((Date.now() - start) / 1000);
|
|
||||||
if (duration) {
|
|
||||||
core.info(`Took ${duration}s.`);
|
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
core.info(`[warning] ${e.message}`);
|
core.info(`[warning] ${e.message}`);
|
||||||
|
|
18
src/save.ts
18
src/save.ts
|
@ -5,15 +5,10 @@ import * as glob from "@actions/glob";
|
||||||
import * as io from "@actions/io";
|
import * as io from "@actions/io";
|
||||||
import fs from "fs";
|
import fs from "fs";
|
||||||
import path from "path";
|
import path from "path";
|
||||||
import { cleanTarget, getCacheConfig, getPackages, isValidEvent, Packages, paths, rm, stateKey } from "./common";
|
import { cleanTarget, getCacheConfig, getPackages, Packages, paths, rm, stateKey } from "./common";
|
||||||
|
|
||||||
async function run() {
|
async function run() {
|
||||||
if (!isValidEvent()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const start = Date.now();
|
|
||||||
const { paths: savePaths, key } = await getCacheConfig();
|
const { paths: savePaths, key } = await getCacheConfig();
|
||||||
|
|
||||||
if (core.getState(stateKey) === key) {
|
if (core.getState(stateKey) === key) {
|
||||||
|
@ -41,16 +36,7 @@ async function run() {
|
||||||
|
|
||||||
core.info(`Saving paths:\n ${savePaths.join("\n ")}`);
|
core.info(`Saving paths:\n ${savePaths.join("\n ")}`);
|
||||||
core.info(`Using key "${key}".`);
|
core.info(`Using key "${key}".`);
|
||||||
try {
|
await cache.saveCache(savePaths, key);
|
||||||
await cache.saveCache(savePaths, key);
|
|
||||||
} catch (e) {
|
|
||||||
core.info(`[warning] ${e.message}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
const duration = Math.round((Date.now() - start) / 1000);
|
|
||||||
if (duration) {
|
|
||||||
core.info(`Took ${duration}s.`);
|
|
||||||
}
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
core.info(`[warning] ${e.message}`);
|
core.info(`[warning] ${e.message}`);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue