Skip to content

Commit

Permalink
Switch from poetry to vanilla setup.cfg + tox
Browse files Browse the repository at this point in the history
  • Loading branch information
dcermak committed Jan 10, 2025
1 parent 1250587 commit 241042c
Show file tree
Hide file tree
Showing 8 changed files with 135 additions and 1,448 deletions.
152 changes: 44 additions & 108 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,138 +19,84 @@ jobs:
python-version: '3.x'
- uses: actions/cache@v4
with:
path: ~/.cache/pypoetry/virtualenvs
key: poetry-${{ hashFiles('poetry.lock') }}
path: ~/.tox
key: tox-${{ hashFiles('tox.ini') }}-${{ hashFiles('setup.cfg') }}-${{ hashFiles('test-requirements.txt') }}

- run: |
pip install --upgrade poetry nox nox-poetry
nox -s format -- --check
generate_requirements:
name: Generate requirements.txt for Python 3.6 CI
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: '3.x'
- uses: actions/cache@v4
with:
path: ~/.cache/pypoetry/virtualenvs
key: poetry-${{ hashFiles('poetry.lock') }}

- run: |
pipx install poetry
poetry export --with=dev --without-hashes > requirements.txt
- uses: actions/upload-artifact@v4
with:
name: requirements
path: requirements.txt
if-no-files-found: error

ci_36:
name: Run the integration tests for Python 3.6
runs-on: ubuntu-20.04
needs: generate_requirements

strategy:
fail-fast: false
matrix:
container_runtime: ["podman", "docker"]

steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: 3.6

- uses: actions/download-artifact@v4
with:
name: requirements
path: .

- run: pip install -r test-requirements.txt

- run: |
export CUR_USER="$(whoami)"
sudo loginctl enable-linger ${CUR_USER}
- run: |
mkdir ./tmp/
chmod 1777 ./tmp
export TMPDIR="$(pwd)/tmp"
# duplication of noxfile.py because we can't use that one with python 3.6 :-/
coverage run -m pytest -vv tests -p pytest_container -x -n auto --reruns 3 --pytest-container-log-level DEBUG
coverage run -m pytest -vv tests -p pytest_container -x --reruns 3 --pytest-container-log-level DEBUG
coverage combine
coverage report -m
coverage xml
- name: verify that no stray containers are left
run: |
[[ $(${{ matrix.container_runtime }} ps -aq|wc -l) = "0" ]]
- name: verify that no stray volumes are left
run: |
[[ $(${{ matrix.container_runtime }} volume ls -q|wc -l) = "0" ]]
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v5
with:
token: ${{ secrets.CODECOV_TOKEN }}
- run: tox -e format -- --check

ci:
name: Run the integration tests
runs-on: "ubuntu-latest"
runs-on: ${{ matrix.os_version }}
strategy:
fail-fast: false
matrix:
python_version: ["3.7", "3.8", "3.9", "3.10", "3.11", "3.12", "3.13"]
container_runtime: ["podman", "docker"]
update_runtime: [ true, false ]
without_buildah: [ false ]
os_version: ["ubuntu-latest"]

exclude:
- container_runtime: "docker"
python_version: "3.7"
update_runtime: true
without_buildah: false
os_version: "ubuntu-latest"
- container_runtime: "docker"
python_version: "3.8"
update_runtime: true
without_buildah: false
os_version: "ubuntu-latest"
- container_runtime: "docker"
python_version: "3.9"
update_runtime: true
without_buildah: false
os_version: "ubuntu-latest"
- container_runtime: "docker"
python_version: "3.10"
update_runtime: true
without_buildah: false
os_version: "ubuntu-latest"
- container_runtime: "docker"
python_version: "3.11"
update_runtime: true
without_buildah: false
os_version: "ubuntu-latest"
- container_runtime: "docker"
python_version: "3.12"
update_runtime: true
without_buildah: false
os_version: "ubuntu-latest"
- container_runtime: "docker"
python_version: "3.13"
update_runtime: true
without_buildah: false
os_version: "ubuntu-latest"

include:
# also test without buildah, but only on the latest python
- python_version: "3.13"
container_runtime: "podman"
update_runtime: true
without_buildah: true
os_version: "ubuntu-latest"
- python_version: "3.13"
container_runtime: "podman"
update_runtime: false
without_buildah: true
os_version: "ubuntu-latest"

