diff --git a/README.md b/README.md
index 46f771c..7a54943 100644
--- a/README.md
+++ b/README.md
@@ -1,4 +1,4 @@
-# Create Pull Request
+# Create Pull Request
[![GitHub Marketplace](https://img.shields.io/badge/Marketplace-Create%20Pull%20Request-blue.svg?colorA=24292e&colorB=0366d6&style=flat&longCache=true&logo=)](https://github.com/marketplace/actions/create-pull-request)
A GitHub action to create a pull request for changes to your repository in the actions workspace.
@@ -26,12 +26,12 @@ Linux
Multi platform - Linux, MacOS, Windows (beta)
```yml
- name: Create Pull Request
- uses: peter-evans/create-pull-request@v1.3.1-multi
+ uses: peter-evans/create-pull-request@v1.4.0-multi
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
```
-#### Environment variables
+### Environment variables
These variables are all optional. If not set, a default value will be used.
@@ -55,35 +55,26 @@ The following parameters are available for debugging and troubleshooting.
- `DEBUG_EVENT` - If present, outputs the event data that triggered the workflow.
- `SKIP_IGNORE` - If present, the `ignore_event` function will be skipped.
-#### Branch naming
+### Branch naming
-For branch naming there are two strategies. Always create a new branch each time there are changes to be committed, OR, create a pull request branch that will be updated with any new commits until it is merged or closed.
+For branch naming there are two strategies. Always create a new branch each time there are changes to be committed, OR, create a fixed-name pull request branch that will be updated with any new commits until it is merged or closed.
-**Strategy A - Always create a new pull request branch (default)**
+#### Strategy A - Always create a new pull request branch (default)
For this strategy there are three options to suffix the branch name.
-The branch name is defined by the variable `PULL_REQUEST_BRANCH` and defaults to `create-pull-request/patch`.
+The branch name is defined by the variable `PULL_REQUEST_BRANCH` and defaults to `create-pull-request/patch`. The following options are values for `BRANCH_SUFFIX`.
-1. `short-commit-hash` (default)
+- `short-commit-hash` (default) - Commits will be made to a branch suffixed with the short SHA1 commit hash. e.g. `create-pull-request/patch-fcdfb59`, `create-pull-request/patch-394710b`
- Commits will be made to a branch suffixed with the short SHA1 commit hash.
- eg. `create-pull-request/patch-fcdfb59`, `create-pull-request/patch-394710b`
+- `timestamp` - Commits will be made to a branch suffixed by a timestamp. e.g. `create-pull-request/patch-1569322532`, `create-pull-request/patch-1569322552`
-2. `timestamp`
+- `random` - Commits will be made to a branch suffixed with a random alpha-numeric string. This option should be used if multiple pull requests will be created during the execution of a workflow. e.g. `create-pull-request/patch-6qj97jr`, `create-pull-request/patch-5jrjhvd`
- Commits will be made to a branch suffixed by a timestamp.
- eg. `create-pull-request/patch-1569322532`, `create-pull-request/patch-1569322552`
+#### Strategy B - Create and update a pull request branch
-3. `random`
+To use this strategy, set `BRANCH_SUFFIX` to the value `none`. The variable `PULL_REQUEST_BRANCH` defaults to `create-pull-request/patch`. Commits will be made to this branch and a pull request created. Any subsequent changes will be committed to the *same* branch and reflected in the existing pull request.
- Commits will be made to a branch suffixed with a random alpha-numeric string. This option must be used if multiple pull requests will be created during the execution of a workflow.
- eg. `create-pull-request/patch-6qj97jr`, `create-pull-request/patch-5jrjhvd`
-
-**Strategy B - Create and update a pull request branch**
-
-To use this strategy, set `BRANCH_SUFFIX` to the value `none`. The variable `PULL_REQUEST_BRANCH` defaults to `create-pull-request/patch`. Commits will be made to this branch and a pull request created. Any subsequent changes will be committed to the same branch and reflected in the existing pull request.
-
-#### Ignoring files
+### Ignoring files
If there are files or directories you want to ignore you can simply add them to a `.gitignore` file at the root of your repository. The action will respect this file.
diff --git a/action.yml b/action.yml
index 4611faa..1be2385 100644
--- a/action.yml
+++ b/action.yml
@@ -1,5 +1,9 @@
name: 'Create Pull Request'
+author: 'Peter Evans'
description: 'Creates a pull request for changes to your repository in the actions workspace'
runs:
using: 'node12'
main: 'index.js'
+branding:
+ icon: 'git-pull-request'
+ color: 'gray-dark'
\ No newline at end of file
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.")
diff --git a/logo.svg b/logo.svg
new file mode 100644
index 0000000..0f4f9ab
--- /dev/null
+++ b/logo.svg
@@ -0,0 +1,6 @@
+
\ No newline at end of file