| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | import * as cache from "@actions/cache"; | 
					
						
							|  |  |  | import * as core from "@actions/core"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { Events, Inputs, RefKey } from "../src/constants"; | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  | import { saveImpl } from "../src/saveImpl"; | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | import { StateProvider } from "../src/stateProvider"; | 
					
						
							|  |  |  | import * as actionUtils from "../src/utils/actionUtils"; | 
					
						
							|  |  |  | import * as testUtils from "../src/utils/testUtils"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | jest.mock("@actions/core"); | 
					
						
							|  |  |  | jest.mock("@actions/cache"); | 
					
						
							|  |  |  | jest.mock("../src/utils/actionUtils"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | beforeAll(() => { | 
					
						
							|  |  |  |     jest.spyOn(core, "getInput").mockImplementation((name, options) => { | 
					
						
							|  |  |  |         return jest.requireActual("@actions/core").getInput(name, options); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "getInputAsArray").mockImplementation( | 
					
						
							|  |  |  |         (name, options) => { | 
					
						
							|  |  |  |             return jest | 
					
						
							|  |  |  |                 .requireActual("../src/utils/actionUtils") | 
					
						
							|  |  |  |                 .getInputAsArray(name, options); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "getInputAsInt").mockImplementation( | 
					
						
							|  |  |  |         (name, options) => { | 
					
						
							|  |  |  |             return jest | 
					
						
							|  |  |  |                 .requireActual("../src/utils/actionUtils") | 
					
						
							|  |  |  |                 .getInputAsInt(name, options); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-05 16:49:13 +05:30
										 |  |  |     jest.spyOn(actionUtils, "getInputAsBool").mockImplementation( | 
					
						
							|  |  |  |         (name, options) => { | 
					
						
							|  |  |  |             return jest | 
					
						
							|  |  |  |                 .requireActual("../src/utils/actionUtils") | 
					
						
							|  |  |  |                 .getInputAsBool(name, options); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  |     jest.spyOn(actionUtils, "isExactKeyMatch").mockImplementation( | 
					
						
							|  |  |  |         (key, cacheResult) => { | 
					
						
							|  |  |  |             return jest | 
					
						
							|  |  |  |                 .requireActual("../src/utils/actionUtils") | 
					
						
							|  |  |  |                 .isExactKeyMatch(key, cacheResult); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "isValidEvent").mockImplementation(() => { | 
					
						
							|  |  |  |         const actualUtils = jest.requireActual("../src/utils/actionUtils"); | 
					
						
							|  |  |  |         return actualUtils.isValidEvent(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2023-01-05 16:49:13 +05:30
										 |  |  |     jest.restoreAllMocks(); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  |     process.env[Events.Key] = Events.Push; | 
					
						
							|  |  |  |     process.env[RefKey] = "refs/heads/feature-branch"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | 
					
						
							|  |  |  |         () => true | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | afterEach(() => { | 
					
						
							|  |  |  |     testUtils.clearInputs(); | 
					
						
							|  |  |  |     delete process.env[Events.Key]; | 
					
						
							|  |  |  |     delete process.env[RefKey]; | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with invalid event outputs warning", async () => { | 
					
						
							|  |  |  |     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  |     const invalidEvent = "commit_comment"; | 
					
						
							|  |  |  |     process.env[Events.Key] = invalidEvent; | 
					
						
							|  |  |  |     delete process.env[RefKey]; | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  |     expect(logWarningMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         `Event Validation Error: The event type ${invalidEvent} is not supported because it's not tied to a branch or tag ref.` | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with no primary key in state outputs warning", async () => { | 
					
						
							|  |  |  |     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const savedCacheKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return ""; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledWith(`Key is not specified.`); | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save without AC available should no-op", async () => { | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | 
					
						
							|  |  |  |         () => false | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save on ghes without AC available should no-op", async () => { | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | 
					
						
							|  |  |  |         () => false | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save on GHES with AC available", async () => { | 
					
						
							|  |  |  |     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     const savedCacheKey = "Linux-node-"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return primaryKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const inputPath = "node_modules"; | 
					
						
							|  |  |  |     testUtils.setInput(Inputs.Path, inputPath); | 
					
						
							|  |  |  |     testUtils.setInput(Inputs.UploadChunkSize, "4000000"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const cacheId = 4; | 
					
						
							|  |  |  |     const saveCacheMock = jest | 
					
						
							|  |  |  |         .spyOn(cache, "saveCache") | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return Promise.resolve(cacheId); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | 
					
						
							| 
									
										
										
										
											2023-01-05 16:49:13 +05:30
										 |  |  |     expect(saveCacheMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         [inputPath], | 
					
						
							|  |  |  |         primaryKey, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             uploadChunkSize: 4000000 | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         false | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with exact match returns early", async () => { | 
					
						
							|  |  |  |     const infoMock = jest.spyOn(core, "info"); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     const savedCacheKey = primaryKey; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return primaryKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  |     expect(infoMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         `Cache hit occurred on the primary key ${primaryKey}, not saving cache.` | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with missing input outputs warning", async () => { | 
					
						
							|  |  |  |     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     const savedCacheKey = "Linux-node-"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return primaryKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         "Input required and not supplied: path" | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with large cache outputs warning", async () => { | 
					
						
							|  |  |  |     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     const savedCacheKey = "Linux-node-"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return primaryKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const inputPath = "node_modules"; | 
					
						
							|  |  |  |     testUtils.setInput(Inputs.Path, inputPath); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const saveCacheMock = jest | 
					
						
							|  |  |  |         .spyOn(cache, "saveCache") | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             throw new Error( | 
					
						
							|  |  |  |                 "Cache size of ~6144 MB (6442450944 B) is over the 5GB limit, not saving cache." | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         [inputPath], | 
					
						
							|  |  |  |         primaryKey, | 
					
						
							| 
									
										
										
										
											2023-01-05 16:49:13 +05:30
										 |  |  |         expect.anything(), | 
					
						
							|  |  |  |         false | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         "Cache size of ~6144 MB (6442450944 B) is over the 5GB limit, not saving cache." | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with reserve cache failure outputs warning", async () => { | 
					
						
							|  |  |  |     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     const savedCacheKey = "Linux-node-"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return primaryKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const inputPath = "node_modules"; | 
					
						
							|  |  |  |     testUtils.setInput(Inputs.Path, inputPath); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const saveCacheMock = jest | 
					
						
							|  |  |  |         .spyOn(cache, "saveCache") | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             const actualCache = jest.requireActual("@actions/cache"); | 
					
						
							|  |  |  |             const error = new actualCache.ReserveCacheError( | 
					
						
							|  |  |  |                 `Unable to reserve cache with key ${primaryKey}, another job may be creating this cache.` | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             throw error; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         [inputPath], | 
					
						
							|  |  |  |         primaryKey, | 
					
						
							| 
									
										
										
										
											2023-01-05 16:49:13 +05:30
										 |  |  |         expect.anything(), | 
					
						
							|  |  |  |         false | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         `Unable to reserve cache with key ${primaryKey}, another job may be creating this cache.` | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with server error outputs warning", async () => { | 
					
						
							|  |  |  |     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     const savedCacheKey = "Linux-node-"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return primaryKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const inputPath = "node_modules"; | 
					
						
							|  |  |  |     testUtils.setInput(Inputs.Path, inputPath); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const saveCacheMock = jest | 
					
						
							|  |  |  |         .spyOn(cache, "saveCache") | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             throw new Error("HTTP Error Occurred"); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         [inputPath], | 
					
						
							|  |  |  |         primaryKey, | 
					
						
							| 
									
										
										
										
											2023-01-05 16:49:13 +05:30
										 |  |  |         expect.anything(), | 
					
						
							|  |  |  |         false | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  |     expect(logWarningMock).toHaveBeenCalledWith("HTTP Error Occurred"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test("save with valid inputs uploads a cache", async () => { | 
					
						
							|  |  |  |     const failedMock = jest.spyOn(core, "setFailed"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | 
					
						
							|  |  |  |     const savedCacheKey = "Linux-node-"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     jest.spyOn(core, "getState") | 
					
						
							|  |  |  |         // Cache Entry State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return savedCacheKey; | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         // Cache Key State
 | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return primaryKey; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const inputPath = "node_modules"; | 
					
						
							|  |  |  |     testUtils.setInput(Inputs.Path, inputPath); | 
					
						
							|  |  |  |     testUtils.setInput(Inputs.UploadChunkSize, "4000000"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const cacheId = 4; | 
					
						
							|  |  |  |     const saveCacheMock = jest | 
					
						
							|  |  |  |         .spyOn(cache, "saveCache") | 
					
						
							|  |  |  |         .mockImplementationOnce(() => { | 
					
						
							|  |  |  |             return Promise.resolve(cacheId); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 15:36:58 +00:00
										 |  |  |     await saveImpl(new StateProvider()); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | 
					
						
							| 
									
										
										
										
											2023-01-05 16:49:13 +05:30
										 |  |  |     expect(saveCacheMock).toHaveBeenCalledWith( | 
					
						
							|  |  |  |         [inputPath], | 
					
						
							|  |  |  |         primaryKey, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             uploadChunkSize: 4000000 | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         false | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2022-12-21 19:38:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     expect(failedMock).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | }); |