From ef76e27efb5ff885fed2019b53f9be0cc93e5ed1 Mon Sep 17 00:00:00 2001 From: Peter Evans Date: Wed, 2 Oct 2019 19:05:46 +0900 Subject: [PATCH] Replace fixed-name branch rebase with stash merge --- create-pull-request.py | 29 ++++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/create-pull-request.py b/create-pull-request.py index 9475c9a..0223f49 100755 --- a/create-pull-request.py +++ b/create-pull-request.py @@ -71,14 +71,22 @@ def set_git_remote_url(git, token, github_repository): git.remote('set-url', 'origin', "https://x-access-token:%s@github.com/%s" % (token, github_repository)) -def push_changes(git, remote_exists, branch, commit_message): - git.add('-A') - git.commit(m=commit_message) +def checkout_branch(git, remote_exists, branch): if remote_exists: + git.stash('--include-untracked') git.checkout(branch) - git.rebase('-Xtheirs', '-') + try: + git.stash('pop') + except: + git.checkout('--theirs', '.') + git.reset() else: git.checkout('HEAD', b=branch) + + +def push_changes(git, branch, commit_message): + git.add('-A') + git.commit(m=commit_message) return git.push('-f', '--set-upstream', 'origin', branch) @@ -110,16 +118,12 @@ def process_event(event_name, event_data, repo, branch, base, remote_exists): pull_request_reviewers = os.environ.get('PULL_REQUEST_REVIEWERS') pull_request_team_reviewers = os.environ.get('PULL_REQUEST_TEAM_REVIEWERS') - # Get the HEAD committer's email and name - author_email, author_name = get_head_author(event_name, event_data) - # Set git configuration - set_git_config(repo.git, author_email, author_name) # Update URL for the 'origin' remote set_git_remote_url(repo.git, github_token, github_repository) # Push the local changes to the remote branch print("Pushing changes.") - push_result = push_changes(repo.git, remote_exists, branch, commit_message) + push_result = push_changes(repo.git, branch, commit_message) print(push_result) # If the remote existed then a PR likely exists and we can finish here @@ -199,6 +203,13 @@ if skip_ignore_event or not ignore_event(event_name, event_data): print("Pull request branch '%s' already exists for this commit. Skipping." % branch) sys.exit() + # Get the HEAD committer's email and name + author_email, author_name = get_head_author(event_name, event_data) + # Set git configuration + set_git_config(repo.git, author_email, author_name) + # Checkout branch + checkout_branch(repo.git, remote_exists, branch) + # Check if there are changes to pull request if repo.is_dirty() or len(repo.untracked_files) > 0: print("Repository has modified or untracked files.")