From cf3c7d10781a8f2b9bb585de4ed1cc4ded1b219d Mon Sep 17 00:00:00 2001 From: Dylan Verheul Date: Thu, 21 Dec 2023 17:00:31 +0100 Subject: [PATCH 1/2] Revert packaging tools to setuptools, build, tox and twine --- .github/workflows/test.yml | 104 +++++++++++++++++++++++-------------- .readthedocs.yml | 6 ++- CHANGELOG.md | 1 + CONTRIBUTING.md | 4 +- Makefile | 38 +++++++++----- docs/conf.py | 9 ++-- docs/requirements.txt | 3 ++ pyproject.toml | 90 +++----------------------------- requirements-dev.txt | 2 + requirements-test.txt | 3 ++ tox.ini | 50 ++++++++++++++++++ 11 files changed, 164 insertions(+), 146 deletions(-) create mode 100644 docs/requirements.txt create mode 100644 requirements-dev.txt create mode 100644 requirements-test.txt create mode 100644 tox.ini diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 0059377..53422fb 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -6,65 +6,89 @@ concurrency: group: test-${{ github.head_ref }} cancel-in-progress: true -env: - PYTHONUNBUFFERED: "1" - FORCE_COLOR: "1" - jobs: - - static_tests: - name: Static Tests + ruff: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - - name: Set up Python - uses: actions/setup-python@v5 - with: - python-version: "3.11" - - name: Install latest pip and Hatch - run: pip install --upgrade pip hatch - - name: Lint - run: hatch run lint:all - - name: Docs - run: hatch run docs:build - - name: Build - run: hatch build + - uses: chartboost/ruff-action@v1 tests_matrix: - name: Python ${{ matrix.python-version }} runs-on: ubuntu-latest strategy: - fail-fast: false matrix: - python-version: ["3.8", "3.9", "3.10", "3.11"] + python-version: [3.8, 3.9, "3.10", 3.11, 3.12] + django-version: [3.2, 4.1, 4.2, 5.0, "main"] + exclude: + # Django 3.2 + - python-version: "3.10" + django-version: 3.2 + - python-version: 3.11 + django-version: 3.2 + - python-version: 3.12 + django-version: 3.2 - steps: - - uses: actions/checkout@v4 + # Django 4.1 + - python-version: 3.12 + django-version: 4.1 - - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v5 - with: - python-version: ${{ matrix.python-version }} + # Django 4.2 + - python-version: 3.12 + django-version: 4.2 - - name: Install latest pip, Hatch and coveralls - run: pip install --upgrade pip hatch coveralls + # Django 5.0 + - python-version: 3.8 + django-version: 5.0 + - python-version: 3.9 + django-version: 5.0 - - name: Run tests - run: hatch run test-cov + # Django main + - python-version: 3.8 + django-version: "main" + - python-version: 3.9 + django-version: "main" - - name: Coverage combine - run: coverage combine + steps: + - uses: actions/checkout@v4 + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v5 + with: + python-version: ${{ matrix.python-version }} + cache: 'pip' + cache-dependency-path: requirements-test.txt + - run: python -m pip install -r requirements-test.txt + - run: python -m pip install -U Django==${{ matrix.django-version }} + if: matrix.django-version != 'main' + - run: python -m pip install -U https://github.com/django/django/archive/master.tar.gz + if: matrix.django-version == 'main' + - run: python -m pip install -e . + - run: coverage run manage.py test + - run: python -m pip install -U coveralls + - name: Upload coveralls (parallel) + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + COVERALLS_PARALLEL: true + run: coveralls --service=github - - name: Upload coveralls (parallel) - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - COVERALLS_PARALLEL: true - run: coveralls --service=github + docs: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-python@v5 + with: + python-version: "3.11" + cache: 'pip' + cache-dependency-path: docs/requirements.txt + - name: Install and build + run: | + python -m pip install -r docs/requirements.txt + python -m pip install -e . + make docs tests: if: always() runs-on: ubuntu-latest - needs: [static_tests, tests_matrix] + needs: [ tests_matrix, ruff, docs ] steps: - name: Check tests matrix status if: needs.tests_matrix.result != 'success' diff --git a/.readthedocs.yml b/.readthedocs.yml index 636b846..b987040 100644 --- a/.readthedocs.yml +++ b/.readthedocs.yml @@ -5,6 +5,8 @@ build: tools: python: "3.11" commands: - - pip install -U pip hatch - - hatch run docs:build + - pip install -U pip + - pip install -U -r docs/requirements.txt + - pip install -e . + - make docs - mv docs/_build $READTHEDOCS_OUTPUT diff --git a/CHANGELOG.md b/CHANGELOG.md index 2620ecf..0cfb0f8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ - Use ruff instead of black for formatting (#392). - Remove support for Python 3.7 (EOL) (#388). +- Revert packaging tools to setuptools, build, tox and twine (). ## 23.5 (2023-06-02) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 7775f00..8df0a30 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -45,8 +45,6 @@ Ready to contribute? Here\'s how to set up `django-marina` for local development You will need some knowledge of git, github, and Python/Django development. Using a Python virtual environment is advised. -This project uses [Hatch](https://github.com/pypa/hatch) for environments and builds. - ### Local installation This section assumes you know about local Python versions and virtual environments. @@ -56,7 +54,7 @@ To clone the repository and install the requirements for local development: ```console git clone git://github.com/zostera/django-marina.git cd django-marina -pip install -U pip hatch +pip install -U pip -r requirements-dev.txt pip install -e . ``` diff --git a/Makefile b/Makefile index 5701451..a8d5ca3 100644 --- a/Makefile +++ b/Makefile @@ -1,31 +1,37 @@ -VERSION := $(shell hatch version) +VERSION := $(shell python -c "import django_marina;print(django_marina.__version__)") .PHONY: test test: - hatch run test + coverage run manage.py test + coverage report .PHONY: tests tests: - hatch run all:test + nox .PHONY: reformat reformat: - hatch run lint:fmt + ruff --fix . + ruff format . .PHONY: lint lint: - hatch run lint:style + ruff . .PHONY: docs -docs: - hatch run docs:build +docs: clean + cd docs && sphinx-build -b html -d _build/doctrees . _build/html + +.PHONY: example +example: + cd example && python manage.py runserver .PHONY: porcelain porcelain: ifeq ($(shell git status --porcelain),) @echo "Working directory is clean." else - @echo "Error - working directory is dirty. Commit those changes!"; + @echo "Error - working directory is dirty. Commit your changes."; @exit 1; endif @@ -34,17 +40,25 @@ branch: ifeq ($(shell git rev-parse --abbrev-ref HEAD),main) @echo "On branch main." else - @echo "Error - Not on branch main!" + @echo "Error - Not on branch main." @exit 1; endif .PHONY: build build: docs - rm -rf build dist src/*.egg-info - hatch build + python -m build .PHONY: publish publish: porcelain branch build - hatch publish + twine check dist/* + twine upload dist/* git tag -a v${VERSION} -m "Release ${VERSION}" git push origin --tags + +.PHONY: clean +clean: docs + rm -rf build dist src/*.egg-info .coverage* + +.PHONY: version +version: + @echo ${VERSION} diff --git a/docs/conf.py b/docs/conf.py index 340a6c6..f34e299 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -3,18 +3,17 @@ import tomllib +module = importlib.import_module("django_marina") + with open("../pyproject.toml", "rb") as f: pyproject = tomllib.load(f) project = pyproject["project"]["name"] -project_with_underscores = project.replace("-", "_") -module = importlib.import_module(f"{project_with_underscores}") - -authors = ", ".join(author["name"] for author in pyproject["project"]["authors"]) release = module.__version__ version = ".".join(release.split(".")[:2]) +author = ", ".join(author["name"] for author in pyproject["project"]["authors"]) year = datetime.now().year -copyright = f"{year} {authors}" +copyright = f"{year}, {author}" extensions = [ "sphinx.ext.autodoc", diff --git a/docs/requirements.txt b/docs/requirements.txt new file mode 100644 index 0000000..cb2e9af --- /dev/null +++ b/docs/requirements.txt @@ -0,0 +1,3 @@ +sphinx>=7.2.6 +sphinx-mdinclude>=0.5.3 +furo>=2023.05.20 diff --git a/pyproject.toml b/pyproject.toml index 000716a..5206354 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [build-system] -build-backend = "hatchling.build" -requires = ["hatchling"] +build-backend = "setuptools.build_meta" +requires = ["setuptools"] [project] authors = [ @@ -21,6 +21,7 @@ classifiers = [ "Programming Language :: Python :: 3.9", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", + "Programming Language :: Python :: 3.12", "Topic :: Software Development :: Libraries", "Topic :: Utilities", ] @@ -29,13 +30,11 @@ dependencies = [ "beautifulsoup4>=4.8.0", ] description = "Django extensions by Zostera" -dynamic = [ - "version", -] -license = "BSD-3-Clause" +license = {file = "LICENSE"} name = "django-marina" readme = "README.md" requires-python = ">=3.8" +version = "23.5.dev1" [project.urls] Changelog = "https://github.com/zostera/django-marina/blob/main/CHANGELOG.md" @@ -44,82 +43,6 @@ Homepage = "https://github.com/zostera/django-marina" Issues = "https://github.com/zostera/django-marina/issues" Source = "https://github.com/zostera/django-marina" -[tool.hatch.version] -path = "src/django_marina/__about__.py" - -[tool.hatch.envs.default] -dependencies = [ - "coverage[toml]>=7.2.6", -] -matrix-name-format = "dj{value}" - -[tool.hatch.envs.default.scripts] -cov = [ - "test-cov", - "cov-report", -] -cov-report = [ - "- coverage combine", - "coverage report", -] -test = "python manage.py test {args:tests}" -test-cov = "coverage run manage.py test {args:tests}" - -[[tool.hatch.envs.all.matrix]] -django = ["3.2", "4.1", "4.2"] -python = ["3.8", "3.9"] - -[[tool.hatch.envs.all.matrix]] -django = ["3.2", "4.1", "4.2", "main"] -python = ["3.10"] - -[[tool.hatch.envs.all.matrix]] -django = ["4.1", "4.2", "main"] -python = ["3.11"] - -[tool.hatch.envs.all.overrides] -matrix.django.dependencies = [ - {value = "django~=3.2.0", if = ["3.2"]}, - {value = "django~=4.1.0", if = ["4.1"]}, - {value = "django~=4.2.0", if = ["4.2"]}, - {value = "django @ git+https://github.com/django/django.git", if = ["main"]}, -] - -[tool.hatch.envs.docs] -dependencies = [ - "sphinx>=7.0.1", - "sphinx-mdinclude>=0.5.3", - "furo>=2023.05.20", -] -python = "3.11" -template = "docs" - -[tool.hatch.envs.docs.scripts] -build = [ - "clean", - "cd docs && sphinx-build -b html -d _build/doctrees . _build/html", -] -clean = "rm -rf docs/_build" - -[tool.hatch.envs.lint] -dependencies = [ - "ruff>0.1", -] -detached = true - -[tool.hatch.envs.lint.scripts] -all = [ - "style", -] -fmt = [ - "ruff --fix {args:.}", - "ruff format {args:.}", - "style", -] -style = [ - "ruff {args:.}", -] - [tool.ruff] fix = false fixable = [ @@ -154,8 +77,7 @@ known-third-party = ["django"] [tool.coverage.run] branch = true -parallel = true -source = ["src"] +source = ["src", "tests"] [tool.coverage.paths] package = ["src/django_marina", "*/django_marina/src/django_marina"] diff --git a/requirements-dev.txt b/requirements-dev.txt new file mode 100644 index 0000000..882f3ef --- /dev/null +++ b/requirements-dev.txt @@ -0,0 +1,2 @@ +-r requirements-test.txt +-r docs/requirements.txt diff --git a/requirements-test.txt b/requirements-test.txt new file mode 100644 index 0000000..0cd6d95 --- /dev/null +++ b/requirements-test.txt @@ -0,0 +1,3 @@ +tox==4.11.4 +coverage==7.3.4 +ruff==0.1.8 diff --git a/tox.ini b/tox.ini new file mode 100644 index 0000000..2501070 --- /dev/null +++ b/tox.ini @@ -0,0 +1,50 @@ +[tox] +args_are_paths = false +envlist = + py38-{3.2,4.1,4.2}, + py39-{3.2,4.1,4.2}, + py310-{3.2,4.1,4.2,5.0,main}, + py311-{4.1,4.2,5.0,main}, + py312-{4.2,5.0,main}, + docs, + lint, + +[testenv] +basepython = + py37: python3.7 + py38: python3.8 + py39: python3.9 + py310: python3.10 + py311: python3.11 + py312: python3.12 +usedevelop = true +pip_pre = true +setenv = + PYTHONPATH={toxinidir} + PYTHONWARNINGS=all +commands = + python manage.py test {posargs} +deps = + 3.2: Django==3.2.* + 4.0: Django==4.0.* + 4.1: Django==4.1.* + 4.2: Django==4.2.* + 5.0: Django==5.0.* + main: https://github.com/django/django/archive/main.tar.gz + -r{toxinidir}/requirements-test.txt + +[testenv:ruff] +basepython = python3.11 +allowlist_externals = ruff +deps = ruff +commands = ruff . + +[testenv:docs] +basepython = python3.11 +allowlist_externals = make +setenv = + PYTHONWARNINGS=default +commands = + make docs +deps = + -r{toxinidir}/docs/requirements.txt From e9a105b177f1a026f30b299e7353f02c42261330 Mon Sep 17 00:00:00 2001 From: Dylan Verheul Date: Thu, 21 Dec 2023 17:00:57 +0100 Subject: [PATCH 2/2] Update CHANGELOG --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0cfb0f8..84a5563 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,7 +4,7 @@ - Use ruff instead of black for formatting (#392). - Remove support for Python 3.7 (EOL) (#388). -- Revert packaging tools to setuptools, build, tox and twine (). +- Revert packaging tools to setuptools, build, tox and twine (#394). ## 23.5 (2023-06-02)