mirror of
				https://kkgithub.com/actions/cache.git
				synced 2025-10-27 00:11:50 +08:00 
			
		
		
		
	Compare commits
	
		
			14 Commits
		
	
	
		
			tiwarishub
			...
			bishal-pdM
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8a9a57869f | |||
| fb1d96e3ff | |||
| 23d218be27 | |||
| a7c34adf76 | |||
| 83394c99b7 | |||
| e839c25979 | |||
| 33a923d660 | |||
| a404368986 | |||
| f4278025ab | |||
| 9916fe1701 | |||
| 318935ef66 | |||
| 85efbb58b9 | |||
| 4387dbc81a | |||
| a0e530f115 | 
							
								
								
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,6 +1,6 @@ | ||||
| --- | ||||
| name: "@actions/cache" | ||||
| version: 3.0.0 | ||||
| version: 3.0.3 | ||||
| type: npm | ||||
| summary:  | ||||
| homepage:  | ||||
|  | ||||
							
								
								
									
										23
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								README.md
									
									
									
									
									
								
							| @ -15,6 +15,9 @@ See ["Caching dependencies to speed up workflows"](https://help.github.com/githu | ||||
| * Updated the minimum runner version support from node 12 -> node 16. | ||||
| * Fixed avoiding empty cache save when no files are available for caching. | ||||
| * Fixed tar creation error while trying to create tar with path as `~/` home folder on `ubuntu-latest`. | ||||
| * Fixed zstd failing on amazon linux 2.0 runners | ||||
| * Fixed cache not working with github workspace directory or current directory | ||||
| * Fixed the download stuck problem by introducing a timeout of 1 hour for cache downloads. | ||||
|  | ||||
| Refer [here](https://github.com/actions/cache/blob/v2/README.md) for previous versions | ||||
|  | ||||
| @ -81,6 +84,7 @@ Every programming language and framework has its own way of caching. | ||||
| See [Examples](examples.md) for a list of `actions/cache` implementations for use with: | ||||
|  | ||||
| - [C# - NuGet](./examples.md#c---nuget) | ||||
| - [Clojure - Lein Deps](./examples.md#clojure---lein-deps) | ||||
| - [D - DUB](./examples.md#d---dub) | ||||
| - [Deno](./examples.md#deno) | ||||
| - [Elixir - Mix](./examples.md#elixir---mix) | ||||
| @ -215,6 +219,25 @@ jobs: | ||||
|         run: ./generate-primes -d prime-numbers | ||||
| ``` | ||||
|  | ||||
| ## Known practices and workarounds | ||||
| Following are some of the known practices/workarounds which community has used to fulfill specific requirements. You may choose to use them if suits your use case. Note these are not necessarily the only or the recommended solution. | ||||
|  | ||||
| #### Update a cache | ||||
| A cache today is immutable and cannot be updated. But some use cases require the cache to be saved even though there was a "hit" during restore. To do so, use a `key` which is unique for every run and use `restore-keys` to restore the nearest cache. For example: | ||||
|   ``` | ||||
|       - name: update cache on every commit | ||||
|         uses: actions/cache@v3 | ||||
|         with: | ||||
|           path: prime-numbers | ||||
|           key: primes-${{ runner.os }}-${{ github.run_id }} # Can use time based key as well | ||||
|           restore-keys: | | ||||
|             primes-${{ runner.os }} | ||||
|   ```           | ||||
|   Please note that this will create a new cache on every run and hence will consume the cache [quota](#cache-limits). | ||||
|    | ||||
| #### Use cache across feature branches | ||||
| Reusing cache across feature branches is not allowed today to provide cache [isolation](https://docs.github.com/en/actions/using-workflows/caching-dependencies-to-speed-up-workflows#restrictions-for-accessing-a-cache). However if both feature branches are from the default branch, a good way to achieve this is to ensure that the default branch has a cache. This cache will then be consumable by both feature branches. | ||||
|  | ||||
| ## Contributing | ||||
| We would love for you to contribute to `actions/cache`, pull requests are welcome! Please see the [CONTRIBUTING.md](CONTRIBUTING.md) for more information. | ||||
|  | ||||
|  | ||||
| @ -17,4 +17,11 @@ | ||||
| - Fixed tar creation error while trying to create tar with path as `~/` home folder on `ubuntu-latest`. ([issue](https://github.com/actions/cache/issues/689)) | ||||
|  | ||||
| ### 3.0.5 | ||||
| - Removed error handling by consuming actions/cache 3.0 toolkit, Now cache server error handling will be done by toolkit. ([PR](https://github.com/actions/cache/pull/834)) | ||||
| - Removed error handling by consuming actions/cache 3.0 toolkit, Now cache server error handling will be done by toolkit. ([PR](https://github.com/actions/cache/pull/834)) | ||||
|  | ||||
| ### 3.0.6 | ||||
| - Fixed [#809](https://github.com/actions/cache/issues/809) - zstd -d: no such file or directory error | ||||
| - Fixed [#833](https://github.com/actions/cache/issues/833) - cache doesn't work with github workspace directory | ||||
|  | ||||
| ### 3.0.7 | ||||
| - Fixed [#810](https://github.com/actions/cache/issues/810) - download stuck issue. A new timeout is introduced in the download process to abort the download if it gets stuck and doesn't finish within an hour. | ||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										45
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							| @ -5470,10 +5470,10 @@ const buffer = __importStar(__webpack_require__(293)); | ||||
| const fs = __importStar(__webpack_require__(747)); | ||||
| const stream = __importStar(__webpack_require__(794)); | ||||
| const util = __importStar(__webpack_require__(669)); | ||||
| const timer = __importStar(__webpack_require__(581)); | ||||
| const utils = __importStar(__webpack_require__(15)); | ||||
| const constants_1 = __webpack_require__(931); | ||||
| const requestUtils_1 = __webpack_require__(899); | ||||
| const abort_controller_1 = __webpack_require__(106); | ||||
| /** | ||||
|  * Pipes the body of a HTTP response to a stream | ||||
|  * | ||||
| @ -5657,19 +5657,24 @@ function downloadCacheStorageSDK(archiveLocation, archivePath, options) { | ||||
|             const fd = fs.openSync(archivePath, 'w'); | ||||
|             try { | ||||
|                 downloadProgress.startDisplayTimer(); | ||||
|                 const controller = new abort_controller_1.AbortController(); | ||||
|                 const abortSignal = controller.signal; | ||||
|                 while (!downloadProgress.isDone()) { | ||||
|                     const segmentStart = downloadProgress.segmentOffset + downloadProgress.segmentSize; | ||||
|                     const segmentSize = Math.min(maxSegmentSize, contentLength - segmentStart); | ||||
|                     downloadProgress.nextSegment(segmentSize); | ||||
|                     const result = yield Promise.race([client.downloadToBuffer(segmentStart, segmentSize, { | ||||
|                             concurrency: options.downloadConcurrency, | ||||
|                             onProgress: downloadProgress.onProgress() | ||||
|                         }), | ||||
|                         timer.setTimeout(60 * 60 * 1000, 'timeout')]); | ||||
|                     const result = yield promiseWithTimeout(options.segmentTimeoutInMs || 3600000, client.downloadToBuffer(segmentStart, segmentSize, { | ||||
|                         abortSignal, | ||||
|                         concurrency: options.downloadConcurrency, | ||||
|                         onProgress: downloadProgress.onProgress() | ||||
|                     })); | ||||
|                     if (result === 'timeout') { | ||||
|                         throw new Error("Segment download timed out"); | ||||
|                         controller.abort(); | ||||
|                         throw new Error('Aborting cache download as the download time exceeded the timeout.'); | ||||
|                     } | ||||
|                     else if (Buffer.isBuffer(result)) { | ||||
|                         fs.writeFileSync(fd, result); | ||||
|                     } | ||||
|                     fs.writeFileSync(fd, result); | ||||
|                 } | ||||
|             } | ||||
|             finally { | ||||
| @ -5680,6 +5685,16 @@ function downloadCacheStorageSDK(archiveLocation, archivePath, options) { | ||||
|     }); | ||||
| } | ||||
| exports.downloadCacheStorageSDK = downloadCacheStorageSDK; | ||||
| const promiseWithTimeout = (timeoutMs, promise) => __awaiter(void 0, void 0, void 0, function* () { | ||||
|     let timeoutHandle; | ||||
|     const timeoutPromise = new Promise(resolve => { | ||||
|         timeoutHandle = setTimeout(() => resolve('timeout'), timeoutMs); | ||||
|     }); | ||||
|     return Promise.race([promise, timeoutPromise]).then(result => { | ||||
|         clearTimeout(timeoutHandle); | ||||
|         return result; | ||||
|     }); | ||||
| }); | ||||
| //# sourceMappingURL=downloadUtils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -40800,7 +40815,8 @@ function getDownloadOptions(copy) { | ||||
|     const result = { | ||||
|         useAzureSdk: true, | ||||
|         downloadConcurrency: 8, | ||||
|         timeoutInMs: 30000 | ||||
|         timeoutInMs: 30000, | ||||
|         segmentTimeoutInMs: 3600000 | ||||
|     }; | ||||
|     if (copy) { | ||||
|         if (typeof copy.useAzureSdk === 'boolean') { | ||||
| @ -40812,10 +40828,14 @@ function getDownloadOptions(copy) { | ||||
|         if (typeof copy.timeoutInMs === 'number') { | ||||
|             result.timeoutInMs = copy.timeoutInMs; | ||||
|         } | ||||
|         if (typeof copy.segmentTimeoutInMs === 'number') { | ||||
|             result.segmentTimeoutInMs = copy.segmentTimeoutInMs; | ||||
|         } | ||||
|     } | ||||
|     core.debug(`Use Azure SDK: ${result.useAzureSdk}`); | ||||
|     core.debug(`Download concurrency: ${result.downloadConcurrency}`); | ||||
|     core.debug(`Request timeout (ms): ${result.timeoutInMs}`); | ||||
|     core.debug(`Segment download timeout (ms): ${result.segmentTimeoutInMs}`); | ||||
|     return result; | ||||
| } | ||||
| exports.getDownloadOptions = getDownloadOptions; | ||||
| @ -42354,12 +42374,7 @@ function clean(key) | ||||
| /* 578 */, | ||||
| /* 579 */, | ||||
| /* 580 */, | ||||
| /* 581 */ | ||||
| /***/ (function(module) { | ||||
| 
 | ||||
| module.exports = require("timers/promises"); | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 581 */, | ||||
| /* 582 */ | ||||
| /***/ (function(module) { | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										45
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							| @ -5470,10 +5470,10 @@ const buffer = __importStar(__webpack_require__(293)); | ||||
| const fs = __importStar(__webpack_require__(747)); | ||||
| const stream = __importStar(__webpack_require__(794)); | ||||
| const util = __importStar(__webpack_require__(669)); | ||||
| const timer = __importStar(__webpack_require__(581)); | ||||
| const utils = __importStar(__webpack_require__(15)); | ||||
| const constants_1 = __webpack_require__(931); | ||||
| const requestUtils_1 = __webpack_require__(899); | ||||
| const abort_controller_1 = __webpack_require__(106); | ||||
| /** | ||||
|  * Pipes the body of a HTTP response to a stream | ||||
|  * | ||||
| @ -5657,19 +5657,24 @@ function downloadCacheStorageSDK(archiveLocation, archivePath, options) { | ||||
|             const fd = fs.openSync(archivePath, 'w'); | ||||
|             try { | ||||
|                 downloadProgress.startDisplayTimer(); | ||||
|                 const controller = new abort_controller_1.AbortController(); | ||||
|                 const abortSignal = controller.signal; | ||||
|                 while (!downloadProgress.isDone()) { | ||||
|                     const segmentStart = downloadProgress.segmentOffset + downloadProgress.segmentSize; | ||||
|                     const segmentSize = Math.min(maxSegmentSize, contentLength - segmentStart); | ||||
|                     downloadProgress.nextSegment(segmentSize); | ||||
|                     const result = yield Promise.race([client.downloadToBuffer(segmentStart, segmentSize, { | ||||
|                             concurrency: options.downloadConcurrency, | ||||
|                             onProgress: downloadProgress.onProgress() | ||||
|                         }), | ||||
|                         timer.setTimeout(60 * 60 * 1000, 'timeout')]); | ||||
|                     const result = yield promiseWithTimeout(options.segmentTimeoutInMs || 3600000, client.downloadToBuffer(segmentStart, segmentSize, { | ||||
|                         abortSignal, | ||||
|                         concurrency: options.downloadConcurrency, | ||||
|                         onProgress: downloadProgress.onProgress() | ||||
|                     })); | ||||
|                     if (result === 'timeout') { | ||||
|                         throw new Error("Segment download timed out"); | ||||
|                         controller.abort(); | ||||
|                         throw new Error('Aborting cache download as the download time exceeded the timeout.'); | ||||
|                     } | ||||
|                     else if (Buffer.isBuffer(result)) { | ||||
|                         fs.writeFileSync(fd, result); | ||||
|                     } | ||||
|                     fs.writeFileSync(fd, result); | ||||
|                 } | ||||
|             } | ||||
|             finally { | ||||
| @ -5680,6 +5685,16 @@ function downloadCacheStorageSDK(archiveLocation, archivePath, options) { | ||||
|     }); | ||||
| } | ||||
| exports.downloadCacheStorageSDK = downloadCacheStorageSDK; | ||||
| const promiseWithTimeout = (timeoutMs, promise) => __awaiter(void 0, void 0, void 0, function* () { | ||||
|     let timeoutHandle; | ||||
|     const timeoutPromise = new Promise(resolve => { | ||||
|         timeoutHandle = setTimeout(() => resolve('timeout'), timeoutMs); | ||||
|     }); | ||||
|     return Promise.race([promise, timeoutPromise]).then(result => { | ||||
|         clearTimeout(timeoutHandle); | ||||
|         return result; | ||||
|     }); | ||||
| }); | ||||
| //# sourceMappingURL=downloadUtils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -40800,7 +40815,8 @@ function getDownloadOptions(copy) { | ||||
|     const result = { | ||||
|         useAzureSdk: true, | ||||
|         downloadConcurrency: 8, | ||||
|         timeoutInMs: 30000 | ||||
|         timeoutInMs: 30000, | ||||
|         segmentTimeoutInMs: 3600000 | ||||
|     }; | ||||
|     if (copy) { | ||||
|         if (typeof copy.useAzureSdk === 'boolean') { | ||||
| @ -40812,10 +40828,14 @@ function getDownloadOptions(copy) { | ||||
|         if (typeof copy.timeoutInMs === 'number') { | ||||
|             result.timeoutInMs = copy.timeoutInMs; | ||||
|         } | ||||
|         if (typeof copy.segmentTimeoutInMs === 'number') { | ||||
|             result.segmentTimeoutInMs = copy.segmentTimeoutInMs; | ||||
|         } | ||||
|     } | ||||
|     core.debug(`Use Azure SDK: ${result.useAzureSdk}`); | ||||
|     core.debug(`Download concurrency: ${result.downloadConcurrency}`); | ||||
|     core.debug(`Request timeout (ms): ${result.timeoutInMs}`); | ||||
|     core.debug(`Segment download timeout (ms): ${result.segmentTimeoutInMs}`); | ||||
|     return result; | ||||
| } | ||||
| exports.getDownloadOptions = getDownloadOptions; | ||||
| @ -42354,12 +42374,7 @@ function clean(key) | ||||
| /* 578 */, | ||||
| /* 579 */, | ||||
| /* 580 */, | ||||
| /* 581 */ | ||||
| /***/ (function(module) { | ||||
| 
 | ||||
| module.exports = require("timers/promises"); | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 581 */, | ||||
| /* 582 */ | ||||
| /***/ (function(module) { | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										14
									
								
								examples.md
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								examples.md
									
									
									
									
									
								
							| @ -1,6 +1,7 @@ | ||||
| # Examples | ||||
|  | ||||
| - [C# - NuGet](#c---nuget) | ||||
| - [Clojure - Lein Deps](#clojure---lein-deps) | ||||
| - [D - DUB](#d---dub) | ||||
|   - [POSIX](#posix) | ||||
|   - [Windows](#windows) | ||||
| @ -80,6 +81,19 @@ steps: | ||||
|         ${{ runner.os }}-nuget- | ||||
| ``` | ||||
|  | ||||
| ## Clojure - Lein Deps | ||||
|  | ||||
| ```yaml | ||||
| - name: Cache lein project dependencies | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~/.m2/repository | ||||
|     key: ${{ runner.os }}-clojure-${{ hashFiles('**/project.clj') }} | ||||
|     restore-keys: | | ||||
|       ${{ runner.os }}-clojure | ||||
| ``` | ||||
|  | ||||
|  | ||||
| ## D - DUB | ||||
|  | ||||
| ### POSIX | ||||
|  | ||||
							
								
								
									
										18
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										18
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -1,15 +1,15 @@ | ||||
| { | ||||
|   "name": "cache", | ||||
|   "version": "3.0.5", | ||||
|   "version": "3.0.7", | ||||
|   "lockfileVersion": 2, | ||||
|   "requires": true, | ||||
|   "packages": { | ||||
|     "": { | ||||
|       "name": "cache", | ||||
|       "version": "3.0.5", | ||||
|       "version": "3.0.7", | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "@actions/cache": "file:actions-cache-3.0.1.tgz", | ||||
|         "@actions/cache": "^3.0.3", | ||||
|         "@actions/core": "^1.7.0", | ||||
|         "@actions/exec": "^1.1.1", | ||||
|         "@actions/io": "^1.1.2" | ||||
| @ -36,10 +36,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@actions/cache": { | ||||
|       "version": "3.0.1", | ||||
|       "resolved": "file:actions-cache-3.0.1.tgz", | ||||
|       "integrity": "sha512-ucvw0xvFpe0/vfNQ/rc11ste0nidCdBAJ5j5F01BxBqjxmGH2doVzfPlqSIGhcN7wKI074x2ATb9+7HSrTqGHg==", | ||||
|       "license": "MIT", | ||||
|       "version": "3.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.0.3.tgz", | ||||
|       "integrity": "sha512-kn0pZRQNFRg1IQnW/N7uTNbbLqYalvQW2bmrznn3C34LMY/rSuEmH6Uo69HDh335Q0vKs9kg/jsIarzUBKzEXg==", | ||||
|       "dependencies": { | ||||
|         "@actions/core": "^1.2.6", | ||||
|         "@actions/exec": "^1.0.1", | ||||
| @ -9534,8 +9533,9 @@ | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@actions/cache": { | ||||
|       "version": "file:actions-cache-3.0.1.tgz", | ||||
|       "integrity": "sha512-ucvw0xvFpe0/vfNQ/rc11ste0nidCdBAJ5j5F01BxBqjxmGH2doVzfPlqSIGhcN7wKI074x2ATb9+7HSrTqGHg==", | ||||
|       "version": "3.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.0.3.tgz", | ||||
|       "integrity": "sha512-kn0pZRQNFRg1IQnW/N7uTNbbLqYalvQW2bmrznn3C34LMY/rSuEmH6Uo69HDh335Q0vKs9kg/jsIarzUBKzEXg==", | ||||
|       "requires": { | ||||
|         "@actions/core": "^1.2.6", | ||||
|         "@actions/exec": "^1.0.1", | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "cache", | ||||
|   "version": "3.0.5", | ||||
|   "version": "3.0.7", | ||||
|   "private": true, | ||||
|   "description": "Cache dependencies and build outputs", | ||||
|   "main": "dist/restore/index.js", | ||||
| @ -23,7 +23,7 @@ | ||||
|   "author": "GitHub", | ||||
|   "license": "MIT", | ||||
|   "dependencies": { | ||||
|     "@actions/cache": "file:actions-cache-3.0.1.tgz", | ||||
|     "@actions/cache": "^3.0.3", | ||||
|     "@actions/core": "^1.7.0", | ||||
|     "@actions/exec": "^1.1.1", | ||||
|     "@actions/io": "^1.1.2" | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	