Django 2.2.1 release notes
May 1, 2019
Django 2.2.1 fixes several bugs in 2.2.
Bugfixes
- Fixed a regression in Django 2.1 that caused the incorrect quoting of
database user password when using
dbshell
on Oracle
(#30307).
- Added compatibility for
psycopg2
2.8 (#30331).
- Fixed a regression in Django 2.2 that caused a crash when loading the
template for the technical 500 debug page (#30324).
- Fixed crash of
ordering
argument in
ArrayAgg
and
StringAgg
when it contains an
expression with params (#30332).
- Fixed a regression in Django 2.2 that caused a single instance fast-delete
to not set the primary key to
None
(#30330).
- Prevented
makemigrations
from generating infinite migrations for
check constraints and partial indexes when condition
contains
a range
object (#30350).
- Reverted an optimization in Django 2.2 (#29725) that caused the
inconsistent behavior of
count()
and exists()
on a reverse
many-to-many relationship with a custom manager (#30325).
- Fixed a regression in Django 2.2 where
Paginator
crashes if object_list
is
a queryset ordered or aggregated over a nested JSONField
key transform
(#30335).
- Fixed a regression in Django 2.2 where
IntegerField
validation of
database limits crashes if limit_value
attribute in a custom validator is
callable (#30328).
- Fixed a regression in Django 2.2 where
SearchVector
generates SQL that is
not indexable (#30385).
- Fixed a regression in Django 2.2 that caused an exception to be raised when
a custom error handler could not be imported (#30318).
- Relaxed the system check added in Django 2.2 for the admin app’s dependencies
to reallow use of
SessionMiddleware
subclasses,
rather than requiring django.contrib.sessions
to be in
INSTALLED_APPS
(#30312).
- Increased the default timeout when using
Watchman
to 5 seconds to prevent
falling back to StatReloader
on larger projects and made it customizable
via the DJANGO_WATCHMAN_TIMEOUT
environment variable
(#30361).
- Fixed a regression in Django 2.2 that caused a crash when migrating
permissions for proxy models if the target permissions already existed. For
example, when a permission had been created manually or a model had been
migrated from concrete to proxy (#30351).
- Fixed a regression in Django 2.2 that caused a crash of
runserver
when URLConf modules raised exceptions (#30323).
- Fixed a regression in Django 2.2 where changes were not reliably detected by
auto-reloader when using
StatReloader
(#30323).
- Fixed a migration crash on Oracle and PostgreSQL when adding a check
constraint with a
contains
, startswith
, or endswith
lookup (or
their case-insensitive variant) (#30408).
- Fixed a migration crash on Oracle and SQLite when adding a check constraint
with
condition
contains |
(OR
) operator (#30412).