mirror of
				https://github.com/actions/cache.git
				synced 2025-10-31 11:48:38 +08:00 
			
		
		
		
	Version cache with all inputs
This commit is contained in:
		
							parent
							
								
									ac5351dd08
								
							
						
					
					
						commit
						820f06f7d0
					
				|  | @ -241,7 +241,7 @@ test("restore with cache found", async () => { | ||||||
|     await run(); |     await run(); | ||||||
| 
 | 
 | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(getCacheMock).toHaveBeenCalledWith([key]); |     expect(getCacheMock).toHaveBeenCalledWith(); | ||||||
|     expect(setCacheStateMock).toHaveBeenCalledWith(cacheEntry); |     expect(setCacheStateMock).toHaveBeenCalledWith(cacheEntry); | ||||||
|     expect(createTempDirectoryMock).toHaveBeenCalledTimes(1); |     expect(createTempDirectoryMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(downloadCacheMock).toHaveBeenCalledWith( |     expect(downloadCacheMock).toHaveBeenCalledWith( | ||||||
|  | @ -307,7 +307,7 @@ test("restore with a pull request event and cache found", async () => { | ||||||
|     await run(); |     await run(); | ||||||
| 
 | 
 | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(getCacheMock).toHaveBeenCalledWith([key]); |     expect(getCacheMock).toHaveBeenCalledWith(); | ||||||
|     expect(setCacheStateMock).toHaveBeenCalledWith(cacheEntry); |     expect(setCacheStateMock).toHaveBeenCalledWith(cacheEntry); | ||||||
|     expect(createTempDirectoryMock).toHaveBeenCalledTimes(1); |     expect(createTempDirectoryMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(downloadCacheMock).toHaveBeenCalledWith( |     expect(downloadCacheMock).toHaveBeenCalledWith( | ||||||
|  | @ -374,7 +374,7 @@ test("restore with cache found for restore key", async () => { | ||||||
|     await run(); |     await run(); | ||||||
| 
 | 
 | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(getCacheMock).toHaveBeenCalledWith([key, restoreKey]); |     expect(getCacheMock).toHaveBeenCalledWith(); | ||||||
|     expect(setCacheStateMock).toHaveBeenCalledWith(cacheEntry); |     expect(setCacheStateMock).toHaveBeenCalledWith(cacheEntry); | ||||||
|     expect(createTempDirectoryMock).toHaveBeenCalledTimes(1); |     expect(createTempDirectoryMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(downloadCacheMock).toHaveBeenCalledWith( |     expect(downloadCacheMock).toHaveBeenCalledWith( | ||||||
|  |  | ||||||
|  | @ -161,11 +161,10 @@ test("save with missing input outputs warning", async () => { | ||||||
| 
 | 
 | ||||||
|     await run(); |     await run(); | ||||||
| 
 | 
 | ||||||
|     // TODO: this shouldn't be necessary if tarball contains entries relative to workspace
 |     expect(logWarningMock).toHaveBeenCalledWith( | ||||||
|     expect(logWarningMock).not.toHaveBeenCalledWith( |  | ||||||
|         "Input required and not supplied: path" |         "Input required and not supplied: path" | ||||||
|     ); |     ); | ||||||
|     expect(logWarningMock).toHaveBeenCalledTimes(0); |     expect(logWarningMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										27
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										27
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							|  | @ -2183,9 +2183,12 @@ var __importStar = (this && this.__importStar) || function (mod) { | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| const core = __importStar(__webpack_require__(470)); | const core = __importStar(__webpack_require__(470)); | ||||||
| const fs = __importStar(__webpack_require__(747)); | const fs = __importStar(__webpack_require__(747)); | ||||||
|  | const crypto = __importStar(__webpack_require__(417)); | ||||||
| const auth_1 = __webpack_require__(226); | const auth_1 = __webpack_require__(226); | ||||||
| const http_client_1 = __webpack_require__(539); | const http_client_1 = __webpack_require__(539); | ||||||
| const utils = __importStar(__webpack_require__(443)); | const utils = __importStar(__webpack_require__(443)); | ||||||
|  | const constants_1 = __webpack_require__(694); | ||||||
|  | const versionSalt = "1.0"; | ||||||
| function isSuccessStatusCode(statusCode) { | function isSuccessStatusCode(statusCode) { | ||||||
|     if (!statusCode) { |     if (!statusCode) { | ||||||
|         return false; |         return false; | ||||||
|  | @ -2231,11 +2234,25 @@ function createHttpClient() { | ||||||
|     const bearerCredentialHandler = new auth_1.BearerCredentialHandler(token); |     const bearerCredentialHandler = new auth_1.BearerCredentialHandler(token); | ||||||
|     return new http_client_1.HttpClient("actions/cache", [bearerCredentialHandler], getRequestOptions()); |     return new http_client_1.HttpClient("actions/cache", [bearerCredentialHandler], getRequestOptions()); | ||||||
| } | } | ||||||
| function getCacheEntry(keys) { | function getCacheVersion() { | ||||||
|  |     // Add salt to cache version to support breaking changes in cache entry
 | ||||||
|  |     const components = [ | ||||||
|  |         core.getInput(constants_1.Inputs.Key), | ||||||
|  |         core.getInput(constants_1.Inputs.RestoreKeys), | ||||||
|  |         core.getInput(constants_1.Inputs.Path), | ||||||
|  |         versionSalt | ||||||
|  |     ]; | ||||||
|  |     return crypto | ||||||
|  |         .createHash("sha256") | ||||||
|  |         .update(components.join("|")) | ||||||
|  |         .digest("hex"); | ||||||
|  | } | ||||||
|  | function getCacheEntry() { | ||||||
|     var _a; |     var _a; | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const httpClient = createHttpClient(); |         const httpClient = createHttpClient(); | ||||||
|         const resource = `cache?keys=${encodeURIComponent(keys.join(","))}`; |         const version = getCacheVersion(); | ||||||
|  |         const resource = `cache?version=${version}`; | ||||||
|         const response = yield httpClient.getJson(getCacheApiUrl(resource)); |         const response = yield httpClient.getJson(getCacheApiUrl(resource)); | ||||||
|         if (response.statusCode === 204) { |         if (response.statusCode === 204) { | ||||||
|             return null; |             return null; | ||||||
|  | @ -2278,8 +2295,10 @@ function reserveCache(key) { | ||||||
|     var _a, _b, _c; |     var _a, _b, _c; | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const httpClient = createHttpClient(); |         const httpClient = createHttpClient(); | ||||||
|  |         const version = getCacheVersion(); | ||||||
|         const reserveCacheRequest = { |         const reserveCacheRequest = { | ||||||
|             key |             key, | ||||||
|  |             version | ||||||
|         }; |         }; | ||||||
|         const response = yield httpClient.postJson(getCacheApiUrl("caches"), reserveCacheRequest); |         const response = yield httpClient.postJson(getCacheApiUrl("caches"), reserveCacheRequest); | ||||||
|         return _c = (_b = (_a = response) === null || _a === void 0 ? void 0 : _a.result) === null || _b === void 0 ? void 0 : _b.cacheId, (_c !== null && _c !== void 0 ? _c : -1); |         return _c = (_b = (_a = response) === null || _a === void 0 ? void 0 : _a.result) === null || _b === void 0 ? void 0 : _b.cacheId, (_c !== null && _c !== void 0 ? _c : -1); | ||||||
|  | @ -4568,7 +4587,7 @@ function run() { | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             try { |             try { | ||||||
|                 const cacheEntry = yield cacheHttpClient.getCacheEntry(keys); |                 const cacheEntry = yield cacheHttpClient.getCacheEntry(); | ||||||
|                 if (!((_a = cacheEntry) === null || _a === void 0 ? void 0 : _a.archiveLocation)) { |                 if (!((_a = cacheEntry) === null || _a === void 0 ? void 0 : _a.archiveLocation)) { | ||||||
|                     core.info(`Cache not found for input keys: ${keys.join(", ")}`); |                     core.info(`Cache not found for input keys: ${keys.join(", ")}`); | ||||||
|                     return; |                     return; | ||||||
|  |  | ||||||
							
								
								
									
										27
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										27
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							|  | @ -2183,9 +2183,12 @@ var __importStar = (this && this.__importStar) || function (mod) { | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| const core = __importStar(__webpack_require__(470)); | const core = __importStar(__webpack_require__(470)); | ||||||
| const fs = __importStar(__webpack_require__(747)); | const fs = __importStar(__webpack_require__(747)); | ||||||
|  | const crypto = __importStar(__webpack_require__(417)); | ||||||
| const auth_1 = __webpack_require__(226); | const auth_1 = __webpack_require__(226); | ||||||
| const http_client_1 = __webpack_require__(539); | const http_client_1 = __webpack_require__(539); | ||||||
| const utils = __importStar(__webpack_require__(443)); | const utils = __importStar(__webpack_require__(443)); | ||||||
|  | const constants_1 = __webpack_require__(694); | ||||||
|  | const versionSalt = "1.0"; | ||||||
| function isSuccessStatusCode(statusCode) { | function isSuccessStatusCode(statusCode) { | ||||||
|     if (!statusCode) { |     if (!statusCode) { | ||||||
|         return false; |         return false; | ||||||
|  | @ -2231,11 +2234,25 @@ function createHttpClient() { | ||||||
|     const bearerCredentialHandler = new auth_1.BearerCredentialHandler(token); |     const bearerCredentialHandler = new auth_1.BearerCredentialHandler(token); | ||||||
|     return new http_client_1.HttpClient("actions/cache", [bearerCredentialHandler], getRequestOptions()); |     return new http_client_1.HttpClient("actions/cache", [bearerCredentialHandler], getRequestOptions()); | ||||||
| } | } | ||||||
| function getCacheEntry(keys) { | function getCacheVersion() { | ||||||
|  |     // Add salt to cache version to support breaking changes in cache entry
 | ||||||
|  |     const components = [ | ||||||
|  |         core.getInput(constants_1.Inputs.Key), | ||||||
|  |         core.getInput(constants_1.Inputs.RestoreKeys), | ||||||
|  |         core.getInput(constants_1.Inputs.Path), | ||||||
|  |         versionSalt | ||||||
|  |     ]; | ||||||
|  |     return crypto | ||||||
|  |         .createHash("sha256") | ||||||
|  |         .update(components.join("|")) | ||||||
|  |         .digest("hex"); | ||||||
|  | } | ||||||
|  | function getCacheEntry() { | ||||||
|     var _a; |     var _a; | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const httpClient = createHttpClient(); |         const httpClient = createHttpClient(); | ||||||
|         const resource = `cache?keys=${encodeURIComponent(keys.join(","))}`; |         const version = getCacheVersion(); | ||||||
|  |         const resource = `cache?version=${version}`; | ||||||
|         const response = yield httpClient.getJson(getCacheApiUrl(resource)); |         const response = yield httpClient.getJson(getCacheApiUrl(resource)); | ||||||
|         if (response.statusCode === 204) { |         if (response.statusCode === 204) { | ||||||
|             return null; |             return null; | ||||||
|  | @ -2278,8 +2295,10 @@ function reserveCache(key) { | ||||||
|     var _a, _b, _c; |     var _a, _b, _c; | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const httpClient = createHttpClient(); |         const httpClient = createHttpClient(); | ||||||
|  |         const version = getCacheVersion(); | ||||||
|         const reserveCacheRequest = { |         const reserveCacheRequest = { | ||||||
|             key |             key, | ||||||
|  |             version | ||||||
|         }; |         }; | ||||||
|         const response = yield httpClient.postJson(getCacheApiUrl("caches"), reserveCacheRequest); |         const response = yield httpClient.postJson(getCacheApiUrl("caches"), reserveCacheRequest); | ||||||
|         return _c = (_b = (_a = response) === null || _a === void 0 ? void 0 : _a.result) === null || _b === void 0 ? void 0 : _b.cacheId, (_c !== null && _c !== void 0 ? _c : -1); |         return _c = (_b = (_a = response) === null || _a === void 0 ? void 0 : _a.result) === null || _b === void 0 ? void 0 : _b.cacheId, (_c !== null && _c !== void 0 ? _c : -1); | ||||||
|  | @ -4473,7 +4492,7 @@ function run() { | ||||||
|             } |             } | ||||||
|             core.debug(`Cache ID: ${cacheId}`); |             core.debug(`Cache ID: ${cacheId}`); | ||||||
|             const cachePaths = yield utils.resolvePaths(core |             const cachePaths = yield utils.resolvePaths(core | ||||||
|                 .getInput(constants_1.Inputs.Path) |                 .getInput(constants_1.Inputs.Path, { required: true }) | ||||||
|                 .split("\n") |                 .split("\n") | ||||||
|                 .filter(x => x !== "")); |                 .filter(x => x !== "")); | ||||||
|             core.debug("Cache Paths:"); |             core.debug("Cache Paths:"); | ||||||
|  |  | ||||||
							
								
								
									
										41
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										41
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							|  | @ -2244,7 +2244,8 @@ | ||||||
|         "ansi-regex": { |         "ansi-regex": { | ||||||
|           "version": "2.1.1", |           "version": "2.1.1", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "aproba": { |         "aproba": { | ||||||
|           "version": "1.2.0", |           "version": "1.2.0", | ||||||
|  | @ -2265,12 +2266,14 @@ | ||||||
|         "balanced-match": { |         "balanced-match": { | ||||||
|           "version": "1.0.0", |           "version": "1.0.0", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "brace-expansion": { |         "brace-expansion": { | ||||||
|           "version": "1.1.11", |           "version": "1.1.11", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "balanced-match": "^1.0.0", |             "balanced-match": "^1.0.0", | ||||||
|             "concat-map": "0.0.1" |             "concat-map": "0.0.1" | ||||||
|  | @ -2285,17 +2288,20 @@ | ||||||
|         "code-point-at": { |         "code-point-at": { | ||||||
|           "version": "1.1.0", |           "version": "1.1.0", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "concat-map": { |         "concat-map": { | ||||||
|           "version": "0.0.1", |           "version": "0.0.1", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "console-control-strings": { |         "console-control-strings": { | ||||||
|           "version": "1.1.0", |           "version": "1.1.0", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "core-util-is": { |         "core-util-is": { | ||||||
|           "version": "1.0.2", |           "version": "1.0.2", | ||||||
|  | @ -2412,7 +2418,8 @@ | ||||||
|         "inherits": { |         "inherits": { | ||||||
|           "version": "2.0.3", |           "version": "2.0.3", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "ini": { |         "ini": { | ||||||
|           "version": "1.3.5", |           "version": "1.3.5", | ||||||
|  | @ -2424,6 +2431,7 @@ | ||||||
|           "version": "1.0.0", |           "version": "1.0.0", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "number-is-nan": "^1.0.0" |             "number-is-nan": "^1.0.0" | ||||||
|           } |           } | ||||||
|  | @ -2438,6 +2446,7 @@ | ||||||
|           "version": "3.0.4", |           "version": "3.0.4", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "brace-expansion": "^1.1.7" |             "brace-expansion": "^1.1.7" | ||||||
|           } |           } | ||||||
|  | @ -2445,12 +2454,14 @@ | ||||||
|         "minimist": { |         "minimist": { | ||||||
|           "version": "0.0.8", |           "version": "0.0.8", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "minipass": { |         "minipass": { | ||||||
|           "version": "2.3.5", |           "version": "2.3.5", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "safe-buffer": "^5.1.2", |             "safe-buffer": "^5.1.2", | ||||||
|             "yallist": "^3.0.0" |             "yallist": "^3.0.0" | ||||||
|  | @ -2469,6 +2480,7 @@ | ||||||
|           "version": "0.5.1", |           "version": "0.5.1", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "minimist": "0.0.8" |             "minimist": "0.0.8" | ||||||
|           } |           } | ||||||
|  | @ -2549,7 +2561,8 @@ | ||||||
|         "number-is-nan": { |         "number-is-nan": { | ||||||
|           "version": "1.0.1", |           "version": "1.0.1", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "object-assign": { |         "object-assign": { | ||||||
|           "version": "4.1.1", |           "version": "4.1.1", | ||||||
|  | @ -2561,6 +2574,7 @@ | ||||||
|           "version": "1.4.0", |           "version": "1.4.0", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "wrappy": "1" |             "wrappy": "1" | ||||||
|           } |           } | ||||||
|  | @ -2646,7 +2660,8 @@ | ||||||
|         "safe-buffer": { |         "safe-buffer": { | ||||||
|           "version": "5.1.2", |           "version": "5.1.2", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "safer-buffer": { |         "safer-buffer": { | ||||||
|           "version": "2.1.2", |           "version": "2.1.2", | ||||||
|  | @ -2682,6 +2697,7 @@ | ||||||
|           "version": "1.0.2", |           "version": "1.0.2", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "code-point-at": "^1.0.0", |             "code-point-at": "^1.0.0", | ||||||
|             "is-fullwidth-code-point": "^1.0.0", |             "is-fullwidth-code-point": "^1.0.0", | ||||||
|  | @ -2701,6 +2717,7 @@ | ||||||
|           "version": "3.0.1", |           "version": "3.0.1", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true, |           "dev": true, | ||||||
|  |           "optional": true, | ||||||
|           "requires": { |           "requires": { | ||||||
|             "ansi-regex": "^2.0.0" |             "ansi-regex": "^2.0.0" | ||||||
|           } |           } | ||||||
|  | @ -2744,12 +2761,14 @@ | ||||||
|         "wrappy": { |         "wrappy": { | ||||||
|           "version": "1.0.2", |           "version": "1.0.2", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         }, |         }, | ||||||
|         "yallist": { |         "yallist": { | ||||||
|           "version": "3.0.3", |           "version": "3.0.3", | ||||||
|           "bundled": true, |           "bundled": true, | ||||||
|           "dev": true |           "dev": true, | ||||||
|  |           "optional": true | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -1,5 +1,6 @@ | ||||||
| import * as core from "@actions/core"; | import * as core from "@actions/core"; | ||||||
| import * as fs from "fs"; | import * as fs from "fs"; | ||||||
|  | import * as crypto from "crypto"; | ||||||
| import { BearerCredentialHandler } from "@actions/http-client/auth"; | import { BearerCredentialHandler } from "@actions/http-client/auth"; | ||||||
| import { HttpClient, HttpCodes } from "@actions/http-client"; | import { HttpClient, HttpCodes } from "@actions/http-client"; | ||||||
| import { | import { | ||||||
|  | @ -14,6 +15,9 @@ import { | ||||||
|     ReserveCacheResponse |     ReserveCacheResponse | ||||||
| } from "./contracts"; | } from "./contracts"; | ||||||
| import * as utils from "./utils/actionUtils"; | import * as utils from "./utils/actionUtils"; | ||||||
|  | import { Inputs } from "./constants"; | ||||||
|  | 
 | ||||||
|  | const versionSalt = "1.0"; | ||||||
| 
 | 
 | ||||||
| function isSuccessStatusCode(statusCode?: number): boolean { | function isSuccessStatusCode(statusCode?: number): boolean { | ||||||
|     if (!statusCode) { |     if (!statusCode) { | ||||||
|  | @ -77,11 +81,25 @@ function createHttpClient(): HttpClient { | ||||||
|     ); |     ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function getCacheEntry( | function getCacheVersion(): string { | ||||||
|     keys: string[] |     // Add salt to cache version to support breaking changes in cache entry
 | ||||||
| ): Promise<ArtifactCacheEntry | null> { |     const components = [ | ||||||
|  |         core.getInput(Inputs.Key), | ||||||
|  |         core.getInput(Inputs.RestoreKeys), | ||||||
|  |         core.getInput(Inputs.Path), | ||||||
|  |         versionSalt | ||||||
|  |     ]; | ||||||
|  | 
 | ||||||
|  |     return crypto | ||||||
|  |         .createHash("sha256") | ||||||
|  |         .update(components.join("|")) | ||||||
|  |         .digest("hex"); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export async function getCacheEntry(): Promise<ArtifactCacheEntry | null> { | ||||||
|     const httpClient = createHttpClient(); |     const httpClient = createHttpClient(); | ||||||
|     const resource = `cache?keys=${encodeURIComponent(keys.join(","))}`; |     const version = getCacheVersion(); | ||||||
|  |     const resource = `cache?version=${version}`; | ||||||
| 
 | 
 | ||||||
|     const response = await httpClient.getJson<ArtifactCacheEntry>( |     const response = await httpClient.getJson<ArtifactCacheEntry>( | ||||||
|         getCacheApiUrl(resource) |         getCacheApiUrl(resource) | ||||||
|  | @ -129,9 +147,11 @@ export async function downloadCache( | ||||||
| // Reserve Cache
 | // Reserve Cache
 | ||||||
| export async function reserveCache(key: string): Promise<number> { | export async function reserveCache(key: string): Promise<number> { | ||||||
|     const httpClient = createHttpClient(); |     const httpClient = createHttpClient(); | ||||||
|  |     const version = getCacheVersion(); | ||||||
| 
 | 
 | ||||||
|     const reserveCacheRequest: ReserveCacheRequest = { |     const reserveCacheRequest: ReserveCacheRequest = { | ||||||
|         key |         key, | ||||||
|  |         version | ||||||
|     }; |     }; | ||||||
|     const response = await httpClient.postJson<ReserveCacheResponse>( |     const response = await httpClient.postJson<ReserveCacheResponse>( | ||||||
|         getCacheApiUrl("caches"), |         getCacheApiUrl("caches"), | ||||||
|  |  | ||||||
|  | @ -54,7 +54,7 @@ async function run(): Promise<void> { | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         try { |         try { | ||||||
|             const cacheEntry = await cacheHttpClient.getCacheEntry(keys); |             const cacheEntry = await cacheHttpClient.getCacheEntry(); | ||||||
|             if (!cacheEntry?.archiveLocation) { |             if (!cacheEntry?.archiveLocation) { | ||||||
|                 core.info(`Cache not found for input keys: ${keys.join(", ")}`); |                 core.info(`Cache not found for input keys: ${keys.join(", ")}`); | ||||||
|                 return; |                 return; | ||||||
|  |  | ||||||
|  | @ -45,7 +45,7 @@ async function run(): Promise<void> { | ||||||
|         core.debug(`Cache ID: ${cacheId}`); |         core.debug(`Cache ID: ${cacheId}`); | ||||||
|         const cachePaths = await utils.resolvePaths( |         const cachePaths = await utils.resolvePaths( | ||||||
|             core |             core | ||||||
|                 .getInput(Inputs.Path) |                 .getInput(Inputs.Path, { required: true }) | ||||||
|                 .split("\n") |                 .split("\n") | ||||||
|                 .filter(x => x !== "") |                 .filter(x => x !== "") | ||||||
|         ); |         ); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Ethan Dennis
						Ethan Dennis