mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	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:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							83fbaa9231
						
					
				
				
					commit
					628c4a26ee
				
			| @@ -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')) | ||||||
|   | |||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -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(), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user