mirror of https://github.com/actions/setup-go.git
				
				
				
			
		
			
				
	
	
		
			100 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
| import * as cache from '@actions/cache';
 | |
| import * as core from '@actions/core';
 | |
| import * as glob from '@actions/glob';
 | |
| 
 | |
| import * as cacheRestore from '../src/cache-restore';
 | |
| import * as cacheUtils from '../src/cache-utils';
 | |
| import {PackageManagerInfo} from '../src/package-managers';
 | |
| 
 | |
| describe('restoreCache', () => {
 | |
|   //Arrange
 | |
|   const hashFilesSpy = jest.spyOn(glob, 'hashFiles');
 | |
|   const getCacheDirectoryPathSpy = jest.spyOn(
 | |
|     cacheUtils,
 | |
|     'getCacheDirectoryPath'
 | |
|   );
 | |
|   const restoreCacheSpy = jest.spyOn(cache, 'restoreCache');
 | |
|   const infoSpy = jest.spyOn(core, 'info');
 | |
|   const setOutputSpy = jest.spyOn(core, 'setOutput');
 | |
| 
 | |
|   const versionSpec = '1.13.1';
 | |
|   const packageManager = 'default';
 | |
|   const cacheDependencyPath = 'path';
 | |
| 
 | |
|   beforeEach(() => {
 | |
|     getCacheDirectoryPathSpy.mockImplementation(
 | |
|       (PackageManager: PackageManagerInfo) => {
 | |
|         return new Promise<string[]>(resolve => {
 | |
|           resolve(['cache_directory_path', 'cache_directory_path']);
 | |
|         });
 | |
|       }
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('should throw if dependency file path is not valid', async () => {
 | |
|     //Arrange
 | |
|     hashFilesSpy.mockImplementation((somePath: string) => {
 | |
|       return new Promise<string>(resolve => {
 | |
|         resolve('');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     //Act + Assert
 | |
|     await expect(async () => {
 | |
|       await cacheRestore.restoreCache(
 | |
|         versionSpec,
 | |
|         packageManager,
 | |
|         cacheDependencyPath
 | |
|       );
 | |
|     }).rejects.toThrow(
 | |
|       'Some specified paths were not resolved, unable to cache dependencies.'
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('should inform if cache hit is not occurred', async () => {
 | |
|     //Arrange
 | |
|     hashFilesSpy.mockImplementation((somePath: string) => {
 | |
|       return new Promise<string>(resolve => {
 | |
|         resolve('file_hash');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     restoreCacheSpy.mockImplementation(() => {
 | |
|       return new Promise<string>(resolve => {
 | |
|         resolve('');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     //Act + Assert
 | |
|     await cacheRestore.restoreCache(
 | |
|       versionSpec,
 | |
|       packageManager,
 | |
|       cacheDependencyPath
 | |
|     );
 | |
|     expect(infoSpy).toHaveBeenCalledWith(`Cache is not found`);
 | |
|   });
 | |
| 
 | |
|   it('should set output if cache hit is occurred', async () => {
 | |
|     //Arrange
 | |
|     hashFilesSpy.mockImplementation((somePath: string) => {
 | |
|       return new Promise<string>(resolve => {
 | |
|         resolve('file_hash');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     restoreCacheSpy.mockImplementation(() => {
 | |
|       return new Promise<string>(resolve => {
 | |
|         resolve('cache_key');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     //Act + Assert
 | |
|     await cacheRestore.restoreCache(
 | |
|       versionSpec,
 | |
|       packageManager,
 | |
|       cacheDependencyPath
 | |
|     );
 | |
|     expect(setOutputSpy).toHaveBeenCalledWith('cache-hit', true);
 | |
|   });
 | |
| });
 |