mirror of https://github.com/actions/cache.git
				
				
				
			Save-only warning added
This commit is contained in:
		
							parent
							
								
									8955114d15
								
							
						
					
					
						commit
						1d114a8000
					
				|  | @ -6,7 +6,7 @@ | ||||||
| 	// Use 'forwardPorts' to make a list of ports inside the container available locally. | 	// Use 'forwardPorts' to make a list of ports inside the container available locally. | ||||||
| 	// "forwardPorts": [], | 	// "forwardPorts": [], | ||||||
| 	// Use 'postCreateCommand' to run commands after the container is created. | 	// Use 'postCreateCommand' to run commands after the container is created. | ||||||
| 	"postCreateCommand": "npm install && npm run build" | 	"postCreateCommand": "npm install" | ||||||
| 	// Configure tool-specific properties. | 	// Configure tool-specific properties. | ||||||
| 	// "customizations": {}, | 	// "customizations": {}, | ||||||
| 	// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root. | 	// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root. | ||||||
|  |  | ||||||
|  | @ -91,3 +91,31 @@ test("save with valid inputs uploads a cache", async () => { | ||||||
| 
 | 
 | ||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
| }); | }); | ||||||
|  | 
 | ||||||
|  | test("save failing logs the warning message", async () => { | ||||||
|  |     const warningMock = jest.spyOn(core, "warning"); | ||||||
|  | 
 | ||||||
|  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | ||||||
|  | 
 | ||||||
|  |     const inputPath = "node_modules"; | ||||||
|  |     testUtils.setInput(Inputs.Key, primaryKey); | ||||||
|  |     testUtils.setInput(Inputs.Path, inputPath); | ||||||
|  |     testUtils.setInput(Inputs.UploadChunkSize, "4000000"); | ||||||
|  | 
 | ||||||
|  |     const cacheId = -1; | ||||||
|  |     const saveCacheMock = jest | ||||||
|  |         .spyOn(cache, "saveCache") | ||||||
|  |         .mockImplementationOnce(() => { | ||||||
|  |             return Promise.resolve(cacheId); | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |     await run(); | ||||||
|  | 
 | ||||||
|  |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|  |     expect(saveCacheMock).toHaveBeenCalledWith([inputPath], primaryKey, { | ||||||
|  |         uploadChunkSize: 4000000 | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     expect(warningMock).toHaveBeenCalledTimes(1); | ||||||
|  |     expect(warningMock).toHaveBeenCalledWith("Cache save failed."); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | @ -1043,6 +1043,29 @@ class ExecState extends events.EventEmitter { | ||||||
| 
 | 
 | ||||||
| "use strict"; | "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; | ||||||
|  | }; | ||||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|     return new (P || (P = Promise))(function (resolve, reject) { |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  | @ -1056,11 +1079,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) { | ||||||
|     return (mod && mod.__esModule) ? mod : { "default": mod }; |     return (mod && mod.__esModule) ? mod : { "default": mod }; | ||||||
| }; | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const core = __importStar(__webpack_require__(470)); | ||||||
| const saveImpl_1 = __importDefault(__webpack_require__(471)); | const saveImpl_1 = __importDefault(__webpack_require__(471)); | ||||||
| const stateProvider_1 = __webpack_require__(309); | const stateProvider_1 = __webpack_require__(309); | ||||||
| function run() { | function run() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         yield (0, saveImpl_1.default)(new stateProvider_1.NullStateProvider()); |         const cacheId = yield (0, saveImpl_1.default)(new stateProvider_1.NullStateProvider()); | ||||||
|  |         if (cacheId === -1) { | ||||||
|  |             core.warning(`Cache save failed.`); | ||||||
|  |         } | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| run(); | run(); | ||||||
|  | @ -41092,13 +41119,14 @@ const utils = __importStar(__webpack_require__(443)); | ||||||
| process.on("uncaughtException", e => utils.logWarning(e.message)); | process.on("uncaughtException", e => utils.logWarning(e.message)); | ||||||
| function saveImpl(stateProvider) { | function saveImpl(stateProvider) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         let cacheId; | ||||||
|         try { |         try { | ||||||
|             if (!utils.isCacheFeatureAvailable()) { |             if (!utils.isCacheFeatureAvailable()) { | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             if (!utils.isValidEvent()) { |             if (!utils.isValidEvent()) { | ||||||
|                 utils.logWarning(`Event Validation Error: The event type ${process.env[constants_1.Events.Key]} is not supported because it's not tied to a branch or tag ref.`); |                 utils.logWarning(`Event Validation Error: The event type ${process.env[constants_1.Events.Key]} is not supported because it's not tied to a branch or tag ref.`); | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             // If restore has stored a primary key in state, reuse that
 |             // If restore has stored a primary key in state, reuse that
 | ||||||
|             // Else re-evaluate from inputs
 |             // Else re-evaluate from inputs
 | ||||||
|  | @ -41106,19 +41134,19 @@ function saveImpl(stateProvider) { | ||||||
|                 core.getInput(constants_1.Inputs.Key); |                 core.getInput(constants_1.Inputs.Key); | ||||||
|             if (!primaryKey) { |             if (!primaryKey) { | ||||||
|                 utils.logWarning(`Key is not specified.`); |                 utils.logWarning(`Key is not specified.`); | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             // If matched restore key is same as primary key, then do not save cache
 |             // If matched restore key is same as primary key, then do not save cache
 | ||||||
|             // NO-OP in case of SaveOnly action
 |             // NO-OP in case of SaveOnly action
 | ||||||
|             const restoredKey = stateProvider.getCacheState(); |             const restoredKey = stateProvider.getCacheState(); | ||||||
|             if (utils.isExactKeyMatch(primaryKey, restoredKey)) { |             if (utils.isExactKeyMatch(primaryKey, restoredKey)) { | ||||||
|                 core.info(`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`); |                 core.info(`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`); | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, { |             const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, { | ||||||
|                 required: true |                 required: true | ||||||
|             }); |             }); | ||||||
|             const cacheId = yield cache.saveCache(cachePaths, primaryKey, { |             cacheId = yield cache.saveCache(cachePaths, primaryKey, { | ||||||
|                 uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize) |                 uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize) | ||||||
|             }); |             }); | ||||||
|             if (cacheId != -1) { |             if (cacheId != -1) { | ||||||
|  | @ -41128,6 +41156,7 @@ function saveImpl(stateProvider) { | ||||||
|         catch (error) { |         catch (error) { | ||||||
|             utils.logWarning(error.message); |             utils.logWarning(error.message); | ||||||
|         } |         } | ||||||
|  |         return cacheId; | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.default = saveImpl; | exports.default = saveImpl; | ||||||
|  |  | ||||||
|  | @ -41063,13 +41063,14 @@ const utils = __importStar(__webpack_require__(443)); | ||||||
| process.on("uncaughtException", e => utils.logWarning(e.message)); | process.on("uncaughtException", e => utils.logWarning(e.message)); | ||||||
| function saveImpl(stateProvider) { | function saveImpl(stateProvider) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         let cacheId; | ||||||
|         try { |         try { | ||||||
|             if (!utils.isCacheFeatureAvailable()) { |             if (!utils.isCacheFeatureAvailable()) { | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             if (!utils.isValidEvent()) { |             if (!utils.isValidEvent()) { | ||||||
|                 utils.logWarning(`Event Validation Error: The event type ${process.env[constants_1.Events.Key]} is not supported because it's not tied to a branch or tag ref.`); |                 utils.logWarning(`Event Validation Error: The event type ${process.env[constants_1.Events.Key]} is not supported because it's not tied to a branch or tag ref.`); | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             // If restore has stored a primary key in state, reuse that
 |             // If restore has stored a primary key in state, reuse that
 | ||||||
|             // Else re-evaluate from inputs
 |             // Else re-evaluate from inputs
 | ||||||
|  | @ -41077,19 +41078,19 @@ function saveImpl(stateProvider) { | ||||||
|                 core.getInput(constants_1.Inputs.Key); |                 core.getInput(constants_1.Inputs.Key); | ||||||
|             if (!primaryKey) { |             if (!primaryKey) { | ||||||
|                 utils.logWarning(`Key is not specified.`); |                 utils.logWarning(`Key is not specified.`); | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             // If matched restore key is same as primary key, then do not save cache
 |             // If matched restore key is same as primary key, then do not save cache
 | ||||||
|             // NO-OP in case of SaveOnly action
 |             // NO-OP in case of SaveOnly action
 | ||||||
|             const restoredKey = stateProvider.getCacheState(); |             const restoredKey = stateProvider.getCacheState(); | ||||||
|             if (utils.isExactKeyMatch(primaryKey, restoredKey)) { |             if (utils.isExactKeyMatch(primaryKey, restoredKey)) { | ||||||
|                 core.info(`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`); |                 core.info(`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`); | ||||||
|                 return; |                 return 0; | ||||||
|             } |             } | ||||||
|             const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, { |             const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, { | ||||||
|                 required: true |                 required: true | ||||||
|             }); |             }); | ||||||
|             const cacheId = yield cache.saveCache(cachePaths, primaryKey, { |             cacheId = yield cache.saveCache(cachePaths, primaryKey, { | ||||||
|                 uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize) |                 uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize) | ||||||
|             }); |             }); | ||||||
|             if (cacheId != -1) { |             if (cacheId != -1) { | ||||||
|  | @ -41099,6 +41100,7 @@ function saveImpl(stateProvider) { | ||||||
|         catch (error) { |         catch (error) { | ||||||
|             utils.logWarning(error.message); |             utils.logWarning(error.message); | ||||||
|         } |         } | ||||||
|  |         return cacheId; | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.default = saveImpl; | exports.default = saveImpl; | ||||||
|  |  | ||||||
|  | @ -10,10 +10,11 @@ import * as utils from "./utils/actionUtils"; | ||||||
| // throw an uncaught exception.  Instead of failing this action, just warn.
 | // throw an uncaught exception.  Instead of failing this action, just warn.
 | ||||||
| process.on("uncaughtException", e => utils.logWarning(e.message)); | process.on("uncaughtException", e => utils.logWarning(e.message)); | ||||||
| 
 | 
 | ||||||
| async function saveImpl(stateProvider: IStateProvider): Promise<void> { | async function saveImpl(stateProvider: IStateProvider): Promise<number> { | ||||||
|  |     let cacheId; | ||||||
|     try { |     try { | ||||||
|         if (!utils.isCacheFeatureAvailable()) { |         if (!utils.isCacheFeatureAvailable()) { | ||||||
|             return; |             return 0; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (!utils.isValidEvent()) { |         if (!utils.isValidEvent()) { | ||||||
|  | @ -22,7 +23,7 @@ async function saveImpl(stateProvider: IStateProvider): Promise<void> { | ||||||
|                     process.env[Events.Key] |                     process.env[Events.Key] | ||||||
|                 } is not supported because it's not tied to a branch or tag ref.` |                 } is not supported because it's not tied to a branch or tag ref.` | ||||||
|             ); |             ); | ||||||
|             return; |             return 0; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // If restore has stored a primary key in state, reuse that
 |         // If restore has stored a primary key in state, reuse that
 | ||||||
|  | @ -33,7 +34,7 @@ async function saveImpl(stateProvider: IStateProvider): Promise<void> { | ||||||
| 
 | 
 | ||||||
|         if (!primaryKey) { |         if (!primaryKey) { | ||||||
|             utils.logWarning(`Key is not specified.`); |             utils.logWarning(`Key is not specified.`); | ||||||
|             return; |             return 0; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // If matched restore key is same as primary key, then do not save cache
 |         // If matched restore key is same as primary key, then do not save cache
 | ||||||
|  | @ -44,14 +45,14 @@ async function saveImpl(stateProvider: IStateProvider): Promise<void> { | ||||||
|             core.info( |             core.info( | ||||||
|                 `Cache hit occurred on the primary key ${primaryKey}, not saving cache.` |                 `Cache hit occurred on the primary key ${primaryKey}, not saving cache.` | ||||||
|             ); |             ); | ||||||
|             return; |             return 0; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const cachePaths = utils.getInputAsArray(Inputs.Path, { |         const cachePaths = utils.getInputAsArray(Inputs.Path, { | ||||||
|             required: true |             required: true | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|         const cacheId = await cache.saveCache(cachePaths, primaryKey, { |         cacheId = await cache.saveCache(cachePaths, primaryKey, { | ||||||
|             uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize) |             uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize) | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|  | @ -61,6 +62,7 @@ async function saveImpl(stateProvider: IStateProvider): Promise<void> { | ||||||
|     } catch (error: unknown) { |     } catch (error: unknown) { | ||||||
|         utils.logWarning((error as Error).message); |         utils.logWarning((error as Error).message); | ||||||
|     } |     } | ||||||
|  |     return cacheId; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export default saveImpl; | export default saveImpl; | ||||||
|  |  | ||||||
|  | @ -1,8 +1,13 @@ | ||||||
|  | import * as core from "@actions/core"; | ||||||
|  | 
 | ||||||
| import saveImpl from "./saveImpl"; | import saveImpl from "./saveImpl"; | ||||||
| import { NullStateProvider } from "./stateProvider"; | import { NullStateProvider } from "./stateProvider"; | ||||||
| 
 | 
 | ||||||
| async function run(): Promise<void> { | async function run(): Promise<void> { | ||||||
|     await saveImpl(new NullStateProvider()); |     const cacheId = await saveImpl(new NullStateProvider()); | ||||||
|  |     if (cacheId === -1) { | ||||||
|  |         core.warning(`Cache save failed.`); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| run(); | run(); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Sankalp Kotewar
						Sankalp Kotewar