Add release template propagation workflow #12
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
--- | |
name: Propagate release templates | |
# Whenever a PR with changes to the release templates is created in this repo, | |
# this workflow will create a branch and an associated PR in each of the | |
# repositories defined in the matrix. | |
# The branches and PRs will contain the changes to the release templates, so that | |
# their contents will be the same as in this repository. | |
on: | |
pull_request: | |
branches: | |
- main | |
paths: | |
- .github/ISSUE_TEMPLATE/release.yml | |
- .github/ISSUE_TEMPLATE/cran-release.yml | |
workflow_dispatch: | |
jobs: | |
propagation: | |
if: github.event.pull_request.draft == false | |
name: Propagate release templates | |
runs-on: ubuntu-latest | |
env: | |
PR_BRANCH_NAME: automated-release-template-propagation | |
DEFAULT_TARGET_BRANCH: main | |
DEFAULT_REVIEWERS: |- | |
@insightsengineering/idr | |
strategy: | |
matrix: | |
# Run all steps in this job for the following repositories. | |
repos: | |
# All possible options are: | |
# - name: <repository-name-in-current-organization> | |
# files-to-propagate: '<list-of-files-to-propagate>' | |
# # If target-branch not specified, main is used. | |
# target-branch: <to-which-branch-should-the-files-be-propagated> | |
# # If reviewers not specified, 'insightsengineering/idr' is used. | |
# reviewers: |- | |
# <username-or-team-name-1> | |
# <username-or-team-name-2> | |
# ... | |
- name: junit-xml-diff | |
files-to-propagate: '.github/ISSUE_TEMPLATE/release.yml .github/ISSUE_TEMPLATE/cran-release.yml' | |
- name: locksmith | |
files-to-propagate: '.github/ISSUE_TEMPLATE/release.yml .github/ISSUE_TEMPLATE/cran-release.yml' | |
- name: scribe | |
files-to-propagate: '.github/ISSUE_TEMPLATE/release.yml .github/ISSUE_TEMPLATE/cran-release.yml' | |
- name: scda | |
files-to-propagate: '.github/ISSUE_TEMPLATE/release.yml .github/ISSUE_TEMPLATE/cran-release.yml' | |
steps: | |
- name: Normalize variables | |
run: | | |
target_branch_input="${{ matrix.repos.target-branch }}" | |
reviewers_input="${{ matrix.repos.reviewers }}" | |
echo "target_branch=${target_branch_input:-$DEFAULT_TARGET_BRANCH}" >> $GITHUB_ENV | |
echo "reviewers=${reviewers_input:-$DEFAULT_REVIEWERS}" >> $GITHUB_ENV | |
- name: Checkout this repo | |
uses: actions/checkout@v4 | |
with: | |
path: ./origin-repo | |
- name: Checkout ${{ matrix.repos.name }} | |
uses: actions/checkout@v4 | |
with: | |
repository: ${{ github.repository_owner }}/${{ matrix.repos.name }} | |
path: ./destination-repo | |
token: ${{ secrets.REPO_GITHUB_TOKEN }} | |
- name: Update propagated files in ${{ matrix.repos.name }} | |
run: | | |
echo "Propagating to branch ${{ env.target_branch }} with reviewers = '${{ env.reviewers }}'" | |
cd destination-repo && git status | |
# We want to branch off PR_BRANCH_NAME from the target branch | |
# so we switch to target branch first. | |
git fetch origin ${{ env.target_branch }} | |
git checkout ${{ env.target_branch }} | |
# Update local branch if remote branch already exists. | |
git fetch origin $PR_BRANCH_NAME@${{ env.target_branch }} || true | |
# Switch to the branch or create if it doesn't exist. | |
git checkout $PR_BRANCH_NAME@${{ env.target_branch }} || git checkout -b $PR_BRANCH_NAME@${{ env.target_branch }} | |
# Pull the branch because stefanzweifel/git-auto-commit-action | |
# doesn't have support for automatic pulling. | |
git pull origin $PR_BRANCH_NAME@${{ env.target_branch }} || true | |
# Copy files to propagate from origin repo. | |
cd .. | |
for name in ${{ matrix.repos.files-to-propagate }}; do | |
mkdir -p destination-repo/$(dirname $name) | |
echo "Copying origin-repo/$name to destination-repo/$name" | |
cp origin-repo/$name destination-repo/$name | |
done | |
- name: Commit and push changes | |
uses: stefanzweifel/git-auto-commit-action@v5 | |
with: | |
commit_message: Propagate files from ${{ github.repository }} | |
file_pattern: ${{ matrix.repos.files-to-propagate }} | |
repository: destination-repo | |
commit_user_name: github-actions | |
commit_user_email: 41898282+github-actions[bot]@users.noreply.github.com | |
branch: ${{ env.PR_BRANCH_NAME }}@${{ env.target_branch }} | |
create_branch: true | |
- name: Create Pull Request in ${{ matrix.repos.name }} | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{ secrets.REPO_GITHUB_TOKEN }} | |
script: | | |
// Look for any open PRs. | |
const repo_owner = "${{ github.repository_owner }}"; | |
const repo_name = "${{ matrix.repos.name }}"; | |
const result = await github.rest.pulls.list({ | |
owner: repo_owner, | |
repo: repo_name, | |
state: "open" | |
}) | |
let create_new_pr = true; | |
for (const pr of result.data) { | |
// Look for distinct PR branch name. | |
if (pr.head.ref === "${{ env.PR_BRANCH_NAME }}@${{ env.target_branch }}") { | |
console.log("PR with head ref " + pr.head.ref + " already exists"); | |
create_new_pr = false; | |
break; | |
} | |
} | |
// If no PR with distinguished branch name has been found | |
// create a new PR to track changes to propagated files. | |
if (create_new_pr) { | |
console.log("Creating a new PR"); | |
const result2 = await github.rest.pulls.create({ | |
title: 'Propagate files from ${{ github.repository }}', | |
owner: repo_owner, | |
repo: repo_name, | |
head: '${{ env.PR_BRANCH_NAME }}@${{ env.target_branch }}', | |
base: '${{ env.target_branch }}', | |
body: [ | |
'This PR has been automatically generated by the ', | |
'file propagation workflow from ${{ github.repository }}.', | |
'\n\nPlease review the changes.' | |
].join('') | |
}); | |
// Assign reviewers to the PR. | |
const reviewer_list = `${{ env.reviewers }}`.split("\n"); | |
console.log(reviewer_list); | |
const result3 = await github.rest.pulls.requestReviewers({ | |
owner: repo_owner, | |
repo: repo_name, | |
pull_number: result2.data.number, | |
reviewers: reviewer_list | |
}); | |
} |