You've already forked setup-node
							
							
				mirror of
				https://github.com/actions/setup-node.git
				synced 2025-10-26 13:05:12 +07:00 
			
		
		
		
	Add cache-key as output
This commit is contained in:
		| @ -180,6 +180,38 @@ describe('cache-restore', () => { | |||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   describe('Cache key output', () => { | ||||||
|  |     const packageManager = 'npm'; | ||||||
|  |     const cacheDependencyPath = 'package-lock.json'; | ||||||
|  |     const primaryKey = `node-cache-${platform}-${arch}-${packageManager}-${npmFileHash}`; | ||||||
|  |     const cacheKey = `node-cache-${platform}-${arch}-${packageManager}-abc123`; | ||||||
|  |  | ||||||
|  |     beforeEach(() => { | ||||||
|  |       getCommandOutputSpy.mockImplementation(command => { | ||||||
|  |         if (command.includes('npm config get cache')) return npmCachePath; | ||||||
|  |       }); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('sets the cache-key output', async () => { | ||||||
|  |       restoreCacheSpy.mockResolvedValue(cacheKey); | ||||||
|  |       await restoreCache(packageManager, cacheDependencyPath); | ||||||
|  |       expect(setOutputSpy).toHaveBeenCalledWith('cache-key', primaryKey); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('sets the cache-hit output to true when cache is found', async () => { | ||||||
|  |       restoreCacheSpy.mockResolvedValue(cacheKey); | ||||||
|  |       await restoreCache(packageManager, cacheDependencyPath); | ||||||
|  |       expect(setOutputSpy).toHaveBeenCalledWith('cache-hit', true); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('sets the cache-hit output to false when cache is not found', async () => { | ||||||
|  |       restoreCacheSpy.mockResolvedValue(undefined); | ||||||
|  |       await restoreCache(packageManager, cacheDependencyPath); | ||||||
|  |  | ||||||
|  |       expect(setOutputSpy).toHaveBeenCalledWith('cache-hit', false); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|   afterEach(() => { |   afterEach(() => { | ||||||
|     jest.resetAllMocks(); |     jest.resetAllMocks(); | ||||||
|     jest.clearAllMocks(); |     jest.clearAllMocks(); | ||||||
|  | |||||||
| @ -27,6 +27,7 @@ describe('run', () => { | |||||||
|   let setFailedSpy: jest.SpyInstance; |   let setFailedSpy: jest.SpyInstance; | ||||||
|   let getStateSpy: jest.SpyInstance; |   let getStateSpy: jest.SpyInstance; | ||||||
|   let saveCacheSpy: jest.SpyInstance; |   let saveCacheSpy: jest.SpyInstance; | ||||||
|  |   let setOutputSpy: jest.SpyInstance; | ||||||
|   let getCommandOutputSpy: jest.SpyInstance; |   let getCommandOutputSpy: jest.SpyInstance; | ||||||
|   let hashFilesSpy: jest.SpyInstance; |   let hashFilesSpy: jest.SpyInstance; | ||||||
|   let existsSpy: jest.SpyInstance; |   let existsSpy: jest.SpyInstance; | ||||||
| @ -53,6 +54,8 @@ describe('run', () => { | |||||||
|     saveCacheSpy = jest.spyOn(cache, 'saveCache'); |     saveCacheSpy = jest.spyOn(cache, 'saveCache'); | ||||||
|     saveCacheSpy.mockImplementation(() => undefined); |     saveCacheSpy.mockImplementation(() => undefined); | ||||||
|  |  | ||||||
|  |     setOutputSpy = jest.spyOn(core, 'setOutput'); | ||||||
|  |  | ||||||
|     // glob |     // glob | ||||||
|     hashFilesSpy = jest.spyOn(glob, 'hashFiles'); |     hashFilesSpy = jest.spyOn(glob, 'hashFiles'); | ||||||
|     hashFilesSpy.mockImplementation((pattern: string) => { |     hashFilesSpy.mockImplementation((pattern: string) => { | ||||||
| @ -228,6 +231,7 @@ describe('run', () => { | |||||||
|       expect(infoSpy).toHaveBeenLastCalledWith( |       expect(infoSpy).toHaveBeenLastCalledWith( | ||||||
|         `Cache saved with the key: ${npmFileHash}` |         `Cache saved with the key: ${npmFileHash}` | ||||||
|       ); |       ); | ||||||
|  |       expect(core.setOutput).toHaveBeenCalledWith('cache-key', npmFileHash); | ||||||
|       expect(setFailedSpy).not.toHaveBeenCalled(); |       expect(setFailedSpy).not.toHaveBeenCalled(); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| @ -258,6 +262,7 @@ describe('run', () => { | |||||||
|       expect(infoSpy).toHaveBeenLastCalledWith( |       expect(infoSpy).toHaveBeenLastCalledWith( | ||||||
|         `Cache saved with the key: ${npmFileHash}` |         `Cache saved with the key: ${npmFileHash}` | ||||||
|       ); |       ); | ||||||
|  |       expect(core.setOutput).toHaveBeenCalledWith('cache-key', npmFileHash); | ||||||
|       expect(setFailedSpy).not.toHaveBeenCalled(); |       expect(setFailedSpy).not.toHaveBeenCalled(); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| @ -288,6 +293,7 @@ describe('run', () => { | |||||||
|       expect(infoSpy).toHaveBeenLastCalledWith( |       expect(infoSpy).toHaveBeenLastCalledWith( | ||||||
|         `Cache saved with the key: ${yarnFileHash}` |         `Cache saved with the key: ${yarnFileHash}` | ||||||
|       ); |       ); | ||||||
|  |       expect(core.setOutput).toHaveBeenCalledWith('cache-key', yarnFileHash); | ||||||
|       expect(setFailedSpy).not.toHaveBeenCalled(); |       expect(setFailedSpy).not.toHaveBeenCalled(); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| @ -297,9 +303,9 @@ describe('run', () => { | |||||||
|         key === State.CachePackageManager |         key === State.CachePackageManager | ||||||
|           ? inputs['cache'] |           ? inputs['cache'] | ||||||
|           : key === State.CacheMatchedKey |           : key === State.CacheMatchedKey | ||||||
|           ? pnpmFileHash |           ? 'no-match' | ||||||
|           : key === State.CachePrimaryKey |           : key === State.CachePrimaryKey | ||||||
|           ? npmFileHash |           ? pnpmFileHash | ||||||
|           : key === State.CachePaths |           : key === State.CachePaths | ||||||
|           ? '["/foo/bar"]' |           ? '["/foo/bar"]' | ||||||
|           : 'not expected' |           : 'not expected' | ||||||
| @ -316,8 +322,9 @@ describe('run', () => { | |||||||
|       ); |       ); | ||||||
|       expect(saveCacheSpy).toHaveBeenCalled(); |       expect(saveCacheSpy).toHaveBeenCalled(); | ||||||
|       expect(infoSpy).toHaveBeenLastCalledWith( |       expect(infoSpy).toHaveBeenLastCalledWith( | ||||||
|         `Cache saved with the key: ${npmFileHash}` |         `Cache saved with the key: ${pnpmFileHash}` | ||||||
|       ); |       ); | ||||||
|  |       expect(core.setOutput).toHaveBeenCalledWith('cache-key', pnpmFileHash); | ||||||
|       expect(setFailedSpy).not.toHaveBeenCalled(); |       expect(setFailedSpy).not.toHaveBeenCalled(); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|  | |||||||
| @ -30,6 +30,8 @@ inputs: | |||||||
| outputs: | outputs: | ||||||
|   cache-hit:  |   cache-hit:  | ||||||
|     description: 'A boolean value to indicate if a cache was hit.' |     description: 'A boolean value to indicate if a cache was hit.' | ||||||
|  |   cache-key: | ||||||
|  |     description: 'The key used for the cache.' | ||||||
|   node-version: |   node-version: | ||||||
|     description: 'The installed node version.' |     description: 'The installed node version.' | ||||||
| runs: | runs: | ||||||
|  | |||||||
| @ -45,6 +45,7 @@ export const restoreCache = async ( | |||||||
|   core.debug(`primary key is ${primaryKey}`); |   core.debug(`primary key is ${primaryKey}`); | ||||||
|  |  | ||||||
|   core.saveState(State.CachePrimaryKey, primaryKey); |   core.saveState(State.CachePrimaryKey, primaryKey); | ||||||
|  |   core.setOutput('cache-key', primaryKey); | ||||||
|  |  | ||||||
|   const isManagedByYarnBerry = await repoHasYarnBerryManagedDependencies( |   const isManagedByYarnBerry = await repoHasYarnBerryManagedDependencies( | ||||||
|     packageManagerInfo, |     packageManagerInfo, | ||||||
|  | |||||||
| @ -66,6 +66,7 @@ const cachePackages = async (packageManager: string) => { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   core.info(`Cache saved with the key: ${primaryKey}`); |   core.info(`Cache saved with the key: ${primaryKey}`); | ||||||
|  |   core.setOutput('cache-key', primaryKey); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| run(true); | run(true); | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Alex Dunae
					Alex Dunae