mirror of
				https://github.com/actions/cache.git
				synced 2025-10-31 03:38:36 +08:00 
			
		
		
		
	Merge branch '700-actionscache-granular-cache-control' into bishal/outputter
This commit is contained in:
		
						commit
						34e917cb7d
					
				|  | @ -102,7 +102,7 @@ test("restore on GHES with AC available ", async () => { | ||||||
|     const infoMock = jest.spyOn(core, "info"); |     const infoMock = jest.spyOn(core, "info"); | ||||||
|     const failedMock = jest.spyOn(core, "setFailed"); |     const failedMock = jest.spyOn(core, "setFailed"); | ||||||
|     const stateMock = jest.spyOn(core, "saveState"); |     const stateMock = jest.spyOn(core, "saveState"); | ||||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); |     const setCacheHitOutputMock = jest.spyOn(core, "setOutput"); | ||||||
|     const restoreCacheMock = jest |     const restoreCacheMock = jest | ||||||
|         .spyOn(cache, "restoreCache") |         .spyOn(cache, "restoreCache") | ||||||
|         .mockImplementationOnce(() => { |         .mockImplementationOnce(() => { | ||||||
|  | @ -116,7 +116,7 @@ test("restore on GHES with AC available ", async () => { | ||||||
| 
 | 
 | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); |     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(true); |     expect(setCacheHitOutputMock).toHaveBeenCalledWith("cache-hit", "true"); | ||||||
| 
 | 
 | ||||||
|     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); |     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); | ||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
|  | @ -270,7 +270,7 @@ test("restore with cache found for key", async () => { | ||||||
|     const infoMock = jest.spyOn(core, "info"); |     const infoMock = jest.spyOn(core, "info"); | ||||||
|     const failedMock = jest.spyOn(core, "setFailed"); |     const failedMock = jest.spyOn(core, "setFailed"); | ||||||
|     const stateMock = jest.spyOn(core, "saveState"); |     const stateMock = jest.spyOn(core, "saveState"); | ||||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); |     const setCacheHitOutputMock = jest.spyOn(core, "setOutput"); | ||||||
|     const restoreCacheMock = jest |     const restoreCacheMock = jest | ||||||
|         .spyOn(cache, "restoreCache") |         .spyOn(cache, "restoreCache") | ||||||
|         .mockImplementationOnce(() => { |         .mockImplementationOnce(() => { | ||||||
|  | @ -284,7 +284,7 @@ test("restore with cache found for key", async () => { | ||||||
| 
 | 
 | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); |     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(true); |     expect(setCacheHitOutputMock).toHaveBeenCalledWith("cache-hit", "true"); | ||||||
| 
 | 
 | ||||||
|     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); |     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); | ||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
|  | @ -303,7 +303,7 @@ test("restore with cache found for restore key", async () => { | ||||||
|     const infoMock = jest.spyOn(core, "info"); |     const infoMock = jest.spyOn(core, "info"); | ||||||
|     const failedMock = jest.spyOn(core, "setFailed"); |     const failedMock = jest.spyOn(core, "setFailed"); | ||||||
|     const stateMock = jest.spyOn(core, "saveState"); |     const stateMock = jest.spyOn(core, "saveState"); | ||||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); |     const setCacheHitOutputMock = jest.spyOn(core, "setOutput"); | ||||||
|     const restoreCacheMock = jest |     const restoreCacheMock = jest | ||||||
|         .spyOn(cache, "restoreCache") |         .spyOn(cache, "restoreCache") | ||||||
|         .mockImplementationOnce(() => { |         .mockImplementationOnce(() => { | ||||||
|  | @ -317,8 +317,7 @@ test("restore with cache found for restore key", async () => { | ||||||
| 
 | 
 | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); |     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(false); |     expect(setCacheHitOutputMock).toHaveBeenCalledWith("cache-hit", "false"); | ||||||
| 
 |  | ||||||
|     expect(infoMock).toHaveBeenCalledWith( |     expect(infoMock).toHaveBeenCalledWith( | ||||||
|         `Cache restored from key: ${restoreKey}` |         `Cache restored from key: ${restoreKey}` | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
							
								
								
									
										131
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										131
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							|  | @ -3701,30 +3701,7 @@ exports.DiagAPI = DiagAPI; | ||||||
| /* 121 */, | /* 121 */, | ||||||
| /* 122 */, | /* 122 */, | ||||||
| /* 123 */, | /* 123 */, | ||||||
| /* 124 */ | /* 124 */, | ||||||
| /***/ (function(__unusedmodule, exports) { |  | ||||||
| 
 |  | ||||||
| "use strict"; |  | ||||||
| 
 |  | ||||||
| /* |  | ||||||
|  * Copyright The OpenTelemetry Authors |  | ||||||
|  * |  | ||||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
|  * you may not use this file except in compliance with the License. |  | ||||||
|  * You may obtain a copy of the License at |  | ||||||
|  * |  | ||||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 |  | ||||||
|  * |  | ||||||
|  * Unless required by applicable law or agreed to in writing, software |  | ||||||
|  * distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
|  * See the License for the specific language governing permissions and |  | ||||||
|  * limitations under the License. |  | ||||||
|  */ |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| //# sourceMappingURL=tracer_provider.js.map
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 125 */, | /* 125 */, | ||||||
| /* 126 */, | /* 126 */, | ||||||
| /* 127 */, | /* 127 */, | ||||||
|  | @ -4981,7 +4958,41 @@ exports.checkBypass = checkBypass; | ||||||
| /* 193 */, | /* 193 */, | ||||||
| /* 194 */, | /* 194 */, | ||||||
| /* 195 */, | /* 195 */, | ||||||
| /* 196 */, | /* 196 */ | ||||||
|  | /***/ (function(__unusedmodule, exports) { | ||||||
|  | 
 | ||||||
|  | "use strict"; | ||||||
|  | 
 | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | exports.RefKey = exports.Events = exports.State = exports.Outputs = exports.Inputs = void 0; | ||||||
|  | var Inputs; | ||||||
|  | (function (Inputs) { | ||||||
|  |     Inputs["Key"] = "key"; | ||||||
|  |     Inputs["Path"] = "path"; | ||||||
|  |     Inputs["RestoreKeys"] = "restore-keys"; | ||||||
|  |     Inputs["UploadChunkSize"] = "upload-chunk-size"; | ||||||
|  | })(Inputs = exports.Inputs || (exports.Inputs = {})); | ||||||
|  | var Outputs; | ||||||
|  | (function (Outputs) { | ||||||
|  |     Outputs["CacheHit"] = "cache-hit"; | ||||||
|  |     Outputs["Key"] = "key"; | ||||||
|  |     Outputs["Path"] = "path"; | ||||||
|  | })(Outputs = exports.Outputs || (exports.Outputs = {})); | ||||||
|  | var State; | ||||||
|  | (function (State) { | ||||||
|  |     State["CachePrimaryKey"] = "CACHE_KEY"; | ||||||
|  |     State["CacheMatchedKey"] = "CACHE_RESULT"; | ||||||
|  | })(State = exports.State || (exports.State = {})); | ||||||
|  | var Events; | ||||||
|  | (function (Events) { | ||||||
|  |     Events["Key"] = "GITHUB_EVENT_NAME"; | ||||||
|  |     Events["Push"] = "push"; | ||||||
|  |     Events["PullRequest"] = "pull_request"; | ||||||
|  | })(Events = exports.Events || (exports.Events = {})); | ||||||
|  | exports.RefKey = "GITHUB_REF"; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /***/ }), | ||||||
| /* 197 */ | /* 197 */ | ||||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||||
| 
 | 
 | ||||||
|  | @ -38349,7 +38360,7 @@ __exportStar(__webpack_require__(220), exports); | ||||||
| __exportStar(__webpack_require__(932), exports); | __exportStar(__webpack_require__(932), exports); | ||||||
| __exportStar(__webpack_require__(975), exports); | __exportStar(__webpack_require__(975), exports); | ||||||
| __exportStar(__webpack_require__(207), exports); | __exportStar(__webpack_require__(207), exports); | ||||||
| __exportStar(__webpack_require__(124), exports); | __exportStar(__webpack_require__(694), exports); | ||||||
| __exportStar(__webpack_require__(695), exports); | __exportStar(__webpack_require__(695), exports); | ||||||
| var spancontext_utils_1 = __webpack_require__(629); | var spancontext_utils_1 = __webpack_require__(629); | ||||||
| Object.defineProperty(exports, "isSpanContextValid", { enumerable: true, get: function () { return spancontext_utils_1.isSpanContextValid; } }); | Object.defineProperty(exports, "isSpanContextValid", { enumerable: true, get: function () { return spancontext_utils_1.isSpanContextValid; } }); | ||||||
|  | @ -38421,7 +38432,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| exports.isCacheFeatureAvailable = exports.getInputAsInt = exports.getInputAsArray = exports.isValidEvent = exports.logWarning = exports.setCacheHitOutput = exports.isExactKeyMatch = exports.isGhes = void 0; | exports.isCacheFeatureAvailable = exports.getInputAsInt = exports.getInputAsArray = exports.isValidEvent = exports.logWarning = exports.setCacheHitOutput = exports.isExactKeyMatch = exports.isGhes = void 0; | ||||||
| const cache = __importStar(__webpack_require__(692)); | const cache = __importStar(__webpack_require__(692)); | ||||||
| const core = __importStar(__webpack_require__(470)); | const core = __importStar(__webpack_require__(470)); | ||||||
| const constants_1 = __webpack_require__(694); | const constants_1 = __webpack_require__(196); | ||||||
| function isGhes() { | function isGhes() { | ||||||
|     const ghUrl = new URL(process.env["GITHUB_SERVER_URL"] || "https://github.com"); |     const ghUrl = new URL(process.env["GITHUB_SERVER_URL"] || "https://github.com"); | ||||||
|     return ghUrl.hostname.toUpperCase() !== "GITHUB.COM"; |     return ghUrl.hostname.toUpperCase() !== "GITHUB.COM"; | ||||||
|  | @ -47570,6 +47581,21 @@ exports.saveCache = saveCache; | ||||||
| 
 | 
 | ||||||
| "use strict"; | "use strict"; | ||||||
| 
 | 
 | ||||||
|  | /* | ||||||
|  |  * Copyright The OpenTelemetry Authors | ||||||
|  |  * | ||||||
|  |  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  |  * you may not use this file except in compliance with the License. | ||||||
|  |  * You may obtain a copy of the License at | ||||||
|  |  * | ||||||
|  |  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||||
|  |  * | ||||||
|  |  * Unless required by applicable law or agreed to in writing, software | ||||||
|  |  * distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  |  * See the License for the specific language governing permissions and | ||||||
|  |  * limitations under the License. | ||||||
|  |  */ | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| exports.RefKey = exports.Events = exports.State = exports.Outputs = exports.Inputs = void 0; | exports.RefKey = exports.Events = exports.State = exports.Outputs = exports.Inputs = void 0; | ||||||
| var Inputs; | var Inputs; | ||||||
|  | @ -50674,7 +50700,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| const cache = __importStar(__webpack_require__(692)); | const cache = __importStar(__webpack_require__(692)); | ||||||
| const core = __importStar(__webpack_require__(470)); | const core = __importStar(__webpack_require__(470)); | ||||||
| const constants_1 = __webpack_require__(694); | const constants_1 = __webpack_require__(196); | ||||||
| const utils = __importStar(__webpack_require__(443)); | const utils = __importStar(__webpack_require__(443)); | ||||||
| function restoreImpl(outputter) { | function restoreImpl(outputter) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  | @ -55029,7 +55055,54 @@ exports._globalThis = typeof globalThis === 'object' ? globalThis : global; | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| /* 957 */, | /* 957 */, | ||||||
| /* 958 */, | /* 958 */ | ||||||
|  | /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||||
|  | 
 | ||||||
|  | "use strict"; | ||||||
|  | 
 | ||||||
|  | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|  |     if (k2 === undefined) k2 = k; | ||||||
|  |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
|  | }) : (function(o, m, k, k2) { | ||||||
|  |     if (k2 === undefined) k2 = k; | ||||||
|  |     o[k2] = m[k]; | ||||||
|  | })); | ||||||
|  | var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { | ||||||
|  |     Object.defineProperty(o, "default", { enumerable: true, value: v }); | ||||||
|  | }) : function(o, v) { | ||||||
|  |     o["default"] = v; | ||||||
|  | }); | ||||||
|  | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|  |     if (mod && mod.__esModule) return mod; | ||||||
|  |     var result = {}; | ||||||
|  |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|  |     __setModuleDefault(result, mod); | ||||||
|  |     return result; | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | exports.NonStateOutputSetter = exports.StateOutputSetter = void 0; | ||||||
|  | const core = __importStar(__webpack_require__(470)); | ||||||
|  | class StateOutputSetter { | ||||||
|  |     constructor() { | ||||||
|  |         this.setOutput = core.setOutput; | ||||||
|  |         this.setState = core.saveState; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | exports.StateOutputSetter = StateOutputSetter; | ||||||
|  | class NonStateOutputSetter { | ||||||
|  |     constructor() { | ||||||
|  |         this.setOutput = core.setOutput; | ||||||
|  |         this.setState = core.setOutput; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | exports.NonStateOutputSetter = NonStateOutputSetter; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /***/ }), | ||||||
| /* 959 */, | /* 959 */, | ||||||
| /* 960 */ | /* 960 */ | ||||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||||
|  |  | ||||||
|  | @ -23,7 +23,7 @@ async function restoreImpl(outputter: IStateProvider): Promise<string | undefine | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const primaryKey = core.getInput(Inputs.Key, { required: true }); |         const primaryKey = core.getInput(Inputs.Key, { required: true }); | ||||||
|         outputter.setState(State.CachePrimaryKey, primaryKey); |         stateProvider.setState(State.CachePrimaryKey, primaryKey); | ||||||
| 
 | 
 | ||||||
|         const restoreKeys = utils.getInputAsArray(Inputs.RestoreKeys); |         const restoreKeys = utils.getInputAsArray(Inputs.RestoreKeys); | ||||||
|         const cachePaths = utils.getInputAsArray(Inputs.Path, { |         const cachePaths = utils.getInputAsArray(Inputs.Path, { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Bishal Prasad
						Bishal Prasad