mirror of
https://github.com/actions/labeler.git
synced 2025-12-10 03:26:44 +00:00
117 lines
3.3 KiB
TypeScript
117 lines
3.3 KiB
TypeScript
import { run } from "../src/labeler";
|
|
import { GitHub } from "@actions/github";
|
|
import * as core from "@actions/core";
|
|
|
|
const fs = jest.requireActual("fs");
|
|
|
|
jest.mock("@actions/core");
|
|
jest.mock("@actions/github");
|
|
|
|
const gh = new GitHub("_");
|
|
const addLabelsMock = jest.spyOn(gh.issues, "addLabels");
|
|
const removeLabelMock = jest.spyOn(gh.issues, "removeLabel");
|
|
const reposMock = jest.spyOn(gh.repos, "getContents");
|
|
const paginateMock = jest.spyOn(gh, "paginate");
|
|
const getPullMock = jest.spyOn(gh.pulls, "get");
|
|
|
|
const yamlFixtures = {
|
|
"only_pdfs.yml": fs.readFileSync("__tests__/fixtures/only_pdfs.yml"),
|
|
};
|
|
|
|
afterAll(() => jest.restoreAllMocks());
|
|
|
|
describe("run", () => {
|
|
it("adds labels to PRs that match our glob patterns", async () => {
|
|
usingLabelerConfigYaml("only_pdfs.yml");
|
|
mockGitHubResponseChangedFiles("foo.pdf");
|
|
|
|
await run();
|
|
|
|
expect(removeLabelMock).toHaveBeenCalledTimes(0);
|
|
expect(addLabelsMock).toHaveBeenCalledTimes(1);
|
|
expect(addLabelsMock).toHaveBeenCalledWith({
|
|
owner: "monalisa",
|
|
repo: "helloworld",
|
|
issue_number: 123,
|
|
labels: ["touched-a-pdf-file"],
|
|
});
|
|
});
|
|
|
|
it("does not add labels to PRs that do not match our glob patterns", async () => {
|
|
usingLabelerConfigYaml("only_pdfs.yml");
|
|
mockGitHubResponseChangedFiles("foo.txt");
|
|
|
|
await run();
|
|
|
|
expect(removeLabelMock).toHaveBeenCalledTimes(0);
|
|
expect(addLabelsMock).toHaveBeenCalledTimes(0);
|
|
});
|
|
|
|
it("(with sync-labels: true) it deletes preexisting PR labels that no longer match the glob pattern", async () => {
|
|
let mockInput = {
|
|
"repo-token": "foo",
|
|
"configuration-path": "bar",
|
|
"sync-labels": true,
|
|
};
|
|
|
|
jest
|
|
.spyOn(core, "getInput")
|
|
.mockImplementation((name: string, ...opts) => mockInput[name]);
|
|
|
|
usingLabelerConfigYaml("only_pdfs.yml");
|
|
mockGitHubResponseChangedFiles("foo.txt");
|
|
getPullMock.mockResolvedValue(<any>{
|
|
data: {
|
|
labels: [{ name: "touched-a-pdf-file" }],
|
|
},
|
|
});
|
|
|
|
await run();
|
|
|
|
expect(addLabelsMock).toHaveBeenCalledTimes(0);
|
|
expect(removeLabelMock).toHaveBeenCalledTimes(1);
|
|
expect(removeLabelMock).toHaveBeenCalledWith({
|
|
owner: "monalisa",
|
|
repo: "helloworld",
|
|
issue_number: 123,
|
|
name: "touched-a-pdf-file",
|
|
});
|
|
});
|
|
|
|
it("(with sync-labels: false) it issues no delete calls even when there are preexisting PR labels that no longer match the glob pattern", async () => {
|
|
let mockInput = {
|
|
"repo-token": "foo",
|
|
"configuration-path": "bar",
|
|
"sync-labels": false,
|
|
};
|
|
|
|
jest
|
|
.spyOn(core, "getInput")
|
|
.mockImplementation((name: string, ...opts) => mockInput[name]);
|
|
|
|
usingLabelerConfigYaml("only_pdfs.yml");
|
|
mockGitHubResponseChangedFiles("foo.txt");
|
|
getPullMock.mockResolvedValue(<any>{
|
|
data: {
|
|
labels: [{ name: "touched-a-pdf-file" }],
|
|
},
|
|
});
|
|
|
|
await run();
|
|
|
|
expect(addLabelsMock).toHaveBeenCalledTimes(0);
|
|
expect(removeLabelMock).toHaveBeenCalledTimes(0);
|
|
});
|
|
});
|
|
|
|
function usingLabelerConfigYaml(fixtureName: keyof typeof yamlFixtures): void {
|
|
reposMock.mockResolvedValue(<any>{
|
|
data: { content: yamlFixtures[fixtureName], encoding: "utf8" },
|
|
});
|
|
}
|
|
|
|
function mockGitHubResponseChangedFiles(...files: string[]): void {
|
|
const returnValue = files.map((f) => ({ filename: f }));
|
|
paginateMock.mockReturnValue(<any>returnValue);
|
|
}
|