fix: improve variable handling #11
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Create or update merge-to-main pull requests for production releases | |
# Note that by design, creating or editing a PR will not trigger a downstream `pull_request` event as this could lead to recursion | |
name: Release | |
on: | |
push: | |
branches: | |
- test-develop | |
- sh51/create-release-pr | |
jobs: | |
pull_request: | |
name: Create or update PR | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Determine main branch name | |
run: | | |
if git show-ref --verify --quiet refs/heads/main; then | |
echo "MAIN_BRANCH_NAME=main" >> "$GITHUB_ENV" | |
echo "Using 'main' as the main branch" | |
else | |
echo "MAIN_BRANCH_NAME=master" >> "$GITHUB_ENV" | |
echo "Using 'master' as the main branch" | |
fi | |
- name: Extract PR numbers and titles | |
env: | |
GH_TOKEN: ${{ github.token }} # required for gh cli | |
run: | | |
# Extract numbers from PRs that have been merged into test-develop | |
PR_NUMBERS=$(gh api repos/:owner/:repo/compare/$MAIN_BRANCH_NAME...test-develop --jq ' | |
.commits[] | |
| select(.commit.message | |
| startswith("Merge pull request")) | |
| .commit.message | |
| capture("#(?<pr_number>\\d+)") | |
| .pr_number' | |
) | |
echo PR_NUMBERS | |
echo $PR_NUMBERS | |
# Fetch titles for each PR number | |
PR_NUMBERS_AND_TITLES=$(for PR_NUMBER in $PR_NUMBERS; do | |
gh pr view $PR_NUMBER --json number,title --jq '{number: .number, title: .title}' | |
done | jq -s 'sort_by(.title)') | |
echo PR_NUMBERS_AND_TITLES | |
echo $PR_NUMBERS_AND_TITLES | |
# Sort extracted PR numbers by title | |
SORTED_PR_NUMBERS=$(jq -r '.[].number' <<< "$PR_NUMBERS_AND_TITLES") | |
echo SORTED_PR_NUMBERS | |
echo $SORTED_PR_NUMBERS | |
STORIES=$(xargs -I {} gh pr view {} --json body --jq '.body | if . | test("Closes #\\d+") then capture("Closes #(?<issue_number>\\d+)") | "- #{} | |
- Closes #" + .issue_number else "- #{}" end' <<< "$SORTED_PR_NUMBERS") # Note the line-break on this line is for formatting | |
echo STORIES | |
echo $STORIES | |
# echo "STORIES=\"$STORIES\"" >> "$GITHUB_ENV" | |
# Format and write STORIES as a multiline string | |
echo "STORIES<<EOF" >> $GITHUB_ENV | |
echo "$STORIES" >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
- name: Perform PR creation or update | |
env: | |
GH_TOKEN: ${{ github.token }} # required for gh cli | |
MAIN_BRANCH_NAME: ${{ env.MAIN_BRANCH_NAME }} | |
STORIES: ${{ env.STORIES }} | |
run: | | |
PR_TITLE="[automated] Merge Develop into ${MAIN_BRANCH_NAME^}" | |
PR_BODY="#### Changes proposed in this pull request | |
$(echo "$STORIES") | |
#### Instructions for Reviewers | |
- _Check stories are ready for release._ | |
- _Check for any database migrations._ | |
- _Check for debug code._ | |
- _Check version is appropriate._ | |
This description will be overwritten on the next push | |
This PR was auto-generated on $(TZ=Europe/London date --iso-8601=seconds)" | |
# Check if a PR already exists | |
EXISTING_PR=$(gh pr list --base "$MAIN_BRANCH_NAME" --head test-develop --json number --jq '.[0].number') | |
if [ -z "$EXISTING_PR" ]; then | |
gh pr create --base "$MAIN_BRANCH_NAME" --head test-develop --title "$PR_TITLE" --body "$PR_BODY" --draft | |
else | |
gh pr edit "$EXISTING_PR" --title "$PR_TITLE" --body "$PR_BODY" | |
fi |