Merge pull request #263 from actions/users/aiyan/allow-all-events
Allow all events to access cache
This commit is contained in:
		| @@ -4,7 +4,7 @@ import { promises as fs } from "fs"; | ||||
| import * as os from "os"; | ||||
| import * as path from "path"; | ||||
|  | ||||
| import { Events, Outputs, State } from "../src/constants"; | ||||
| import { Events, Outputs, RefKey, State } from "../src/constants"; | ||||
| import { ArtifactCacheEntry } from "../src/contracts"; | ||||
| import * as actionUtils from "../src/utils/actionUtils"; | ||||
|  | ||||
| @@ -19,6 +19,7 @@ function getTempDir(): string { | ||||
|  | ||||
| afterEach(() => { | ||||
|     delete process.env[Events.Key]; | ||||
|     delete process.env[RefKey]; | ||||
| }); | ||||
|  | ||||
| afterAll(async () => { | ||||
| @@ -185,7 +186,7 @@ test("logWarning logs a message with a warning prefix", () => { | ||||
|     expect(infoMock).toHaveBeenCalledWith(`[warning]${message}`); | ||||
| }); | ||||
|  | ||||
| test("isValidEvent returns false for unknown event", () => { | ||||
| test("isValidEvent returns false for event that does not have a branch or tag", () => { | ||||
|     const event = "foo"; | ||||
|     process.env[Events.Key] = event; | ||||
|  | ||||
| @@ -325,18 +326,10 @@ test("resolvePaths exclusion pattern returns not found", async () => { | ||||
|     } | ||||
| }); | ||||
|  | ||||
| test("isValidEvent returns true for push event", () => { | ||||
| test("isValidEvent returns true for event that has a ref", () => { | ||||
|     const event = Events.Push; | ||||
|     process.env[Events.Key] = event; | ||||
|  | ||||
|     const isValidEvent = actionUtils.isValidEvent(); | ||||
|  | ||||
|     expect(isValidEvent).toBe(true); | ||||
| }); | ||||
|  | ||||
| test("isValidEvent returns true for pull request event", () => { | ||||
|     const event = Events.PullRequest; | ||||
|     process.env[Events.Key] = event; | ||||
|     process.env[RefKey] = "ref/heads/feature"; | ||||
|  | ||||
|     const isValidEvent = actionUtils.isValidEvent(); | ||||
|  | ||||
|   | ||||
| @@ -6,7 +6,8 @@ import { | ||||
|     CacheFilename, | ||||
|     CompressionMethod, | ||||
|     Events, | ||||
|     Inputs | ||||
|     Inputs, | ||||
|     RefKey | ||||
| } from "../src/constants"; | ||||
| import { ArtifactCacheEntry } from "../src/contracts"; | ||||
| import run from "../src/restore"; | ||||
| @@ -31,11 +32,6 @@ beforeAll(() => { | ||||
|         return actualUtils.isValidEvent(); | ||||
|     }); | ||||
|  | ||||
|     jest.spyOn(actionUtils, "getSupportedEvents").mockImplementation(() => { | ||||
|         const actualUtils = jest.requireActual("../src/utils/actionUtils"); | ||||
|         return actualUtils.getSupportedEvents(); | ||||
|     }); | ||||
|  | ||||
|     jest.spyOn(actionUtils, "getCacheFileName").mockImplementation(cm => { | ||||
|         const actualUtils = jest.requireActual("../src/utils/actionUtils"); | ||||
|         return actualUtils.getCacheFileName(cm); | ||||
| @@ -44,11 +40,13 @@ beforeAll(() => { | ||||
|  | ||||
| beforeEach(() => { | ||||
|     process.env[Events.Key] = Events.Push; | ||||
|     process.env[RefKey] = "refs/heads/feature-branch"; | ||||
| }); | ||||
|  | ||||
| afterEach(() => { | ||||
|     testUtils.clearInputs(); | ||||
|     delete process.env[Events.Key]; | ||||
|     delete process.env[RefKey]; | ||||
| }); | ||||
|  | ||||
| test("restore with invalid event outputs warning", async () => { | ||||
| @@ -56,9 +54,10 @@ test("restore with invalid event outputs warning", async () => { | ||||
|     const failedMock = jest.spyOn(core, "setFailed"); | ||||
|     const invalidEvent = "commit_comment"; | ||||
|     process.env[Events.Key] = invalidEvent; | ||||
|     delete process.env[RefKey]; | ||||
|     await run(); | ||||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         `Event Validation Error: The event type ${invalidEvent} is not supported. Only push, pull_request events are supported at this time.` | ||||
|         `Event Validation Error: The event type ${invalidEvent} is not supported because it's not tied to a branch or tag ref.` | ||||
|     ); | ||||
|     expect(failedMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
|   | ||||
| @@ -6,7 +6,8 @@ import { | ||||
|     CacheFilename, | ||||
|     CompressionMethod, | ||||
|     Events, | ||||
|     Inputs | ||||
|     Inputs, | ||||
|     RefKey | ||||
| } from "../src/constants"; | ||||
| import { ArtifactCacheEntry } from "../src/contracts"; | ||||
| import run from "../src/save"; | ||||
| @@ -41,11 +42,6 @@ beforeAll(() => { | ||||
|         return actualUtils.isValidEvent(); | ||||
|     }); | ||||
|  | ||||
|     jest.spyOn(actionUtils, "getSupportedEvents").mockImplementation(() => { | ||||
|         const actualUtils = jest.requireActual("../src/utils/actionUtils"); | ||||
|         return actualUtils.getSupportedEvents(); | ||||
|     }); | ||||
|  | ||||
|     jest.spyOn(actionUtils, "resolvePaths").mockImplementation( | ||||
|         async filePaths => { | ||||
|             return filePaths.map(x => path.resolve(x)); | ||||
| @@ -64,11 +60,13 @@ beforeAll(() => { | ||||
|  | ||||
| beforeEach(() => { | ||||
|     process.env[Events.Key] = Events.Push; | ||||
|     process.env[RefKey] = "refs/heads/feature-branch"; | ||||
| }); | ||||
|  | ||||
| afterEach(() => { | ||||
|     testUtils.clearInputs(); | ||||
|     delete process.env[Events.Key]; | ||||
|     delete process.env[RefKey]; | ||||
| }); | ||||
|  | ||||
| test("save with invalid event outputs warning", async () => { | ||||
| @@ -76,9 +74,10 @@ test("save with invalid event outputs warning", async () => { | ||||
|     const failedMock = jest.spyOn(core, "setFailed"); | ||||
|     const invalidEvent = "commit_comment"; | ||||
|     process.env[Events.Key] = invalidEvent; | ||||
|     delete process.env[RefKey]; | ||||
|     await run(); | ||||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         `Event Validation Error: The event type ${invalidEvent} is not supported. Only push, pull_request events are supported at this time.` | ||||
|         `Event Validation Error: The event type ${invalidEvent} is not supported because it's not tied to a branch or tag ref.` | ||||
|     ); | ||||
|     expect(failedMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Aiqiao Yan
					Aiqiao Yan