Skip to content

πŸ› Fix dependency #54

πŸ› Fix dependency

πŸ› Fix dependency #54

Workflow file for this run

# Build Workflow
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python
name: πŸ“¦ Nested Dict Tools CI build
on:
push:
branches:
- main
pull_request:
branches:
- main
jobs:
build:
timeout-minutes: 30
strategy:
fail-fast: false
matrix:
python-version:
- "3.12"
# - "3.13"
os:
- ubuntu-latest
# - macos-latest
- windows-latest
include:
- os: ubuntu-latest
path: ~/.cache/pip
# - os: macos-latest
# path: ~/Library/Caches/pip
- os: windows-latest
path: ~\AppData\Local\pip\Cache
runs-on: ${{ matrix.os }}
defaults:
run:
shell: bash
steps:
- name: πŸ›ŽοΈ Checkout
uses: actions/checkout@v4
- name: 🐍 Install uv with caching
uses: astral-sh/setup-uv@v3
with:
enable-cache: true
version: "0.5.4"
- name: 🐍 Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: πŸ’Ύ Setup pip cache
uses: actions/cache@v4
with:
path: ${{ matrix.path }}
key: ${{ runner.os }}-pip-${{ hashFiles('uv.lock') }}
restore-keys: ${{ runner.os }}-pip-
- name: πŸ“₯ Install the project
run: |
uv sync --all-extras --dev
- name: 🏞️ Activate virtual environment
run: |
if [ "$RUNNER_OS" == "Windows" ]; then
source .venv\\Scripts\\activate
echo PATH=$PATH >> $GITHUB_ENV
pip install pipx # Problems with ruff action otherwise
else
source .venv/bin/activate
echo PATH=$PATH >> $GITHUB_ENV
fi
- name: 🧹 Lint with ruff @astral-sh
uses: astral-sh/ruff-action@v1
continue-on-error: true
- name: πŸͺ„ Format with ruff @astral-sh
uses: astral-sh/ruff-action@v1
with:
args: "format --diff"
continue-on-error: true
# - name: πŸ“₯ Install pytest-action dependencies
# run: uv pip install pytest-md pytest-emoji
# - name: πŸ§ͺ Run pytest @pavelzw
# uses: pavelzw/pytest-action@v2
# with:
# custom-arguments: "tests -rA --cov=."
# continue-on-error: true
# - name: πŸ§ͺ Run doctest @pavelzw
# uses: pavelzw/pytest-action@v2
# with:
# custom-arguments: "--doctest-modules"
# continue-on-error: true
- name: πŸ§ͺ Run Pytest with doctest
env:
REPORT_OUTPUT: md_report.md
run: |
echo "REPORT_FILE=${REPORT_OUTPUT}" >> "$GITHUB_ENV"
pytest --doctest-modules --md-report --md-report-flavor gfm --md-report-output "$REPORT_OUTPUT" --cov=. # -rA
continue-on-error: true
- name: πŸ§ͺ Add test output reports to the job summary
run: |
if [ -f "$REPORT_FILE" ]; then
echo "<details><summary>Failed Test Report</summary>" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
cat "$REPORT_FILE" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
echo "</details>" >> $GITHUB_STEP_SUMMARY
fi
- name: πŸ“Š Upload coverage to Codecov
uses: codecov/codecov-action@v5
with:
verbose: true
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
continue-on-error: true
# - name: βœ… Pylance type checking @jakebailey
# uses: jakebailey/pyright-action@v2
# with:
# pylance-version: latest-release
# stats: true
# # verbose: true
# continue-on-error: true
# - name: βœ… Verify public API types with Pylance @jakebailey
# uses: jakebailey/pyright-action@v2
# with:
# pylance-version: latest-release
# verify-types: nested_dict_tools
# # verbose: true
# continue-on-error: true
- name: βœ… Type checking with BasedPyright
run: basedpyright --stats
continue-on-error: true
- name: βœ… Verify public API types with BasedPyright
run: |
pip install -e .
basedpyright --verifytypes nest_dict_tools
continue-on-error: true
- name: πŸ—οΈ Build
run: |
pipx install hatch
hatch build