|
|
|
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.restoreModCache(
|
|
|
|
versionSpec,
|
|
|
|
packageManager,
|
|
|
|
cacheDependencyPath
|
|
|
|
);
|
|
|
|
}).rejects.toThrow(
|
|
|
|
'Some specified paths were not resolved, unable to cache dependencies.'
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should inform if cache hit is not occured', 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.restoreModCache(
|
|
|
|
versionSpec,
|
|
|
|
packageManager,
|
|
|
|
cacheDependencyPath
|
|
|
|
);
|
|
|
|
expect(infoSpy).toHaveBeenCalledWith(`Cache is not found`);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should set output if cache hit is occured', 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.restoreModCache(
|
|
|
|
versionSpec,
|
|
|
|
packageManager,
|
|
|
|
cacheDependencyPath
|
|
|
|
);
|
|
|
|
expect(setOutputSpy).toHaveBeenCalledWith('cache-hit', true);
|
|
|
|
});
|
|
|
|
});
|