From c738d0010e5e06445ba507daabe708173f2358d7 Mon Sep 17 00:00:00 2001 From: Kenneth Love Date: Mon, 4 Dec 2023 22:07:41 +0000 Subject: [PATCH] Install multiple Pythons for tox testing --- .devcontainer/devcontainer.json | 24 ++++++++++++++++++------ tox.ini | 18 ++++++++++++++++++ 2 files changed, 36 insertions(+), 6 deletions(-) create mode 100644 tox.ini diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json index fd14906..d4b1c1e 100644 --- a/.devcontainer/devcontainer.json +++ b/.devcontainer/devcontainer.json @@ -5,15 +5,27 @@ // Or use a Dockerfile or Docker Compose file. More info: https://containers.dev/guide/dockerfile "image": "mcr.microsoft.com/devcontainers/python:0-3.11", "features": { - "ghcr.io/devcontainers/features/python:1": { - "installTools": false, - "installJupyterlab": false, - "version": "3.11" + // "ghcr.io/devcontainers/features/python:1": { + // "version": "3.12" + // }, + "ghcr.io/eliises/devcontainer-features/devcontainers-cli:1": { + "version": "latest", + "nodeVersion": "latest" }, - "ghcr.io/eliises/devcontainer-features/devcontainers-cli:1": {}, "ghcr.io/wxw-matt/devcontainer-features/command_runner:0": {}, - "ghcr.io/wxw-matt/devcontainer-features/script_runner:0": {} + "ghcr.io/wxw-matt/devcontainer-features/script_runner:0": {}, + "ghcr.io/devcontainers-contrib/features/pipx-package:1": { + "includeDeps": true, + "package": "black", + "version": "latest", + "injections": "pylint pytest", + "interpreter": "python3" + }, + "ghcr.io/kennethlove/multiple-pythons/multiple-pythons:1": { + "versions": "3.12 3.11 3.10" + } }, + // "postCreateCommand": "", "postStartCommand": "pip install -e .[development,testing]", "customizations": { "vscode": { diff --git a/tox.ini b/tox.ini new file mode 100644 index 0000000..493efba --- /dev/null +++ b/tox.ini @@ -0,0 +1,18 @@ +[tox] +requires = + tox>=4 +env_list = py{310,311,312}-django{42,50} + +[testenv] +description = run unit tests +deps = + pytest>=7 + pytest-cov + pytest-django + pytest-lazy-fixture + pytest-randomly + pytest-xdist + django42: Django~=4.2 + django50: Django~=5.0 +commands = + pytest {posargs:tests}