Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 5 additions & 9 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,24 +9,20 @@ on:
jobs:
tests:
name: Python ${{ matrix.python-version }}
runs-on: ubuntu-20.04
runs-on: ubuntu-latest

strategy:
matrix:
python-version:
- 3.6
- 3.7
- 3.8
- 3.9
python-version: ["3.10", "3.11", "3.12", "3.13"]
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
python-version: ["3.10", "3.11", "3.12", "3.13"]
python-version: ["3.10", "3.11", "3.12", "3.13", "3.14"]

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is adding 3.14 here correct? As of today, the latest commit for pre-6.0 only mentions supported 3.12 and 3.13.

In theory, I'd entirely be onboard with adding a non-failing check run against 3.14, but considering the time delta since this pull request was opened, I'd rather chalk that up to nice-to-have vs. a hard requirement.

Copy link

@cclauss cclauss Oct 17, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

https://code.djangoproject.com/ticket/35844

Django 5.2 will be the first version to support Python 3.14, because Django 5.1 will end the mainstream support in April 2024.

https://forum.djangoproject.com/t/which-versions-of-django-will-support-python-3-14/43005


steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v5

- uses: actions/setup-python@v2
- uses: actions/setup-python@v6
with:
python-version: ${{ matrix.python-version }}

- uses: actions/cache@v2
- uses: actions/cache@v4
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('requirements/*.txt') }}
Expand Down
8 changes: 4 additions & 4 deletions .github/workflows/pre-commit.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,15 @@ on:

jobs:
pre-commit:
runs-on: ubuntu-20.04
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v5
with:
fetch-depth: 0

- uses: actions/setup-python@v2
- uses: actions/setup-python@v6

- uses: pre-commit/action@v2.0.0
- uses: pre-commit/action@v3.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,5 @@ html/
htmlcov/
*.egg-info/
.tox/
/temp
/venv
11 changes: 6 additions & 5 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
repos:
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.3.0
rev: v5.0.0
hooks:
- id: check-added-large-files
- id: check-case-conflict
Expand All @@ -11,24 +11,25 @@ repos:
- id: end-of-file-fixer
- id: trailing-whitespace
- repo: https://github.com/psf/black
rev: 22.8.0
rev: 25.1.0
hooks:
- id: black
language_version: python3
- repo: https://github.com/pycqa/isort
rev: 5.10.1
rev: 6.0.1
hooks:
- id: isort
- repo: https://github.com/PyCQA/flake8
rev: 5.0.4
rev: 7.1.2
hooks:
- id: flake8
additional_dependencies:
- flake8-bugbear
- flake8-comprehensions
- flake8-tidy-imports
- repo: https://github.com/mgedmin/check-manifest
rev: "0.48"
rev: "0.50"
hooks:
- id: check-manifest
args: [--no-build-isolation]
additional_dependencies: [setuptools, wheel]
4 changes: 2 additions & 2 deletions docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -90,8 +90,8 @@ Writing the same code with `django-vanilla-views`, you'd instead arrive at a sim

## Requirements

* **Django**: 2.2, 3.0, 3.1, 3.2
* **Python**: 3.6, 3.7, 3.8, 3.9
* **Django**: 4.2, 5.0, 5.1, 5.2
* **Python**: 3.10, 3.11, 3.12, 3.13
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
* **Python**: 3.10, 3.11, 3.12, 3.13
* **Python**: 3.10, 3.11, 3.12, 3.13, 3.14

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please see previous 3.14 comment.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

https://code.djangoproject.com/ticket/35844

Django 5.2 will be the first version to support Python 3.14, because Django 5.1 will end the mainstream support in April 2024.


## Installation

Expand Down
1 change: 0 additions & 1 deletion example/example/notes/migrations/0001_initial.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@


class Migration(migrations.Migration):

initial = True

dependencies = []
Expand Down
18 changes: 15 additions & 3 deletions example/manage.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,22 @@
#!/usr/bin/env python
"""Django's command-line utility for administrative tasks."""
import os
import sys

if __name__ == "__main__":

def main():
"""Run administrative tasks."""
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "example.settings")
try:
from django.core.management import execute_from_command_line
except ImportError as exc:
raise ImportError(
"Couldn't import Django. Are you sure it's installed and "
"available on your PYTHONPATH environment variable? Did you "
"forget to activate a virtual environment?"
) from exc
execute_from_command_line(sys.argv)

from django.core.management import execute_from_command_line

execute_from_command_line(sys.argv)
if __name__ == "__main__":
main()
4 changes: 2 additions & 2 deletions example/requirements.txt
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
Django>=1.8
django-vanilla-views==1.0.4
Django>=4.2
django-vanilla-views>=3.1.0
18 changes: 15 additions & 3 deletions manage.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,22 @@
#!/usr/bin/env python
"""Django's command-line utility for administrative tasks."""
import os
import sys

if __name__ == "__main__":

def main():
"""Run administrative tasks."""
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "testsettings")
try:
from django.core.management import execute_from_command_line
except ImportError as exc:
raise ImportError(
"Couldn't import Django. Are you sure it's installed and "
"available on your PYTHONPATH environment variable? Did you "
"forget to activate a virtual environment?"
) from exc
execute_from_command_line(sys.argv)

from django.core.management import execute_from_command_line

