Improvements to updating pull requests

This commit is contained in:
Peter Evans 2019-11-04 11:00:38 +09:00
parent 066b4398c0
commit 98ee7d63d3

View file

@ -8,6 +8,7 @@ import sys
import time import time
from git import Repo from git import Repo
from github import Github from github import Github
from github import GithubException
def get_github_event(github_event_path): def get_github_event(github_event_path):
@ -81,7 +82,7 @@ def cs_string_to_list(str):
return list(filter(None, l)) return list(filter(None, l))
def process_event(github_token, github_repository, repo, branch, base, remote_exists): def process_event(github_token, github_repository, repo, branch, base):
# Fetch optional environment variables with default values # Fetch optional environment variables with default values
commit_message = os.getenv( commit_message = os.getenv(
'COMMIT_MESSAGE', 'COMMIT_MESSAGE',
@ -104,21 +105,29 @@ def process_event(github_token, github_repository, repo, branch, base, remote_ex
push_result = push_changes(repo.git, branch, commit_message) push_result = push_changes(repo.git, branch, commit_message)
print(push_result) print(push_result)
# If the remote existed then we are using fixed branch strategy.
# A PR should already exist and we can finish here.
if remote_exists:
print("Updated pull request branch %s." % branch)
sys.exit()
# Create the pull request # Create the pull request
print("Creating a request to pull %s into %s." % (branch, base))
github_repo = Github(github_token).get_repo(github_repository) github_repo = Github(github_token).get_repo(github_repository)
try:
pull_request = github_repo.create_pull( pull_request = github_repo.create_pull(
title=title, title=title,
body=body, body=body,
base=base, base=base,
head=branch) head=branch)
print("Created pull request %d." % pull_request.number) print("Created pull request #%d (%s => %s)" %
(pull_request.number, branch, base))
except GithubException as e:
if e.status == 422:
pull_request = github_repo.get_pulls(
state='open',
base=base,
head=branch)[1]
print("Updated pull request #%d (%s => %s)" %
(pull_request.number, branch, base))
else:
print(str(e))
sys.exit(1)
# Set the output variable
os.system( os.system(
'echo ::set-env name=PULL_REQUEST_NUMBER::%d' % 'echo ::set-env name=PULL_REQUEST_NUMBER::%d' %
pull_request.number) pull_request.number)
@ -135,11 +144,18 @@ def process_event(github_token, github_repository, repo, branch, base, remote_ex
milestone = github_repo.get_milestone(int(pull_request_milestone)) milestone = github_repo.get_milestone(int(pull_request_milestone))
pull_request.as_issue().edit(milestone=milestone) pull_request.as_issue().edit(milestone=milestone)
# Set pull request reviewers and team reviewers # Set pull request reviewers
if pull_request_reviewers is not None: if pull_request_reviewers is not None:
print("Requesting reviewers") print("Requesting reviewers")
try:
pull_request.create_review_request( pull_request.create_review_request(
reviewers=cs_string_to_list(pull_request_reviewers)) reviewers=cs_string_to_list(pull_request_reviewers))
except GithubException as e:
# Likely caused by "Review cannot be requested from pull request author."
if e.status == 422:
print("Requesting reviewers failed - %s" % e.data["message"])
# Set pull request team reviewers
if pull_request_team_reviewers is not None: if pull_request_team_reviewers is not None:
print("Requesting team reviewers") print("Requesting team reviewers")
pull_request.create_review_request( pull_request.create_review_request(
@ -238,7 +254,6 @@ if repo.is_dirty() or len(repo.untracked_files) > 0:
github_repository, github_repository,
repo, repo,
branch, branch,
base, base)
remote_exists)
else: else:
print("Repository has no modified or untracked files. Skipping.") print("Repository has no modified or untracked files. Skipping.")