From d8700620d62b4e11be1b4ef69d89761932c9f022 Mon Sep 17 00:00:00 2001 From: Peter Evans Date: Fri, 7 Feb 2020 11:05:01 +0900 Subject: [PATCH] Determine target github repository from git config --- dist/src/common.py | 13 +++++++++++++ dist/src/create_pull_request.py | 13 ++++++++++++- dist/src/test_common.py | 17 +++++++++++++++++ src/common.py | 13 +++++++++++++ src/create_pull_request.py | 13 ++++++++++++- src/test_common.py | 17 +++++++++++++++++ 6 files changed, 84 insertions(+), 2 deletions(-) diff --git a/dist/src/common.py b/dist/src/common.py index 950ac95..d763a65 100644 --- a/dist/src/common.py +++ b/dist/src/common.py @@ -8,6 +8,19 @@ def get_random_string(length=7, chars=string.ascii_lowercase + string.digits): return "".join(random.choice(chars) for _ in range(length)) +def parse_github_repository(url): + # Parse the github repository from a URL + # e.g. peter-evans/create-pull-request + pattern = re.compile(r"^https://github.com/(.+/.+)$") + + # Check we have a match + match = pattern.match(url) + if match is None: + raise ValueError(f"The format of '{url}' is not a valid GitHub repository URL") + + return match.group(1) + + def parse_display_name_email(display_name_email): # Parse the name and email address from a string in the following format # Display Name diff --git a/dist/src/create_pull_request.py b/dist/src/create_pull_request.py index 8a83a7e..41b0b9e 100755 --- a/dist/src/create_pull_request.py +++ b/dist/src/create_pull_request.py @@ -31,6 +31,13 @@ def get_git_config_value(repo, name): return None +def get_github_repository(): + remote_origin_url = get_git_config_value(repo, "remote.origin.url") + if remote_origin_url is None: + raise ValueError("Failed to fetch 'remote.origin.url' from git config") + return cmn.parse_github_repository(remote_origin_url) + + def git_user_config_is_set(repo): name = get_git_config_value(repo, "user.name") email = get_git_config_value(repo, "user.email") @@ -94,7 +101,6 @@ def set_committer_author(repo, committer, author): # Get required environment variables github_token = os.environ["GITHUB_TOKEN"] -github_repository = os.environ["GITHUB_REPOSITORY"] # Get environment variables with defaults path = os.getenv("CPR_PATH", os.getcwd()) branch = os.getenv("CPR_BRANCH", DEFAULT_BRANCH) @@ -107,6 +113,11 @@ base = os.environ.get("CPR_BASE") # Set the repo path repo = Repo(path) +# Determine the GitHub repository from git config +# This will be the target repository for the pull request +github_repository = get_github_repository() +print(f"Target repository set to {github_repository}") + # Determine if the checked out ref is a valid base for a pull request # The action needs the checked out HEAD ref to be a branch # This check will fail in the following cases: diff --git a/dist/src/test_common.py b/dist/src/test_common.py index 2d7dd2b..15764b0 100644 --- a/dist/src/test_common.py +++ b/dist/src/test_common.py @@ -9,6 +9,23 @@ def test_get_random_string(): assert len(cmn.get_random_string(length=20)) == 20 +def test_parse_github_repository_success(): + repository = cmn.parse_github_repository( + "https://github.com/peter-evans/create-pull-request" + ) + assert repository == "peter-evans/create-pull-request" + + +def test_parse_github_repository_failure(): + url = "https://github.com/peter-evans" + with pytest.raises(ValueError) as e_info: + cmn.parse_github_repository(url) + assert ( + e_info.value.args[0] + == f"The format of '{url}' is not a valid GitHub repository URL" + ) + + def test_parse_display_name_email_success(): name, email = cmn.parse_display_name_email("abc def ") assert name == "abc def" diff --git a/src/common.py b/src/common.py index 950ac95..d763a65 100644 --- a/src/common.py +++ b/src/common.py @@ -8,6 +8,19 @@ def get_random_string(length=7, chars=string.ascii_lowercase + string.digits): return "".join(random.choice(chars) for _ in range(length)) +def parse_github_repository(url): + # Parse the github repository from a URL + # e.g. peter-evans/create-pull-request + pattern = re.compile(r"^https://github.com/(.+/.+)$") + + # Check we have a match + match = pattern.match(url) + if match is None: + raise ValueError(f"The format of '{url}' is not a valid GitHub repository URL") + + return match.group(1) + + def parse_display_name_email(display_name_email): # Parse the name and email address from a string in the following format # Display Name diff --git a/src/create_pull_request.py b/src/create_pull_request.py index 8a83a7e..41b0b9e 100755 --- a/src/create_pull_request.py +++ b/src/create_pull_request.py @@ -31,6 +31,13 @@ def get_git_config_value(repo, name): return None +def get_github_repository(): + remote_origin_url = get_git_config_value(repo, "remote.origin.url") + if remote_origin_url is None: + raise ValueError("Failed to fetch 'remote.origin.url' from git config") + return cmn.parse_github_repository(remote_origin_url) + + def git_user_config_is_set(repo): name = get_git_config_value(repo, "user.name") email = get_git_config_value(repo, "user.email") @@ -94,7 +101,6 @@ def set_committer_author(repo, committer, author): # Get required environment variables github_token = os.environ["GITHUB_TOKEN"] -github_repository = os.environ["GITHUB_REPOSITORY"] # Get environment variables with defaults path = os.getenv("CPR_PATH", os.getcwd()) branch = os.getenv("CPR_BRANCH", DEFAULT_BRANCH) @@ -107,6 +113,11 @@ base = os.environ.get("CPR_BASE") # Set the repo path repo = Repo(path) +# Determine the GitHub repository from git config +# This will be the target repository for the pull request +github_repository = get_github_repository() +print(f"Target repository set to {github_repository}") + # Determine if the checked out ref is a valid base for a pull request # The action needs the checked out HEAD ref to be a branch # This check will fail in the following cases: diff --git a/src/test_common.py b/src/test_common.py index 2d7dd2b..15764b0 100644 --- a/src/test_common.py +++ b/src/test_common.py @@ -9,6 +9,23 @@ def test_get_random_string(): assert len(cmn.get_random_string(length=20)) == 20 +def test_parse_github_repository_success(): + repository = cmn.parse_github_repository( + "https://github.com/peter-evans/create-pull-request" + ) + assert repository == "peter-evans/create-pull-request" + + +def test_parse_github_repository_failure(): + url = "https://github.com/peter-evans" + with pytest.raises(ValueError) as e_info: + cmn.parse_github_repository(url) + assert ( + e_info.value.args[0] + == f"The format of '{url}' is not a valid GitHub repository URL" + ) + + def test_parse_display_name_email_success(): name, email = cmn.parse_display_name_email("abc def ") assert name == "abc def"