1
0
Files
cache/__tests__/save.test.ts
T

101 lines
3.1 KiB
TypeScript
Raw Normal View History

2026-05-20 20:18:29 +00:00
import { afterEach, beforeEach, expect, jest, test } from "@jest/globals";
2026-05-20 19:31:39 +00:00
// Mock @actions/core
jest.unstable_mockModule("@actions/core", () => ({
getInput: jest.fn((name: string, options?: { required?: boolean }) => {
const val =
process.env[`INPUT_${name.replace(/ /g, "_").toUpperCase()}`] || "";
if (options && options.required && !val) {
throw new Error(`Input required and not supplied: ${name}`);
2020-06-02 10:21:03 -05:00
}
2026-05-20 19:31:39 +00:00
return val.trim();
}),
setOutput: jest.fn(),
setFailed: jest.fn(),
info: jest.fn(),
warning: jest.fn(),
debug: jest.fn(),
error: jest.fn(),
saveState: jest.fn(),
getState: jest.fn(() => ""),
isDebug: jest.fn(() => false),
exportVariable: jest.fn(),
addPath: jest.fn(),
group: jest.fn((name: string, fn: () => Promise<unknown>) => fn()),
startGroup: jest.fn(),
endGroup: jest.fn()
}));
// Mock @actions/cache
jest.unstable_mockModule("@actions/cache", () => ({
restoreCache: jest.fn(),
saveCache: jest.fn(),
isFeatureAvailable: jest.fn(() => true),
ReserveCacheError: class ReserveCacheError extends Error {
constructor(message: string) {
super(message);
this.name = "ReserveCacheError";
2020-10-02 09:59:55 -05:00
}
2026-05-20 19:31:39 +00:00
}
}));
2020-10-02 09:59:55 -05:00
2026-05-20 19:31:39 +00:00
const core = await import("@actions/core");
const cache = await import("@actions/cache");
const { Events, Inputs, RefKey } = await import("../src/constants");
const { saveRun } = await import("../src/saveImpl");
const testUtils = await import("../src/utils/testUtils");
2026-05-20 19:31:39 +00:00
beforeEach(() => {
jest.clearAllMocks();
(core.getInput as jest.Mock).mockImplementation(
(name: string, options?: { required?: boolean }) => {
const val =
2026-05-20 20:18:29 +00:00
process.env[`INPUT_${name.replace(/ /g, "_").toUpperCase()}`] ||
"";
2026-05-20 19:31:39 +00:00
if (options && options.required && !val) {
2026-05-20 20:18:29 +00:00
throw new Error(`Input required and not supplied: ${name}`);
2026-05-20 19:31:39 +00:00
}
return val.trim();
2019-11-14 17:14:16 -05:00
}
);
2026-05-20 19:31:39 +00:00
(cache.isFeatureAvailable as jest.Mock).mockReturnValue(true);
process.env[Events.Key] = Events.Push;
2020-04-17 15:46:46 -04:00
process.env[RefKey] = "refs/heads/feature-branch";
});
2019-11-14 17:14:16 -05:00
afterEach(() => {
testUtils.clearInputs();
delete process.env[Events.Key];
2020-04-17 15:46:46 -04:00
delete process.env[RefKey];
});
2022-12-21 19:38:44 +05:30
test("save with valid inputs uploads a cache", async () => {
2019-11-14 17:14:16 -05:00
const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43";
const savedCacheKey = "Linux-node-";
2019-11-14 17:14:16 -05:00
2026-05-20 19:31:39 +00:00
(core.getState as jest.Mock)
.mockReturnValueOnce(primaryKey)
.mockReturnValueOnce(savedCacheKey);
2019-11-14 17:14:16 -05:00
const inputPath = "node_modules";
testUtils.setInput(Inputs.Path, inputPath);
2020-10-02 09:59:55 -05:00
testUtils.setInput(Inputs.UploadChunkSize, "4000000");
2019-11-14 17:14:16 -05:00
2020-01-06 13:05:50 -05:00
const cacheId = 4;
2026-05-20 19:31:39 +00:00
(cache.saveCache as jest.Mock).mockResolvedValue(cacheId);
2020-01-06 13:05:50 -05:00
2024-01-10 15:36:58 +00:00
await saveRun();
2019-11-14 17:14:16 -05:00
2026-05-20 19:31:39 +00:00
expect(cache.saveCache).toHaveBeenCalledTimes(1);
expect(cache.saveCache).toHaveBeenCalledWith(
[inputPath],
primaryKey,
{
uploadChunkSize: 4000000
},
false
);
2019-11-14 17:14:16 -05:00
2026-05-20 19:31:39 +00:00
expect(core.setFailed).toHaveBeenCalledTimes(0);
2019-11-14 17:14:16 -05:00
});