Refs #27996 -- Doc'd no extension required for RandomUUID() on PostgreSQL 13+.

https://www.postgresql.org/docs/13/functions-uuid.html
https://www.postgresql.org/docs/13/pgcrypto.html#id-1.11.7.34.10.5
This commit is contained in:
Nick Pope 2020-07-26 22:29:05 +01:00 committed by Mariusz Felisiak
parent 83fbaa9231
commit 628c4a26ee
3 changed files with 12 additions and 5 deletions

View File

@ -79,6 +79,10 @@ class DatabaseFeatures(BaseDatabaseFeatures):
def is_postgresql_12(self): def is_postgresql_12(self):
return self.connection.pg_version >= 120000 return self.connection.pg_version >= 120000
@cached_property
def is_postgresql_13(self):
return self.connection.pg_version >= 130000
has_brin_autosummarize = property(operator.attrgetter('is_postgresql_10')) has_brin_autosummarize = property(operator.attrgetter('is_postgresql_10'))
has_websearch_to_tsquery = property(operator.attrgetter('is_postgresql_11')) has_websearch_to_tsquery = property(operator.attrgetter('is_postgresql_11'))
supports_table_partitions = property(operator.attrgetter('is_postgresql_10')) supports_table_partitions = property(operator.attrgetter('is_postgresql_10'))

View File

@ -14,8 +14,8 @@ All of these functions are available from the
Returns a version 4 UUID. Returns a version 4 UUID.
The `pgcrypto extension`_ must be installed. You can use the On PostgreSQL < 13, the `pgcrypto extension`_ must be installed. You can use
:class:`~django.contrib.postgres.operations.CryptoExtension` migration the :class:`~django.contrib.postgres.operations.CryptoExtension` migration
operation to install it. operation to install it.
.. _pgcrypto extension: https://www.postgresql.org/docs/current/pgcrypto.html .. _pgcrypto extension: https://www.postgresql.org/docs/current/pgcrypto.html

View File

@ -1,6 +1,6 @@
from unittest import mock from unittest import mock
from django.db import migrations from django.db import connection, migrations
try: try:
from django.contrib.postgres.operations import ( from django.contrib.postgres.operations import (
@ -14,10 +14,12 @@ except ImportError:
BtreeGistExtension = mock.Mock() BtreeGistExtension = mock.Mock()
CITextExtension = mock.Mock() CITextExtension = mock.Mock()
CreateExtension = mock.Mock() CreateExtension = mock.Mock()
CryptoExtension = mock.Mock()
HStoreExtension = mock.Mock() HStoreExtension = mock.Mock()
TrigramExtension = mock.Mock() TrigramExtension = mock.Mock()
UnaccentExtension = mock.Mock() UnaccentExtension = mock.Mock()
needs_crypto_extension = False
else:
needs_crypto_extension = not connection.features.is_postgresql_13
class Migration(migrations.Migration): class Migration(migrations.Migration):
@ -30,7 +32,8 @@ class Migration(migrations.Migration):
# Ensure CreateExtension quotes extension names by creating one with a # Ensure CreateExtension quotes extension names by creating one with a
# dash in its name. # dash in its name.
CreateExtension('uuid-ossp'), CreateExtension('uuid-ossp'),
CryptoExtension(), # CryptoExtension is required for RandomUUID() on PostgreSQL < 13.
CryptoExtension() if needs_crypto_extension else mock.Mock(),
HStoreExtension(), HStoreExtension(),
TrigramExtension(), TrigramExtension(),
UnaccentExtension(), UnaccentExtension(),