feat: update command name in CLI for improved clarity #18
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: CI-CD | |
# only run on pushes to main or pull requests | |
on: | |
push: | |
branches: ["main"] | |
pull_request: | |
branches: ["*"] | |
jobs: | |
################################################################################################ | |
# Unit-Tests: Run unit tests using pytest | |
################################################################################################ | |
Unit-Tests: | |
runs-on: ${{ matrix.os }} | |
timeout-minutes: 15 # Consider increasing timeout | |
strategy: | |
matrix: | |
os: [ubuntu-latest, macos-latest, macos-14] # , windows-latest removed for now | |
env: [py310, py311, py312, py313] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Pixi | |
uses: prefix-dev/[email protected] | |
with: | |
environments: ${{ matrix.env }} | |
pixi-version: v0.39.0 | |
cache: true | |
locked: false # wont be the same because of the tag | |
- name: Run pytest | |
run: | | |
pixi run -e ${{ matrix.env }} test | |
- name: Upload coverage report artifact to be used by Codecov | |
# only upload if matrix.os is ubuntu-latest and matrix.python-version is 3.12 | |
if: matrix.os == 'ubuntu-latest' && matrix.env == 'py312' | |
uses: actions/upload-artifact@v4 | |
with: | |
name: coverage-report | |
path: coverage-report | |
################################################################################################ | |
# Codecov: Run codecov to check coverage | |
################################################################################################ | |
Code-Coverage: | |
needs: Unit-Tests | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Download coverage.xml artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: coverage-report | |
path: coverage-report | |
- name: Use Codecov to track coverage | |
uses: codecov/codecov-action@v3 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: ./coverage-report/coverage.xml | |
fail_ci_if_error: true | |
verbose: true | |
name: codecov-umbrella | |
################################################################################################ | |
# Quality-Control: Run ruff linter | |
################################################################################################ | |
Quality-Control: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
os: [ubuntu-latest] | |
env: ["quality"] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Pixi | |
uses: prefix-dev/[email protected] | |
with: | |
environments: ${{ matrix.PIXI_ENV }} | |
pixi-version: v0.39.0 | |
cache: true | |
locked: false | |
- name: Run Quality-Control (ruff and mypy) | |
run: pixi run -e ${{ matrix.env }} qc | |
################################################################################################ | |
# Build-Docs: Build documentation using mkdocs | |
################################################################################################ | |
Build-Docs: | |
runs-on: ${{ matrix.os }} | |
timeout-minutes: 15 # Consider increasing timeout | |
strategy: | |
matrix: | |
os: [ubuntu-latest] # , windows-latest removed for now | |
env: ["docs"] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Pixi | |
uses: prefix-dev/[email protected] | |
with: | |
environments: ${{ matrix.env }} | |
pixi-version: v0.39.0 | |
cache: true | |
locked: false # wont be the same because of the tag | |
- name: Test docs build | |
run: | | |
pixi run -e ${{ matrix.env }} doc-build | |
################################################################################################ | |
# Publish-Docs: Publish documentation to GitHub Pages using mike only on main branch | |
################################################################################################ | |
Publish-Docs: | |
needs: Build-Docs | |
if: github.ref == 'refs/heads/main' | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
permissions: | |
# Need to give the action permission to write to the repository to deploy the docs | |
contents: write | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-latest] | |
env: ["docs"] | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Configure Git Credentials | |
run: | | |
git config user.name github-actions[bot] | |
git config user.email github-actions[bot]@users.noreply.github.com | |
- name: Install Pixi | |
uses: prefix-dev/[email protected] | |
with: | |
environments: ${{ matrix.env }} | |
pixi-version: v0.39.0 | |
cache: true | |
locked: false # wont be the same because of the tag | |
- name: Publish docs using mike | |
run: | | |
pixi run -e ${{ matrix.env }} mike deploy --push dev devel | |
################################################################################################ | |
# Semantic-Release: Run semantic-release to automate versioning and publishing | |
################################################################################################ | |
Semantic-Release: | |
permissions: | |
# Read releases read-all | |
contents: write | |
packages: write | |
issues: write | |
pull-requests: write | |
needs: [Unit-Tests, Quality-Control, Build-Docs] | |
# if pulling to main, deploy to PyPI | |
if: github.ref == 'refs/heads/main' | |
strategy: | |
matrix: | |
os: [ubuntu-latest] | |
python-version: ["3.12"] | |
env: ["publish"] | |
# Set up operating system | |
runs-on: ${{ matrix.os }} | |
# Concurrency is for preventing multiple runs of the same workflow | |
concurrency: release | |
outputs: | |
released: ${{ steps.release.outputs.released }} | |
version: ${{ steps.release.outputs.version }} | |
tag: ${{ steps.release.outputs.tag }} | |
# Define job steps | |
steps: | |
- name: Check-out repository | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- name: Install Pixi | |
uses: prefix-dev/[email protected] | |
env: | |
RUNNER_DEBUG: true | |
with: | |
environments: ${{ matrix.env }} | |
pixi-version: v0.39.0 | |
cache: true | |
locked: false | |
- name: Print Semver | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: pixi run --environment ${{ matrix.env }} semver | |
- name: Run semantic-release | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
id: release | |
run: pixi run --environment ${{ matrix.env }} release | |
- name: Test Outputs of semantic release step | |
run: | | |
echo "${{ steps.release.outputs.released }}" | |
echo "${{ steps.release.outputs.version }}" | |
echo "${{ steps.release.outputs.tag }}" | |
############################################################################################### | |
# Publish-To-PyPi & Test-PyPi-Installation: Publish to PyPI and test installation | |
############################################################################################### | |
Publish-To-PyPi: | |
needs: Semantic-Release | |
if: needs.Semantic-Release.outputs.released == 'true' | |
strategy: | |
matrix: | |
os: [ubuntu-latest] | |
python-version: ["3.12"] | |
env: ["publish"] | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Checkout the code with tag ${{ needs.Semantic-Release.outputs.tag }} | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ needs.Semantic-Release.outputs.tag }} | |
- name: Install Pixi | |
uses: prefix-dev/[email protected] | |
with: | |
environments: ${{ matrix.env }} | |
pixi-version: v0.39.0 | |
cache: true | |
locked: false # wont be the same because of the tag | |
- name: Publish to PyPI | |
env: | |
HATCH_INDEX_USER: __token__ | |
HATCH_INDEX_AUTH: ${{ secrets.PYPI_API_TOKEN }} | |
HATCH_INDEX_REPO: https://upload.pypi.org/legacy/ | |
run: | | |
pixi run --environment ${{ matrix.env }} publish-pypi |