2020-02-22 06:08:54 +01:00
|
|
|
const path = require("path");
|
|
|
|
const {
|
|
|
|
getRepoPath,
|
|
|
|
execGit,
|
|
|
|
addConfigOption,
|
|
|
|
unsetConfigOption,
|
|
|
|
configOptionExists,
|
|
|
|
getConfigOption,
|
|
|
|
getAndUnsetConfigOption
|
|
|
|
} = require("./git");
|
|
|
|
|
|
|
|
test("getRepoPath", async () => {
|
|
|
|
expect(getRepoPath()).toEqual(process.env["GITHUB_WORKSPACE"]);
|
|
|
|
expect(getRepoPath("foo")).toEqual(
|
|
|
|
path.resolve(process.env["GITHUB_WORKSPACE"], "foo")
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("execGit", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const result = await execGit(
|
|
|
|
repoPath,
|
|
|
|
["config", "--local", "--name-only", "--get-regexp", "remote.origin.url"],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
expect(result.exitCode).toEqual(0);
|
|
|
|
expect(result.stdout.trim()).toEqual("remote.origin.url");
|
|
|
|
});
|
|
|
|
|
|
|
|
test("add and unset config option", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
2020-02-22 08:56:39 +01:00
|
|
|
const add = await addConfigOption(repoPath, "test.add.and.unset.config.option", "foo");
|
2020-02-22 06:08:54 +01:00
|
|
|
expect(add).toBeTruthy();
|
|
|
|
const unset = await unsetConfigOption(repoPath, "test.add.and.unset.config.option");
|
|
|
|
expect(unset).toBeTruthy();
|
|
|
|
});
|
|
|
|
|
2020-02-22 08:56:39 +01:00
|
|
|
test("add and unset config option with value regex", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const add = await addConfigOption(repoPath, "test.add.and.unset.config.option", "foo bar");
|
|
|
|
expect(add).toBeTruthy();
|
|
|
|
const unset = await unsetConfigOption(repoPath, "test.add.and.unset.config.option", "^foo");
|
|
|
|
expect(unset).toBeTruthy();
|
|
|
|
});
|
|
|
|
|
2020-02-22 06:08:54 +01:00
|
|
|
test("configOptionExists returns true", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const result = await configOptionExists(repoPath, "remote.origin.url");
|
|
|
|
expect(result).toBeTruthy();
|
|
|
|
});
|
|
|
|
|
|
|
|
test("configOptionExists returns false", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const result = await configOptionExists(repoPath, "this.key.does.not.exist");
|
|
|
|
expect(result).toBeFalsy();
|
|
|
|
});
|
|
|
|
|
|
|
|
test("get config option", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const add = await addConfigOption(repoPath, "test.get.config.option", "foo");
|
|
|
|
expect(add).toBeTruthy();
|
2020-02-22 08:56:39 +01:00
|
|
|
const option = await getConfigOption(repoPath, "test.get.config.option");
|
|
|
|
expect(option.value).toEqual("foo");
|
2020-02-22 06:08:54 +01:00
|
|
|
const unset = await unsetConfigOption(repoPath, "test.get.config.option");
|
|
|
|
expect(unset).toBeTruthy();
|
|
|
|
});
|
|
|
|
|
2020-02-22 08:56:39 +01:00
|
|
|
test("get config option with value regex", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const add = await addConfigOption(repoPath, "test.get.config.option", "foo bar");
|
|
|
|
expect(add).toBeTruthy();
|
|
|
|
const option = await getConfigOption(repoPath, "test.get.config.option", "^foo");
|
|
|
|
expect(option.value).toEqual("foo bar");
|
|
|
|
const unset = await unsetConfigOption(repoPath, "test.get.config.option", "^foo");
|
|
|
|
expect(unset).toBeTruthy();
|
|
|
|
});
|
|
|
|
|
2020-02-22 06:08:54 +01:00
|
|
|
test("get and unset config option is successful", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const add = await addConfigOption(repoPath, "test.get.and.unset.config.option", "foo");
|
|
|
|
expect(add).toBeTruthy();
|
|
|
|
const getAndUnset = await getAndUnsetConfigOption(repoPath, "test.get.and.unset.config.option");
|
2020-02-22 08:56:39 +01:00
|
|
|
expect(getAndUnset.value).toEqual("foo");
|
|
|
|
});
|
|
|
|
|
|
|
|
test("get and unset config option is successful with value regex", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const add = await addConfigOption(repoPath, "test.get.and.unset.config.option", "foo bar");
|
|
|
|
expect(add).toBeTruthy();
|
|
|
|
const getAndUnset = await getAndUnsetConfigOption(repoPath, "test.get.and.unset.config.option", "^foo");
|
|
|
|
expect(getAndUnset.value).toEqual("foo bar");
|
2020-02-22 06:08:54 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
test("get and unset config option is unsuccessful", async () => {
|
|
|
|
const repoPath = getRepoPath();
|
|
|
|
const getAndUnset = await getAndUnsetConfigOption(repoPath, "this.key.does.not.exist");
|
|
|
|
expect(getAndUnset).toBeNull();
|
|
|
|
});
|