3
0
Fork 0
mirror of https://github.com/Swatinem/rust-cache synced 2025-04-05 21:24:07 +00:00

avoid calling cargo metadata on pre-cleanup

This commit is contained in:
Arpad Borsos 2022-11-03 11:26:22 +01:00
parent 19c46583c5
commit 3f2513fdf4
No known key found for this signature in database
GPG key ID: 570F20163159CB55
6 changed files with 63 additions and 40 deletions

View file

@ -1,5 +1,9 @@
# Changelog # Changelog
## 2.0.2
- Avoid calling `cargo metadata` on pre-cleanup.
## 2.0.1 ## 2.0.1
- Primarily just updating dependencies to fix GitHub deprecation notices. - Primarily just updating dependencies to fix GitHub deprecation notices.

32
dist/restore/index.js vendored
View file

@ -64476,6 +64476,7 @@ async function getCmdOutput(cmd, args = [], options = {}) {
;// CONCATENATED MODULE: ./src/workspace.ts ;// CONCATENATED MODULE: ./src/workspace.ts
const SAVE_TARGETS = new Set(["lib", "proc-macro"]); const SAVE_TARGETS = new Set(["lib", "proc-macro"]);
class Workspace { class Workspace {
constructor(root, target) { constructor(root, target) {
@ -64485,9 +64486,11 @@ class Workspace {
async getPackages() { async getPackages() {
let packages = []; let packages = [];
try { try {
lib_core.debug(`collecting metadata for "${this.root}"`);
const meta = JSON.parse(await getCmdOutput("cargo", ["metadata", "--all-features", "--format-version", "1"], { const meta = JSON.parse(await getCmdOutput("cargo", ["metadata", "--all-features", "--format-version", "1"], {
cwd: this.root, cwd: this.root,
})); }));
lib_core.debug(`workspace "${this.root}" has ${meta.packages.length} packages`);
for (const pkg of meta.packages) { for (const pkg of meta.packages) {
if (pkg.manifest_path.startsWith(this.root)) { if (pkg.manifest_path.startsWith(this.root)) {
continue; continue;
@ -64840,30 +64843,34 @@ async function cleanGit(packages) {
} }
const ONE_WEEK = 7 * 24 * 3600 * 1000; const ONE_WEEK = 7 * 24 * 3600 * 1000;
/** /**
* Removes all files or directories in `dirName`, except the ones matching * Removes all files or directories in `dirName` matching some criteria.
* any string in the `keepPrefix` set.
*
* The matching strips and trailing `-$hash` suffix.
* *
* When the `checkTimestamp` flag is set, this will also remove anything older * When the `checkTimestamp` flag is set, this will also remove anything older
* than one week. * than one week.
*
* Otherwise, it will remove everything that does not match any string in the
* `keepPrefix` set.
* The matching strips and trailing `-$hash` suffix.
*/ */
async function rmExcept(dirName, keepPrefix, checkTimestamp = false) { async function rmExcept(dirName, keepPrefix, checkTimestamp = false) {
const dir = await external_fs_default().promises.opendir(dirName); const dir = await external_fs_default().promises.opendir(dirName);
for await (const dirent of dir) { for await (const dirent of dir) {
if (checkTimestamp) {
const fileName = external_path_default().join(dir.path, dirent.name);
const { mtime } = await external_fs_default().promises.stat(fileName);
const isOutdated = Date.now() - mtime.getTime() > ONE_WEEK;
if (isOutdated) {
await rm(dir.path, dirent);
}
return;
}
let name = dirent.name; let name = dirent.name;
// strip the trailing hash // strip the trailing hash
const idx = name.lastIndexOf("-"); const idx = name.lastIndexOf("-");
if (idx !== -1) { if (idx !== -1) {
name = name.slice(0, idx); name = name.slice(0, idx);
} }
let isOutdated = false; if (!keepPrefix.has(name)) {
if (checkTimestamp) {
const fileName = external_path_default().join(dir.path, dirent.name);
const { mtime } = await external_fs_default().promises.stat(fileName);
isOutdated = Date.now() - mtime.getTime() > ONE_WEEK;
}
if (!keepPrefix.has(name) || isOutdated) {
await rm(dir.path, dirent); await rm(dir.path, dirent);
} }
} }
@ -64933,8 +64940,7 @@ async function run() {
// pre-clean the target directory on cache mismatch // pre-clean the target directory on cache mismatch
for (const workspace of config.workspaces) { for (const workspace of config.workspaces) {
try { try {
const packages = await workspace.getPackages(); await cleanTargetDir(workspace.target, [], true);
await cleanTargetDir(workspace.target, packages, true);
} }
catch { } catch { }
} }

29
dist/save/index.js vendored
View file

@ -64476,6 +64476,7 @@ async function getCmdOutput(cmd, args = [], options = {}) {
;// CONCATENATED MODULE: ./src/workspace.ts ;// CONCATENATED MODULE: ./src/workspace.ts
const SAVE_TARGETS = new Set(["lib", "proc-macro"]); const SAVE_TARGETS = new Set(["lib", "proc-macro"]);
class Workspace { class Workspace {
constructor(root, target) { constructor(root, target) {
@ -64485,9 +64486,11 @@ class Workspace {
async getPackages() { async getPackages() {
let packages = []; let packages = [];
try { try {
core.debug(`collecting metadata for "${this.root}"`);
const meta = JSON.parse(await getCmdOutput("cargo", ["metadata", "--all-features", "--format-version", "1"], { const meta = JSON.parse(await getCmdOutput("cargo", ["metadata", "--all-features", "--format-version", "1"], {
cwd: this.root, cwd: this.root,
})); }));
core.debug(`workspace "${this.root}" has ${meta.packages.length} packages`);
for (const pkg of meta.packages) { for (const pkg of meta.packages) {
if (pkg.manifest_path.startsWith(this.root)) { if (pkg.manifest_path.startsWith(this.root)) {
continue; continue;
@ -64840,30 +64843,34 @@ async function cleanGit(packages) {
} }
const ONE_WEEK = 7 * 24 * 3600 * 1000; const ONE_WEEK = 7 * 24 * 3600 * 1000;
/** /**
* Removes all files or directories in `dirName`, except the ones matching * Removes all files or directories in `dirName` matching some criteria.
* any string in the `keepPrefix` set.
*
* The matching strips and trailing `-$hash` suffix.
* *
* When the `checkTimestamp` flag is set, this will also remove anything older * When the `checkTimestamp` flag is set, this will also remove anything older
* than one week. * than one week.
*
* Otherwise, it will remove everything that does not match any string in the
* `keepPrefix` set.
* The matching strips and trailing `-$hash` suffix.
*/ */
async function rmExcept(dirName, keepPrefix, checkTimestamp = false) { async function rmExcept(dirName, keepPrefix, checkTimestamp = false) {
const dir = await external_fs_default().promises.opendir(dirName); const dir = await external_fs_default().promises.opendir(dirName);
for await (const dirent of dir) { for await (const dirent of dir) {
if (checkTimestamp) {
const fileName = external_path_default().join(dir.path, dirent.name);
const { mtime } = await external_fs_default().promises.stat(fileName);
const isOutdated = Date.now() - mtime.getTime() > ONE_WEEK;
if (isOutdated) {
await rm(dir.path, dirent);
}
return;
}
let name = dirent.name; let name = dirent.name;
// strip the trailing hash // strip the trailing hash
const idx = name.lastIndexOf("-"); const idx = name.lastIndexOf("-");
if (idx !== -1) { if (idx !== -1) {
name = name.slice(0, idx); name = name.slice(0, idx);
} }
let isOutdated = false; if (!keepPrefix.has(name)) {
if (checkTimestamp) {
const fileName = external_path_default().join(dir.path, dirent.name);
const { mtime } = await external_fs_default().promises.stat(fileName);
isOutdated = Date.now() - mtime.getTime() > ONE_WEEK;
}
if (!keepPrefix.has(name) || isOutdated) {
await rm(dir.path, dirent); await rm(dir.path, dirent);
} }
} }

View file

@ -180,17 +180,29 @@ export async function cleanGit(packages: Packages) {
const ONE_WEEK = 7 * 24 * 3600 * 1000; const ONE_WEEK = 7 * 24 * 3600 * 1000;
/** /**
* Removes all files or directories in `dirName`, except the ones matching * Removes all files or directories in `dirName` matching some criteria.
* any string in the `keepPrefix` set. *
*
* The matching strips and trailing `-$hash` suffix.
*
* When the `checkTimestamp` flag is set, this will also remove anything older * When the `checkTimestamp` flag is set, this will also remove anything older
* than one week. * than one week.
*
* Otherwise, it will remove everything that does not match any string in the
* `keepPrefix` set.
* The matching strips and trailing `-$hash` suffix.
*/ */
async function rmExcept(dirName: string, keepPrefix: Set<string>, checkTimestamp = false) { async function rmExcept(dirName: string, keepPrefix: Set<string>, checkTimestamp = false) {
const dir = await fs.promises.opendir(dirName); const dir = await fs.promises.opendir(dirName);
for await (const dirent of dir) { for await (const dirent of dir) {
if (checkTimestamp) {
const fileName = path.join(dir.path, dirent.name);
const { mtime } = await fs.promises.stat(fileName);
const isOutdated = Date.now() - mtime.getTime() > ONE_WEEK;
if (isOutdated) {
await rm(dir.path, dirent);
}
return;
}
let name = dirent.name; let name = dirent.name;
// strip the trailing hash // strip the trailing hash
@ -199,14 +211,7 @@ async function rmExcept(dirName: string, keepPrefix: Set<string>, checkTimestamp
name = name.slice(0, idx); name = name.slice(0, idx);
} }
let isOutdated = false; if (!keepPrefix.has(name)) {
if (checkTimestamp) {
const fileName = path.join(dir.path, dirent.name);
const { mtime } = await fs.promises.stat(fileName);
isOutdated = Date.now() - mtime.getTime() > ONE_WEEK;
}
if (!keepPrefix.has(name) || isOutdated) {
await rm(dir.path, dirent); await rm(dir.path, dirent);
} }
} }

View file

@ -43,9 +43,7 @@ async function run() {
// pre-clean the target directory on cache mismatch // pre-clean the target directory on cache mismatch
for (const workspace of config.workspaces) { for (const workspace of config.workspaces) {
try { try {
const packages = await workspace.getPackages(); await cleanTargetDir(workspace.target, [], true);
await cleanTargetDir(workspace.target, packages, true);
} catch {} } catch {}
} }
} }

View file

@ -1,3 +1,4 @@
import * as core from "@actions/core";
import path from "path"; import path from "path";
import { getCmdOutput } from "./utils"; import { getCmdOutput } from "./utils";
@ -10,11 +11,13 @@ export class Workspace {
public async getPackages(): Promise<Packages> { public async getPackages(): Promise<Packages> {
let packages: Packages = []; let packages: Packages = [];
try { try {
core.debug(`collecting metadata for "${this.root}"`);
const meta: Meta = JSON.parse( const meta: Meta = JSON.parse(
await getCmdOutput("cargo", ["metadata", "--all-features", "--format-version", "1"], { await getCmdOutput("cargo", ["metadata", "--all-features", "--format-version", "1"], {
cwd: this.root, cwd: this.root,
}), }),
); );
core.debug(`workspace "${this.root}" has ${meta.packages.length} packages`);
for (const pkg of meta.packages) { for (const pkg of meta.packages) {
if (pkg.manifest_path.startsWith(this.root)) { if (pkg.manifest_path.startsWith(this.root)) {
continue; continue;