mirror of
				https://github.com/actions/cache.git
				synced 2025-10-31 10:24:19 +08:00 
			
		
		
		
	 0da99ad140
			
		
	
	
		0da99ad140
		
			
		
	
	
	
	
		
			
			* Create CODE_OF_CONDUCT.md * Update workflow (#1) * Run workflow on linux, mac, and windows * Add status badge * Use npm install instead * Bump typescript version * Use node 12.x * Add Ruby Gem example (#4) * Add Cocoapods example (#5) * Add Carthage example (#10) * Move examples to their own page (#13) * Minor typo in README (#15) from `steps.[ID].outupts.cache-hit` to `steps.[ID].outputs.cache-hit` * Update README.md * Prevent commands from executing during tests (#21) * Prevent commands from executing during tests * Add newline at end of file * Drop all commands from output * Link to NuGet lock files documentation (#20) * Add trailing dash to Maven fallback key (#19) * Fix README.md (#25) `restore-keys` had incorrect indentation. * Exclude documentation from CI tests (#28) * Ignore all .md files * Add note about time-based eviction to README (#30) * Fix typo in error message (#29) * Time based eviction interval is 1 week (#34) * Remove cache checksum debug - close #24 (#26) * Remove cache checksum debug - close #24 * Remove cache checksum debug on save * Fix formatting * Add Go modules example (#18) * Add Go modules example * Fix TOC * Fix repo name in contact email (#41) * Add Elixir Mix example (#42) * Add Elixir Mix example * Fix typo * Add cargo example for Rust project (#8) * Add cargo example * Add hash of Cargo.lock to keys of caches * Move Rust example to examples.md * Stop warning when cache is not found (#40) The cache not being found is a common situation so very visible warning is a little too much. * Bump package version * Release v0.0.2
		
			
				
	
	
		
			77 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import * as core from "@actions/core";
 | |
| import { exec } from "@actions/exec";
 | |
| 
 | |
| import * as io from "@actions/io";
 | |
| import * as fs from "fs";
 | |
| import * as path from "path";
 | |
| 
 | |
| import * as cacheHttpClient from "./cacheHttpClient";
 | |
| import { Inputs, State } from "./constants";
 | |
| import * as utils from "./utils/actionUtils";
 | |
| 
 | |
| async function run() {
 | |
|     try {
 | |
|         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) {
 | |
|             core.warning(`Error retrieving key from state.`);
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         if (utils.isExactKeyMatch(primaryKey, state)) {
 | |
|             core.info(
 | |
|                 `Cache hit occurred on the primary key ${primaryKey}, not saving cache.`
 | |
|             );
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         let cachePath = utils.resolvePath(
 | |
|             core.getInput(Inputs.Path, { required: true })
 | |
|         );
 | |
|         core.debug(`Cache Path: ${cachePath}`);
 | |
| 
 | |
|         let archivePath = path.join(
 | |
|             await utils.createTempDirectory(),
 | |
|             "cache.tgz"
 | |
|         );
 | |
|         core.debug(`Archive Path: ${archivePath}`);
 | |
| 
 | |
|         // http://man7.org/linux/man-pages/man1/tar.1.html
 | |
|         // tar [-options] <name of the tar archive> [files or directories which to add into archive]
 | |
|         const args = ["-cz"];
 | |
|         const IS_WINDOWS = process.platform === "win32";
 | |
|         if (IS_WINDOWS) {
 | |
|             args.push("--force-local");
 | |
|             archivePath = archivePath.replace(/\\/g, "/");
 | |
|             cachePath = cachePath.replace(/\\/g, "/");
 | |
|         }
 | |
| 
 | |
|         args.push(...["-f", archivePath, "-C", cachePath, "."]);
 | |
| 
 | |
|         const tarPath = await io.which("tar", true);
 | |
|         core.debug(`Tar Path: ${tarPath}`);
 | |
|         await exec(`"${tarPath}"`, args);
 | |
| 
 | |
|         const fileSizeLimit = 200 * 1024 * 1024; // 200MB
 | |
|         const archiveFileSize = fs.statSync(archivePath).size;
 | |
|         core.debug(`File Size: ${archiveFileSize}`);
 | |
|         if (archiveFileSize > fileSizeLimit) {
 | |
|             core.warning(
 | |
|                 `Cache size of ${archiveFileSize} bytes is over the 200MB limit, not saving cache.`
 | |
|             );
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         const stream = fs.createReadStream(archivePath);
 | |
|         await cacheHttpClient.saveCache(stream, primaryKey);
 | |
|     } catch (error) {
 | |
|         core.warning(error.message);
 | |
|     }
 | |
| }
 | |
| 
 | |
| run();
 | |
| 
 | |
| export default run;
 |