# and test python3.6 on ubuntu 20.04
- python_version: "3.6"
container_runtime: "podman"
update_runtime: false
without_buildah: false
os_version: "ubuntu-20.04"
- python_version: "3.6"
container_runtime: "docker"
update_runtime: false
without_buildah: false
os_version: "ubuntu-20.04"

steps:
- uses: actions/checkout@v4
Expand All @@ -160,10 +106,8 @@ jobs:

- uses: actions/cache@v4
with:
path: ~/.nox
key: nox-${{ matrix.python_version }}-${{ hashFiles('poetry.lock') }}

- run: pip install --upgrade nox poetry nox-poetry
path: ~/.tox
key: tox-${{ hashFiles('tox.ini') }}-${{ hashFiles('setup.cfg') }}-${{ hashFiles('test-requirements.txt') }}

- name: update the container runtime
if: ${{ matrix.update_runtime }}
Expand Down Expand Up @@ -194,15 +138,18 @@ jobs:
chmod 1777 ./tmp
export TMPDIR="$(pwd)/tmp"
export PULL_ALWAYS=0
nox -s "test-${{ matrix.python_version }}(${{ matrix.container_runtime }})" -- -x -n auto --reruns 3 --pytest-container-log-level DEBUG
export CONTAINER_RUNTIME=${{ matrix.container_runtime }}
tox -e py$(echo $PY_VER | tr -d . ) -- -x -n auto --reruns 3
export PULL_ALWAYS=1
nox -s "test-${{ matrix.python_version }}(${{ matrix.container_runtime }})" -- -x -n auto --reruns 3 --pytest-container-log-level DEBUG
nox -s "test-${{ matrix.python_version }}(${{ matrix.container_runtime }})" -- -x --reruns 3 --pytest-container-log-level DEBUG
nox -s coverage
tox -e py$(echo $PY_VER | tr -d . ) -- -x -n auto --reruns 3 --pytest-container-log-level DEBUG
tox -e py$(echo $PY_VER | tr -d . ) -- -x --reruns 3 --pytest-container-log-level DEBUG
tox -e coverage
env:
PY_VER: ${{ matrix.python_version }}
- name: verify that no stray containers are left
run: |
[[ $(podman ps -aq|wc -l) = '0' ]] || (podman ps -aq|xargs podman inspect; exit 1)
[[ $(${{ matrix.container_runtime }} ps -aq|wc -l) = '0' ]] || (${{ matrix.container_runtime }} ps -aq|xargs ${{ matrix.container_runtime }} inspect; exit 1)
- name: verify that no stray volumes are left
run: |
Expand All @@ -222,16 +169,9 @@ jobs:
- uses: actions/setup-python@v5
with:
python-version: "3.x"
- uses: actions/cache@v4
with:
path: ~/.cache/pypoetry/virtualenvs
key: poetry-${{ hashFiles('poetry.lock') }}

- name: Run the build
run: |
pipx install poetry
poetry install
poetry build
run: python setup.py sdist bdist_wheel

- uses: actions/upload-artifact@v4
with:
Expand Down Expand Up @@ -279,12 +219,10 @@ jobs:
python-version: '3.x'
- uses: actions/cache@v4
with:
path: ~/.nox
key: nox-${{ hashFiles('poetry.lock') }}
path: ~/.tox
key: tox-${{ hashFiles('tox.ini') }}-${{ hashFiles('setup.cfg') }}-${{ hashFiles('test-requirements.txt') }}

- run: pip install --upgrade nox poetry nox-poetry

- run: nox -s doc
- run: tox -e doc

- name: upload the build directory
uses: actions/upload-artifact@v4
Expand Down Expand Up @@ -328,15 +266,13 @@ jobs:

- uses: actions/cache@v4
with:
path: ~/.nox
key: nox-${{ hashFiles('poetry.lock') }}

- run: pip install --upgrade nox poetry nox-poetry
path: ~/.tox
key: tox-${{ hashFiles('tox.ini') }}-${{ hashFiles('setup.cfg') }}-${{ hashFiles('test-requirements.txt') }}

# grab the previously built wheel for checking with twine
- uses: actions/download-artifact@v4
with:
name: wheel
path: dist

- run: nox -s lint
- run: tox -e lint
5 changes: 1 addition & 4 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,7 @@ jobs:
python-version: "3.x"

- name: Install dependencies & build wheel
run: |
pipx install poetry
poetry install
poetry build
run: python setup.py sdist bdist_wheel

- name: Check the wheel
run: |
Expand Down
Loading

0 comments on commit 241042c

Please sign in to comment.