2023-03-09 14:49:35 +02:00
|
|
|
import {run as cleanup} from '../src/cleanup-java';
|
2021-08-20 01:19:35 +08:00
|
|
|
import * as core from '@actions/core';
|
|
|
|
import * as cache from '@actions/cache';
|
|
|
|
import * as util from '../src/util';
|
|
|
|
|
|
|
|
describe('cleanup', () => {
|
|
|
|
let spyWarning: jest.SpyInstance<void, Parameters<typeof core.warning>>;
|
2021-08-23 11:54:48 +03:00
|
|
|
let spyInfo: jest.SpyInstance<void, Parameters<typeof core.info>>;
|
2021-08-20 01:19:35 +08:00
|
|
|
let spyCacheSave: jest.SpyInstance<
|
|
|
|
ReturnType<typeof cache.saveCache>,
|
|
|
|
Parameters<typeof cache.saveCache>
|
|
|
|
>;
|
|
|
|
let spyJobStatusSuccess: jest.SpyInstance;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
spyWarning = jest.spyOn(core, 'warning');
|
2021-08-23 11:54:48 +03:00
|
|
|
spyWarning.mockImplementation(() => null);
|
|
|
|
spyInfo = jest.spyOn(core, 'info');
|
|
|
|
spyInfo.mockImplementation(() => null);
|
2021-08-20 01:19:35 +08:00
|
|
|
spyCacheSave = jest.spyOn(cache, 'saveCache');
|
|
|
|
spyJobStatusSuccess = jest.spyOn(util, 'isJobStatusSuccess');
|
|
|
|
spyJobStatusSuccess.mockReturnValue(true);
|
|
|
|
createStateForSuccessfulRestore();
|
|
|
|
});
|
|
|
|
afterEach(() => {
|
|
|
|
resetState();
|
|
|
|
});
|
|
|
|
|
2024-12-19 10:57:06 -05:00
|
|
|
it('does not warn/fail even when the save process throws a ReserveCacheError', async () => {
|
2021-08-20 01:19:35 +08:00
|
|
|
spyCacheSave.mockImplementation((paths: string[], key: string) =>
|
|
|
|
Promise.reject(
|
|
|
|
new cache.ReserveCacheError(
|
|
|
|
'Unable to reserve cache with key, another job may be creating this cache.'
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
jest.spyOn(core, 'getInput').mockImplementation((name: string) => {
|
|
|
|
return name === 'cache' ? 'gradle' : '';
|
|
|
|
});
|
|
|
|
await cleanup();
|
2023-03-09 14:49:35 +02:00
|
|
|
expect(spyCacheSave).toHaveBeenCalled();
|
|
|
|
expect(spyWarning).not.toHaveBeenCalled();
|
2021-08-20 01:19:35 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it('does not fail even though the save process throws error', async () => {
|
|
|
|
spyCacheSave.mockImplementation((paths: string[], key: string) =>
|
|
|
|
Promise.reject(new Error('Unexpected error'))
|
|
|
|
);
|
|
|
|
jest.spyOn(core, 'getInput').mockImplementation((name: string) => {
|
|
|
|
return name === 'cache' ? 'gradle' : '';
|
|
|
|
});
|
|
|
|
await cleanup();
|
2023-03-09 14:49:35 +02:00
|
|
|
expect(spyCacheSave).toHaveBeenCalled();
|
2021-08-20 01:19:35 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function resetState() {
|
|
|
|
jest.spyOn(core, 'getState').mockReset();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create states to emulate a successful restore process.
|
|
|
|
*/
|
|
|
|
function createStateForSuccessfulRestore() {
|
|
|
|
jest.spyOn(core, 'getState').mockImplementation(name => {
|
|
|
|
switch (name) {
|
|
|
|
case 'cache-primary-key':
|
|
|
|
return 'setup-java-cache-primary-key';
|
|
|
|
case 'cache-matched-key':
|
|
|
|
return 'setup-java-cache-matched-key';
|
|
|
|
default:
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|