execute_from_command_line(sys.argv)
if __name__ == "__main__":
main()
2 changes: 1 addition & 1 deletion mkdocs.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@
next_url_map[path] = rel + path_list[idx + 1][:-3] + suffix


for (dirpath, _dirnames, filenames) in os.walk(docs_dir):
for dirpath, _dirnames, filenames in os.walk(docs_dir):
relative_dir = dirpath.replace(docs_dir, "").lstrip(os.path.sep)
build_dir = os.path.join(html_dir, relative_dir)

Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ requires = ["setuptools >= 40.6.0", "wheel"]
build-backend = "setuptools.build_meta"

[tool.black]
target-version = ['py36']
target-version = ['py310']

[tool.isort]
profile = "black"
10 changes: 5 additions & 5 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -83,16 +83,16 @@ def get_package_data(package):
"Changelog": "http://django-vanilla-views.org/topics/release-notes",
"Repository": "https://github.com/tomchristie/django-vanilla-views/",
},
python_requires=">=3.6",
python_requires=">=3.10",
install_requires=[],
classifiers=[
"Development Status :: 5 - Production/Stable",
"Environment :: Web Environment",
"Framework :: Django",
"Framework :: Django :: 2.2",
"Framework :: Django :: 3.0",
"Framework :: Django :: 3.1",
"Framework :: Django :: 3.2",
"Framework :: Django :: 4.2",
"Framework :: Django :: 5.0",
"Framework :: Django :: 5.1",
"Framework :: Django :: 5.2",
"Intended Audience :: Developers",
"License :: OSI Approved :: BSD License",
"Operating System :: OS Independent",
Expand Down
21 changes: 7 additions & 14 deletions testsettings.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
import django

DATABASES = {
"default": {
"ENGINE": "django.db.backends.sqlite3",
Expand All @@ -9,18 +7,13 @@

INSTALLED_APPS = ("vanilla",)

if django.VERSION >= (1, 10):
MIDDLEWARE = [
"django.middleware.common.CommonMiddleware",
"django.middleware.csrf.CsrfViewMiddleware",
]
else:
MIDDLEWARE_CLASSES = [
"django.middleware.common.CommonMiddleware",
"django.middleware.csrf.CsrfViewMiddleware",
]
MIDDLEWARE = [
"django.middleware.common.CommonMiddleware",
"django.middleware.csrf.CsrfViewMiddleware",
]

SECRET_KEY = "abcde12345"

if django.VERSION >= (3, 2):
DEFAULT_AUTO_FIELD = "django.db.models.AutoField"
DEFAULT_AUTO_FIELD = "django.db.models.AutoField"

USE_TZ = False
14 changes: 6 additions & 8 deletions tox.ini
Original file line number Diff line number Diff line change
@@ -1,15 +1,13 @@
[tox]
isolated_build = True
envlist =
py36-django{22,30,31,32}
py37-django{22,30,31,32}
py38-django{30,31,32}
py39-django{30,31,32}
py{310,311,312}-django{42,50,51,52}
py313-django{51,52}

[testenv]
commands = python -W error::DeprecationWarning -W error::PendingDeprecationWarning manage.py test
deps =
django22: django>=2.2,<3.0
django30: django>=3.0,<3.1
django31: django>=3.1,<3.2
django32: django>=3.2,<4.0
django42: django>=4.2,<5.0
django50: django>=5.0,<5.1
django51: django>=5.1,<5.2
django52: django>=5.2,<6.0
2 changes: 1 addition & 1 deletion vanilla/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
)
from vanilla.views import FormView, GenericView, TemplateView

__version__ = "3.0.0"
__version__ = "3.1.0"
__all__ = (
"View",
"GenericView",
Expand Down
17 changes: 3 additions & 14 deletions vanilla/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -52,14 +52,6 @@ def setUp(self):
self.factory = RequestFactory()
super(BaseTestCase, self).setUp()

def assertFormError(self, response, form, field, errors, msg_prefix=""):
# Hack to get around the fact that we're using request factory,
# instead of the full test client.
response.context = response.context_data
return super(BaseTestCase, self).assertFormError(
response, form, field, errors, msg_prefix
)

def assertContext(self, response, expected):
# Ensure the keys all match.
# Note that this style ensures we get nice descriptive failures.
Expand Down Expand Up @@ -301,8 +293,7 @@ def test_create_failed(self):
self.assertEqual(response.status_code, 200)
self.assertEqual(response.template_name, ["vanilla/example_form.html"])
self.assertFormError(
response,
"form",
response.context_data["form"],
"text",
["Ensure this value has at most 10 characters (it has 700)."],
)
Expand Down Expand Up @@ -379,8 +370,7 @@ def test_update_failed(self):
self.assertEqual(response.status_code, 200)
self.assertEqual(response.template_name, ["vanilla/example_form.html"])
self.assertFormError(
response,
"form",
response.context_data["form"],
"text",
["Ensure this value has at most 10 characters (it has 700)."],
)
Expand Down Expand Up @@ -614,8 +604,7 @@ def test_form_failure(self):
self.assertEqual(response.status_code, 200)
self.assertEqual(response.template_name, ["example.html"])
self.assertFormError(
response,
"form",
response.context_data["form"],
"text",
["Ensure this value has at most 10 characters (it has 700)."],
)
Expand Down
Loading