mirror of
				https://github.com/actions/cache.git
				synced 2025-10-31 18:34:19 +08:00 
			
		
		
		
	Fix zstd breaking after new version release
This commit is contained in:
		
							parent
							
								
									7d4d6f7ffd
								
							
						
					
					
						commit
						b1db4b4897
					
				| @ -31,6 +31,7 @@ See ["Caching dependencies to speed up workflows"](https://docs.github.com/en/ac | |||||||
| * New actions are available for granular control over caches - [restore](restore/action.yml) and [save](save/action.yml). | * New actions are available for granular control over caches - [restore](restore/action.yml) and [save](save/action.yml). | ||||||
| * Support cross-os caching as an opt-in feature. See [Cross OS caching](./tips-and-workarounds.md#cross-os-cache) for more info. | * Support cross-os caching as an opt-in feature. See [Cross OS caching](./tips-and-workarounds.md#cross-os-cache) for more info. | ||||||
| * Added option to fail job on cache miss. See [Exit workflow on cache miss](./restore/README.md#exit-workflow-on-cache-miss) for more info. | * Added option to fail job on cache miss. See [Exit workflow on cache miss](./restore/README.md#exit-workflow-on-cache-miss) for more info. | ||||||
|  | * Fix zstd not being used after zstd version upgrade to 1.5.4 on hosted runners | ||||||
| 
 | 
 | ||||||
| See the [v2 README.md](https://github.com/actions/cache/blob/v2/README.md) for older updates. | See the [v2 README.md](https://github.com/actions/cache/blob/v2/README.md) for older updates. | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -73,3 +73,6 @@ | |||||||
| 
 | 
 | ||||||
| ### 3.2.5 | ### 3.2.5 | ||||||
| - Added fix to prevent from setting MYSYS environment variable globally. | - Added fix to prevent from setting MYSYS environment variable globally. | ||||||
|  | 
 | ||||||
|  | ### 3.2.6 | ||||||
|  | - Fix zstd not being used after zstd version upgrade to 1.5.4 on hosted runners. | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								dist/restore-only/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								dist/restore-only/index.js
									
									
									
									
										vendored
									
									
								
							| @ -1152,12 +1152,13 @@ function unlinkFile(filePath) { | |||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.unlinkFile = unlinkFile; | exports.unlinkFile = unlinkFile; | ||||||
| function getVersion(app) { | function getVersion(app, additionalArgs = []) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         core.debug(`Checking ${app} --version`); |  | ||||||
|         let versionOutput = ''; |         let versionOutput = ''; | ||||||
|  |         additionalArgs.push('--version'); | ||||||
|  |         core.debug(`Checking ${app} ${additionalArgs.join(' ')}`); | ||||||
|         try { |         try { | ||||||
|             yield exec.exec(`${app} --version`, [], { |             yield exec.exec(`${app}`, additionalArgs, { | ||||||
|                 ignoreReturnCode: true, |                 ignoreReturnCode: true, | ||||||
|                 silent: true, |                 silent: true, | ||||||
|                 listeners: { |                 listeners: { | ||||||
| @ -1177,19 +1178,14 @@ function getVersion(app) { | |||||||
| // Use zstandard if possible to maximize cache performance
 | // Use zstandard if possible to maximize cache performance
 | ||||||
| function getCompressionMethod() { | function getCompressionMethod() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const versionOutput = yield getVersion('zstd'); |         const versionOutput = yield getVersion('zstd', ['--quiet']); | ||||||
|         const version = semver.clean(versionOutput); |         const version = semver.clean(versionOutput); | ||||||
|         if (!versionOutput.toLowerCase().includes('zstd command line interface')) { |         core.debug(`zstd version: ${version}`); | ||||||
|             // zstd is not installed
 |         if (versionOutput === '') { | ||||||
|             return constants_1.CompressionMethod.Gzip; |             return constants_1.CompressionMethod.Gzip; | ||||||
|         } |         } | ||||||
|         else if (!version || semver.lt(version, 'v1.3.2')) { |  | ||||||
|             // zstd is installed but using a version earlier than v1.3.2
 |  | ||||||
|             // v1.3.2 is required to use the `--long` options in zstd
 |  | ||||||
|             return constants_1.CompressionMethod.ZstdWithoutLong; |  | ||||||
|         } |  | ||||||
|         else { |         else { | ||||||
|             return constants_1.CompressionMethod.Zstd; |             return constants_1.CompressionMethod.ZstdWithoutLong; | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							| @ -1152,12 +1152,13 @@ function unlinkFile(filePath) { | |||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.unlinkFile = unlinkFile; | exports.unlinkFile = unlinkFile; | ||||||
| function getVersion(app) { | function getVersion(app, additionalArgs = []) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         core.debug(`Checking ${app} --version`); |  | ||||||
|         let versionOutput = ''; |         let versionOutput = ''; | ||||||
|  |         additionalArgs.push('--version'); | ||||||
|  |         core.debug(`Checking ${app} ${additionalArgs.join(' ')}`); | ||||||
|         try { |         try { | ||||||
|             yield exec.exec(`${app} --version`, [], { |             yield exec.exec(`${app}`, additionalArgs, { | ||||||
|                 ignoreReturnCode: true, |                 ignoreReturnCode: true, | ||||||
|                 silent: true, |                 silent: true, | ||||||
|                 listeners: { |                 listeners: { | ||||||
| @ -1177,19 +1178,14 @@ function getVersion(app) { | |||||||
| // Use zstandard if possible to maximize cache performance
 | // Use zstandard if possible to maximize cache performance
 | ||||||
| function getCompressionMethod() { | function getCompressionMethod() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const versionOutput = yield getVersion('zstd'); |         const versionOutput = yield getVersion('zstd', ['--quiet']); | ||||||
|         const version = semver.clean(versionOutput); |         const version = semver.clean(versionOutput); | ||||||
|         if (!versionOutput.toLowerCase().includes('zstd command line interface')) { |         core.debug(`zstd version: ${version}`); | ||||||
|             // zstd is not installed
 |         if (versionOutput === '') { | ||||||
|             return constants_1.CompressionMethod.Gzip; |             return constants_1.CompressionMethod.Gzip; | ||||||
|         } |         } | ||||||
|         else if (!version || semver.lt(version, 'v1.3.2')) { |  | ||||||
|             // zstd is installed but using a version earlier than v1.3.2
 |  | ||||||
|             // v1.3.2 is required to use the `--long` options in zstd
 |  | ||||||
|             return constants_1.CompressionMethod.ZstdWithoutLong; |  | ||||||
|         } |  | ||||||
|         else { |         else { | ||||||
|             return constants_1.CompressionMethod.Zstd; |             return constants_1.CompressionMethod.ZstdWithoutLong; | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								dist/save-only/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								dist/save-only/index.js
									
									
									
									
										vendored
									
									
								
							| @ -1208,12 +1208,13 @@ function unlinkFile(filePath) { | |||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.unlinkFile = unlinkFile; | exports.unlinkFile = unlinkFile; | ||||||
| function getVersion(app) { | function getVersion(app, additionalArgs = []) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         core.debug(`Checking ${app} --version`); |  | ||||||
|         let versionOutput = ''; |         let versionOutput = ''; | ||||||
|  |         additionalArgs.push('--version'); | ||||||
|  |         core.debug(`Checking ${app} ${additionalArgs.join(' ')}`); | ||||||
|         try { |         try { | ||||||
|             yield exec.exec(`${app} --version`, [], { |             yield exec.exec(`${app}`, additionalArgs, { | ||||||
|                 ignoreReturnCode: true, |                 ignoreReturnCode: true, | ||||||
|                 silent: true, |                 silent: true, | ||||||
|                 listeners: { |                 listeners: { | ||||||
| @ -1233,19 +1234,14 @@ function getVersion(app) { | |||||||
| // Use zstandard if possible to maximize cache performance
 | // Use zstandard if possible to maximize cache performance
 | ||||||
| function getCompressionMethod() { | function getCompressionMethod() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const versionOutput = yield getVersion('zstd'); |         const versionOutput = yield getVersion('zstd', ['--quiet']); | ||||||
|         const version = semver.clean(versionOutput); |         const version = semver.clean(versionOutput); | ||||||
|         if (!versionOutput.toLowerCase().includes('zstd command line interface')) { |         core.debug(`zstd version: ${version}`); | ||||||
|             // zstd is not installed
 |         if (versionOutput === '') { | ||||||
|             return constants_1.CompressionMethod.Gzip; |             return constants_1.CompressionMethod.Gzip; | ||||||
|         } |         } | ||||||
|         else if (!version || semver.lt(version, 'v1.3.2')) { |  | ||||||
|             // zstd is installed but using a version earlier than v1.3.2
 |  | ||||||
|             // v1.3.2 is required to use the `--long` options in zstd
 |  | ||||||
|             return constants_1.CompressionMethod.ZstdWithoutLong; |  | ||||||
|         } |  | ||||||
|         else { |         else { | ||||||
|             return constants_1.CompressionMethod.Zstd; |             return constants_1.CompressionMethod.ZstdWithoutLong; | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							| @ -1152,12 +1152,13 @@ function unlinkFile(filePath) { | |||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.unlinkFile = unlinkFile; | exports.unlinkFile = unlinkFile; | ||||||
| function getVersion(app) { | function getVersion(app, additionalArgs = []) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         core.debug(`Checking ${app} --version`); |  | ||||||
|         let versionOutput = ''; |         let versionOutput = ''; | ||||||
|  |         additionalArgs.push('--version'); | ||||||
|  |         core.debug(`Checking ${app} ${additionalArgs.join(' ')}`); | ||||||
|         try { |         try { | ||||||
|             yield exec.exec(`${app} --version`, [], { |             yield exec.exec(`${app}`, additionalArgs, { | ||||||
|                 ignoreReturnCode: true, |                 ignoreReturnCode: true, | ||||||
|                 silent: true, |                 silent: true, | ||||||
|                 listeners: { |                 listeners: { | ||||||
| @ -1177,19 +1178,14 @@ function getVersion(app) { | |||||||
| // Use zstandard if possible to maximize cache performance
 | // Use zstandard if possible to maximize cache performance
 | ||||||
| function getCompressionMethod() { | function getCompressionMethod() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const versionOutput = yield getVersion('zstd'); |         const versionOutput = yield getVersion('zstd', ['--quiet']); | ||||||
|         const version = semver.clean(versionOutput); |         const version = semver.clean(versionOutput); | ||||||
|         if (!versionOutput.toLowerCase().includes('zstd command line interface')) { |         core.debug(`zstd version: ${version}`); | ||||||
|             // zstd is not installed
 |         if (versionOutput === '') { | ||||||
|             return constants_1.CompressionMethod.Gzip; |             return constants_1.CompressionMethod.Gzip; | ||||||
|         } |         } | ||||||
|         else if (!version || semver.lt(version, 'v1.3.2')) { |  | ||||||
|             // zstd is installed but using a version earlier than v1.3.2
 |  | ||||||
|             // v1.3.2 is required to use the `--long` options in zstd
 |  | ||||||
|             return constants_1.CompressionMethod.ZstdWithoutLong; |  | ||||||
|         } |  | ||||||
|         else { |         else { | ||||||
|             return constants_1.CompressionMethod.Zstd; |             return constants_1.CompressionMethod.ZstdWithoutLong; | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Lovepreet Singh
						Lovepreet Singh