mirror of
https://code.forgejo.org/actions/cache.git
synced 2025-01-11 04:36:56 +01:00
Fixed test cases
This commit is contained in:
parent
5b7eeecaeb
commit
667e98af5a
7 changed files with 47 additions and 13 deletions
|
@ -15,6 +15,10 @@ beforeAll(() => {
|
|||
return testUtils.getInput(name);
|
||||
});
|
||||
|
||||
jest.spyOn(core, "getState").mockImplementation(name => {
|
||||
return jest.requireActual("@actions/core").getState(name);
|
||||
});
|
||||
|
||||
jest.spyOn(actionUtils, "getInputAsArray").mockImplementation(
|
||||
(name, options) => {
|
||||
return jest
|
||||
|
|
|
@ -1,11 +1,12 @@
|
|||
import * as core from "@actions/core";
|
||||
|
||||
import { Events, RefKey, State } from "../src/constants";
|
||||
import { Events, Inputs, RefKey, State } from "../src/constants";
|
||||
import {
|
||||
IStateProvider,
|
||||
NullStateProvider,
|
||||
StateProvider
|
||||
} from "../src/stateProvider";
|
||||
import * as testUtils from "../src/utils/testUtils";
|
||||
|
||||
jest.mock("@actions/core");
|
||||
|
||||
|
@ -62,7 +63,7 @@ test("NullStateProvider saves outputs", async () => {
|
|||
|
||||
const getInputMock = jest
|
||||
.spyOn(core, "getInput")
|
||||
.mockImplementation(key => states.get(key) || "");
|
||||
.mockImplementation(key => testUtils.getInput(key));
|
||||
|
||||
const getStateMock = jest
|
||||
.spyOn(core, "getState")
|
||||
|
@ -73,7 +74,7 @@ test("NullStateProvider saves outputs", async () => {
|
|||
const setOutputMock = jest
|
||||
.spyOn(core, "setOutput")
|
||||
.mockImplementation((key, value) => {
|
||||
return jest.requireActual("@actions/core").setOutput(key, value);
|
||||
states.set(key, value);
|
||||
});
|
||||
|
||||
const saveStateMock = jest
|
||||
|
@ -83,14 +84,18 @@ test("NullStateProvider saves outputs", async () => {
|
|||
});
|
||||
|
||||
const cacheMatchedKey = "node-cache";
|
||||
const cachePrimaryKey = "primary-key";
|
||||
const nullStateProvider: IStateProvider = new NullStateProvider();
|
||||
nullStateProvider.setState(State.CacheMatchedKey, "outputValue");
|
||||
nullStateProvider.setState(State.CachePrimaryKey, cacheMatchedKey);
|
||||
nullStateProvider.getState("outputKey");
|
||||
nullStateProvider.getCacheState();
|
||||
testUtils.setInput(Inputs.Key, cachePrimaryKey);
|
||||
nullStateProvider.setState(State.CachePrimaryKey, cachePrimaryKey);
|
||||
nullStateProvider.setState(State.CacheMatchedKey, cacheMatchedKey);
|
||||
const output1 = nullStateProvider.getState(State.CachePrimaryKey);
|
||||
const output2 = nullStateProvider.getCacheState();
|
||||
|
||||
expect(getStateMock).toHaveBeenCalledTimes(0);
|
||||
expect(getInputMock).toHaveBeenCalledTimes(2);
|
||||
expect(getInputMock).toHaveBeenCalledTimes(1);
|
||||
expect(output1).toBe("primary-key");
|
||||
expect(output2).toBe(undefined);
|
||||
expect(setOutputMock).toHaveBeenCalledTimes(2);
|
||||
expect(saveStateMock).toHaveBeenCalledTimes(0);
|
||||
});
|
||||
|
|
5
dist/restore-only/index.js
vendored
5
dist/restore-only/index.js
vendored
|
@ -9413,9 +9413,14 @@ class NullStateProvider extends StateProviderBase {
|
|||
[constants_1.State.CachePrimaryKey, constants_1.Outputs.CachePrimaryKey]
|
||||
]);
|
||||
this.setState = (key, value) => {
|
||||
if (this.stateToOutputMap.has(key)) {
|
||||
core.setOutput(this.stateToOutputMap.get(key), value);
|
||||
}
|
||||
};
|
||||
this.getState = (key) => {
|
||||
if (!this.stateToInputMap.has(key)) {
|
||||
return "";
|
||||
}
|
||||
return core.getInput(this.stateToInputMap.get(key));
|
||||
};
|
||||
}
|
||||
|
|
5
dist/restore/index.js
vendored
5
dist/restore/index.js
vendored
|
@ -9413,9 +9413,14 @@ class NullStateProvider extends StateProviderBase {
|
|||
[constants_1.State.CachePrimaryKey, constants_1.Outputs.CachePrimaryKey]
|
||||
]);
|
||||
this.setState = (key, value) => {
|
||||
if (this.stateToOutputMap.has(key)) {
|
||||
core.setOutput(this.stateToOutputMap.get(key), value);
|
||||
}
|
||||
};
|
||||
this.getState = (key) => {
|
||||
if (!this.stateToInputMap.has(key)) {
|
||||
return "";
|
||||
}
|
||||
return core.getInput(this.stateToInputMap.get(key));
|
||||
};
|
||||
}
|
||||
|
|
5
dist/save-only/index.js
vendored
5
dist/save-only/index.js
vendored
|
@ -9469,9 +9469,14 @@ class NullStateProvider extends StateProviderBase {
|
|||
[constants_1.State.CachePrimaryKey, constants_1.Outputs.CachePrimaryKey]
|
||||
]);
|
||||
this.setState = (key, value) => {
|
||||
if (this.stateToOutputMap.has(key)) {
|
||||
core.setOutput(this.stateToOutputMap.get(key), value);
|
||||
}
|
||||
};
|
||||
this.getState = (key) => {
|
||||
if (!this.stateToInputMap.has(key)) {
|
||||
return "";
|
||||
}
|
||||
return core.getInput(this.stateToInputMap.get(key));
|
||||
};
|
||||
}
|
||||
|
|
5
dist/save/index.js
vendored
5
dist/save/index.js
vendored
|
@ -9413,9 +9413,14 @@ class NullStateProvider extends StateProviderBase {
|
|||
[constants_1.State.CachePrimaryKey, constants_1.Outputs.CachePrimaryKey]
|
||||
]);
|
||||
this.setState = (key, value) => {
|
||||
if (this.stateToOutputMap.has(key)) {
|
||||
core.setOutput(this.stateToOutputMap.get(key), value);
|
||||
}
|
||||
};
|
||||
this.getState = (key) => {
|
||||
if (!this.stateToInputMap.has(key)) {
|
||||
return "";
|
||||
}
|
||||
return core.getInput(this.stateToInputMap.get(key));
|
||||
};
|
||||
}
|
||||
|
|
|
@ -43,10 +43,15 @@ export class NullStateProvider extends StateProviderBase {
|
|||
]);
|
||||
|
||||
setState = (key: string, value: string) => {
|
||||
if (this.stateToOutputMap.has(key)) {
|
||||
core.setOutput(this.stateToOutputMap.get(key) as string, value);
|
||||
}
|
||||
};
|
||||
|
||||
getState = (key: string) => {
|
||||
if (!this.stateToInputMap.has(key)) {
|
||||
return "";
|
||||
}
|
||||
return core.getInput(this.stateToInputMap.get(key) as string);
|
||||
};
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue