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 @@ +git-pull-request + + + + + \ No newline at end of file