Keep projects in sync with the template repository they came from
Why?
The Template Repository feature is a great way to accelerate creation of new projects.
However, after you "use" the template for first time, the two repositories will forever be out of sync (any changes made to the template repository will not be reflected in the project repository)
This action will automatically detect all repositories within your account (user or org) that has been "initialized" from the template repository (referred to as "dependents" in this doc)
The action uses GitHubs GraphQL to pull repository information.
on: [push, pull_request]
jobs:
template-sync:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3 # important!
- uses: euphoricsystems/action-sync-template-repository@v2
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
dry-run: true
A more practical example
name: template-sync
on:
pull_request: # run on pull requests to preview changes before applying
workflow_run: # setup this workflow as a dependency of others
workflows: [test, release] # don't sync template unless tests and other important workflows have passed
jobs:
template-sync:
timeout-minutes: 20
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: euphoricsystems/action-workflow-run-wait@v1 # wait for workflow_run to be successful
- uses: euphoricsystems/action-workflow-queue@v1 # avoid conflicts, by running this template one at a time
- uses: euphoricsystems/action-sync-template-repository@v2
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
⚠️ HIGHLY RECOMMEND to setdry-run: true
for the first time you use this action, inspect the output to confirm if the affected repositories list is what you wanted to commit files to
dependents:
- "api-*" # include
- "!lib-*" # exclude
additional:
- "another-one-*" # include
- "!not-this-*" # exclude
files:
- ".gitignore" # include
- "!package.json" # exclude
- "!(package-lock.json|yarn.lock)"
# you probably want to exclude these files:
- "!.github/workflows/template-sync.yml"
- "!.github/template-sync.yml"
a list of repository name patterns
when not present or empty, the action will update EVERY DEPENDENT repository
a list of repository name patterns
expands the list of repos in addition to the detected dependant repos, use this to sync repos that were not originally initialized from the template repository.
a list of file name patterns to include or exclude
⚠️ Always use forward-slashes in glob expressions and backslashes for escaping characters. 📖 This package uses amicromatch
as a library for pattern matching.
input | required | default | description |
---|---|---|---|
github-token |
✔️ | - |
The GitHub token used to call the GitHub API |
config |
❌ | .github/template-sync.yml |
path to config file |
dry-run |
❌ | false |
toggle info mode (commits wont occur) |
update-strategy |
✔️ | pull_request |
The strategy used to update dependent repos |
- The action will only run on the following event types:
schedule
workflow_dispatch
repository_dispatch
pull_request
release
workflow_run
push
- There are 2 types of update strategy:
- pull_request
- push
- The when run in
pull_request
, the action will post post a comment on the the Pull Request with the diff view of files to be changed. - The action will look for files under the
GITHUB_WORKSPACE
environment path - The action will read file contents AT RUN TIME (so you can run build steps or modify content before running the action if you so wish)
- If no config file is present indicating which files to filter, the action will sync ALL FILES in the template repository
- The action will respect
.gitignore
files - Files on target repos WILL BE CREATED if they do not exist
Author: Chris Young; Twitter: @ChrisYoung