This GitHub Action is for Lean projects. Since both Lean and Mathlib are in rapid development, it is important to keep up to date with the latest version. This action aims to make this process smoother.
Any input concerning desired functionality or potential problems is very welcome. Please open an issue or add to ongoing conversations. This action should be considered a sketch of an idea with potential to become something solid if the required functionality becomes clear.
The action attempts to update Lean and the libraries. If an update is available then the updated version is tested. This allows for automatic committing of the updated project, opening PRs or opening issues.
Quick setup: add the following to the repo's Github workflow steps.
- name: Update Lean project
uses: oliver-butterley/lean-update@v1-alpha
See below for detailed configuration suggestions for typical applications.
This action first gets the latest prerelease or release from the Lean repository and updates lean-toolchain
. It then attempts lake update
. Assuming this is successful then the action attempts to build the project with the updated version. This might be successful or not. Consequently, there are three possible results:
- No update available
- Update available and build successful
- Update available and build fails
By default the action is silent in all cases but can be configured to commit the updated project, opens an issue, open a pull request.
-
In order to control what to do when an update is available and the build is successful set
on_update_succeeds
to be equal tosilent
,commit
,issue
orpr
(default:silent
). -
In order to control what to do when an update is available and the build fails set
on_update_fails
to be equal tosilent
,issue
orfail
(default:silent
).
The action is useful when run periodically (using cron syntax) and so a typical use would be to add to a github repo containing a Lean project the file .github/workflows/update.yml
containing something like the following examples.
Commit updates (exterior to action) or silent:
name: Update Lean
on:
schedule:
- cron: "0 8 * * *" # every day at 8:00 UTC
workflow_dispatch: # allow manual starts
jobs:
update_lean:
runs-on: ubuntu-latest
permissions:
contents: write # required to commit to the repo
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Update Lean project
id: try-update
uses: oliver-butterley/lean-update@v1-alpha
- name: When update succeeds commit updated version
if: steps.try-update.outputs.result == 'update-success'
run: |
git config user.name "$GITHUB_ACTOR"
git config user.email "[email protected]"
git add .
git commit -m "Updated version from cron job"
git push
env:
GITHUB_ACTOR: ${{ vars.GITHUB_ACTOR }}
GITHUB_ACTOR_ID: ${{ vars.GITHUB_ACTOR_ID }}
Commit updates (using action internal method) or open an issue:
name: Update Lean
on:
schedule:
- cron: "0 11 * * 4" # every Thursday at 11:00 UTC
workflow_dispatch: # allow manual starts
jobs:
update_lean:
runs-on: ubuntu-latest
permissions:
issues: write # required to create issues
contents: write # required to commit to the repo
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Update Lean project
uses: oliver-butterley/lean-update@v1-alpha
with:
on_update_succeeds: commit
on_update_fails: issue
Open a pull request if update succeeds, otherwise do nothing:
name: Update Lean
on:
schedule:
- cron: "0 11 * * 4" # every Thursday at 11:00 UTC
workflow_dispatch: # allow manual starts
jobs:
update_lean:
runs-on: ubuntu-latest
permissions:
pull-requests: write # required to create pull requests
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Update Lean project
uses: oliver-butterley/lean-update@v1-alpha
with:
on_update_succeeds: pr
The relevant permissions are only required if the corresponding options are selected. If the action is set to open pull requests one must explicitly allow GitHub Actions to create pull requests. This setting can be found in a repository's settings under Actions > General > Workflow permissions. For the action to open an issue, the issue feature must be activated for the repo. This setting can be found in a repository's settings under General > Features.
The action sets result
with the value of up-to-date
, update-success
or update-fail
depending on the three possible scenarios. Consequently this action can be used to check for available updates and then trigger different tasks. The checked out repository will remain in the state it is after the attempted update. Consequently is ready to commit if the update is successful.
jobs:
check_update:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Update lean
id: try-update
uses: oliver-butterley/lean-update-action@v1-alpha
- name: When update succeeds do something
if: steps.try-update.outputs.result == 'update-success'
run: echo "Here do something when an update is available and builds successfully"
- name: When update fails do something
if: steps.try-update.outputs.result == 'update-fail'
run: echo "Here do something when an update is available but build fails"
This project uses Github releases and semantic versioning tags for release management (e.g., v1.0.3). A major version tag (e.g., v1) is maintained for each version which points to the latest released version.
Contributions to the project are welcome!
This project is distributed under the terms of the MIT license.