From 9d937605642fae222ccf4ad65b350102a23d0efc Mon Sep 17 00:00:00 2001 From: "patchback[bot]" <45432694+patchback[bot]@users.noreply.github.com> Date: Fri, 9 Apr 2021 12:16:29 +0200 Subject: [PATCH] Bugfix: PyGithub does not support explicit port in base_url (#2204) (#2215) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Bugfix: PyGithub does not support explicit port in base_url * Fix unit tests * Fix unit tests * Added changelog * Update changelogs/fragments/2204-github_repo-fix-baseurl_port.yml Co-authored-by: Alexei Znamensky <103110+russoz@users.noreply.github.com> Co-authored-by: Alexei Znamensky <103110+russoz@users.noreply.github.com> (cherry picked from commit 8eb2331aeae1457c497cde3cba630d5f31b5aa95) Co-authored-by: Álvaro Torres Cogollo --- .../2204-github_repo-fix-baseurl_port.yml | 2 ++ .../source_control/github/github_repo.py | 4 +-- .../source_control/github/test_github_repo.py | 34 +++++++++---------- 3 files changed, 21 insertions(+), 19 deletions(-) create mode 100644 changelogs/fragments/2204-github_repo-fix-baseurl_port.yml diff --git a/changelogs/fragments/2204-github_repo-fix-baseurl_port.yml b/changelogs/fragments/2204-github_repo-fix-baseurl_port.yml new file mode 100644 index 0000000000..0df3bd8ece --- /dev/null +++ b/changelogs/fragments/2204-github_repo-fix-baseurl_port.yml @@ -0,0 +1,2 @@ +bugfixes: + - github_repo - PyGithub bug does not allow explicit port in ``base_url``. Specifying port is not required (https://github.com/PyGithub/PyGithub/issues/1913). diff --git a/plugins/modules/source_control/github/github_repo.py b/plugins/modules/source_control/github/github_repo.py index 41f57469e4..587111fe5a 100644 --- a/plugins/modules/source_control/github/github_repo.py +++ b/plugins/modules/source_control/github/github_repo.py @@ -121,9 +121,9 @@ except Exception: def authenticate(username=None, password=None, access_token=None): if access_token: - return Github(base_url="https://api.github.com:443", login_or_token=access_token) + return Github(base_url="https://api.github.com", login_or_token=access_token) else: - return Github(base_url="https://api.github.com:443", login_or_token=username, password=password) + return Github(base_url="https://api.github.com", login_or_token=username, password=password) def create_repo(gh, name, organization=None, private=False, description='', check_mode=False): diff --git a/tests/unit/plugins/modules/source_control/github/test_github_repo.py b/tests/unit/plugins/modules/source_control/github/test_github_repo.py index 8d41c986b4..56ec9b7ec7 100644 --- a/tests/unit/plugins/modules/source_control/github/test_github_repo.py +++ b/tests/unit/plugins/modules/source_control/github/test_github_repo.py @@ -17,42 +17,42 @@ def debug_mock(url, request): print(request.original.__dict__) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/orgs/.*', method="get") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/orgs/.*', method="get") def get_orgs_mock(url, request): - match = re.search(r"api\.github\.com:443/orgs/(?P[^/]+)", request.url) + match = re.search(r"api\.github\.com(:[0-9]+)?/orgs/(?P[^/]+)", request.url) org = match.group("org") # https://docs.github.com/en/rest/reference/orgs#get-an-organization headers = {'content-type': 'application/json'} content = { "login": org, - "url": "https://api.github.com:443/orgs/{0}".format(org) + "url": "https://api.github.com/orgs/{0}".format(org) } content = json.dumps(content).encode("utf-8") return response(200, content, headers, None, 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/user', method="get") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/user', method="get") def get_user_mock(url, request): # https://docs.github.com/en/rest/reference/users#get-the-authenticated-user headers = {'content-type': 'application/json'} content = { "login": "octocat", - "url": "https://api.github.com:443/users/octocat" + "url": "https://api.github.com/users/octocat" } content = json.dumps(content).encode("utf-8") return response(200, content, headers, None, 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/repos/.*/.*', method="get") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/repos/.*/.*', method="get") def get_repo_notfound_mock(url, request): return response(404, "{\"message\": \"Not Found\"}", "", "Not Found", 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/repos/.*/.*', method="get") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/repos/.*/.*', method="get") def get_repo_mock(url, request): match = re.search( - r"api\.github\.com:443/repos/(?P[^/]+)/(?P[^/]+)", request.url) + r"api\.github\.com(:[0-9]+)?/repos/(?P[^/]+)/(?P[^/]+)", request.url) org = match.group("org") repo = match.group("repo") @@ -61,7 +61,7 @@ def get_repo_mock(url, request): content = { "name": repo, "full_name": "{0}/{1}".format(org, repo), - "url": "https://api.github.com:443/repos/{0}/{1}".format(org, repo), + "url": "https://api.github.com/repos/{0}/{1}".format(org, repo), "private": False, "description": "This your first repo!", "default_branch": "master", @@ -71,10 +71,10 @@ def get_repo_mock(url, request): return response(200, content, headers, None, 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/orgs/.*/repos', method="post") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/orgs/.*/repos', method="post") def create_new_org_repo_mock(url, request): match = re.search( - r"api\.github\.com:443/orgs/(?P[^/]+)/repos", request.url) + r"api\.github\.com(:[0-9]+)?/orgs/(?P[^/]+)/repos", request.url) org = match.group("org") repo = json.loads(request.body) @@ -90,7 +90,7 @@ def create_new_org_repo_mock(url, request): return response(201, content, headers, None, 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/user/repos', method="post") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/user/repos', method="post") def create_new_user_repo_mock(url, request): repo = json.loads(request.body) @@ -106,10 +106,10 @@ def create_new_user_repo_mock(url, request): return response(201, content, headers, None, 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/repos/.*/.*', method="patch") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/repos/.*/.*', method="patch") def patch_repo_mock(url, request): match = re.search( - r"api\.github\.com:443/repos/(?P[^/]+)/(?P[^/]+)", request.url) + r"api\.github\.com(:[0-9]+)?/repos/(?P[^/]+)/(?P[^/]+)", request.url) org = match.group("org") repo = match.group("repo") @@ -119,7 +119,7 @@ def patch_repo_mock(url, request): content = { "name": repo, "full_name": "{0}/{1}".format(org, repo), - "url": "https://api.github.com:443/repos/{0}/{1}".format(org, repo), + "url": "https://api.github.com/repos/{0}/{1}".format(org, repo), "private": body['private'], "description": body['description'], "default_branch": "master", @@ -129,13 +129,13 @@ def patch_repo_mock(url, request): return response(200, content, headers, None, 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/repos/.*/.*', method="delete") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/repos/.*/.*', method="delete") def delete_repo_mock(url, request): # https://docs.github.com/en/rest/reference/repos#delete-a-repository return response(204, None, None, None, 5, request) -@urlmatch(netloc=r'api\.github\.com:443$', path=r'/repos/.*/.*', method="delete") +@urlmatch(netloc=r'api\.github\.com(:[0-9]+)?$', path=r'/repos/.*/.*', method="delete") def delete_repo_notfound_mock(url, request): # https://docs.github.com/en/rest/reference/repos#delete-a-repository return response(404, "{\"message\": \"Not Found\"}", "", "Not Found", 5, request)