mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #32858 -- Fixed ExclusionConstraint crash with index transforms in expressions.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							501a371411
						
					
				
				
					commit
					b69b0c3fe8
				
			
							
								
								
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							| @@ -561,6 +561,7 @@ answer newbie questions, and generally made Django that much better: | ||||
|     Luan Pablo <luanpab@gmail.com> | ||||
|     Lucas Connors <https://www.revolutiontech.ca/> | ||||
|     Luciano Ramalho | ||||
|     Lucidiot <lucidiot@brainshit.fr> | ||||
|     Ludvig Ericson <ludvig.ericson@gmail.com> | ||||
|     Luis C. Berrocal <luis.berrocal.1942@gmail.com> | ||||
|     Łukasz Langa <lukasz@langa.pl> | ||||
|   | ||||
| @@ -2,6 +2,7 @@ from django.db import NotSupportedError | ||||
| from django.db.backends.ddl_references import Statement, Table | ||||
| from django.db.models import Deferrable, F, Q | ||||
| from django.db.models.constraints import BaseConstraint | ||||
| from django.db.models.expressions import Col | ||||
| from django.db.models.sql import Query | ||||
|  | ||||
| __all__ = ['ExclusionConstraint'] | ||||
| @@ -73,6 +74,8 @@ class ExclusionConstraint(BaseConstraint): | ||||
|                 expression = F(expression) | ||||
|             expression = expression.resolve_expression(query=query) | ||||
|             sql, params = compiler.compile(expression) | ||||
|             if not isinstance(expression, Col): | ||||
|                 sql = f'({sql})' | ||||
|             try: | ||||
|                 opclass = self.opclasses[idx] | ||||
|                 if opclass: | ||||
|   | ||||
| @@ -14,7 +14,9 @@ from django.test import modify_settings, skipUnlessDBFeature | ||||
| from django.utils import timezone | ||||
|  | ||||
| from . import PostgreSQLTestCase | ||||
| from .models import HotelReservation, RangesModel, Room, Scene | ||||
| from .models import ( | ||||
|     HotelReservation, IntegerArrayModel, RangesModel, Room, Scene, | ||||
| ) | ||||
|  | ||||
| try: | ||||
|     from psycopg2.extras import DateRange, NumericRange | ||||
| @@ -670,6 +672,19 @@ class ExclusionConstraintTests(PostgreSQLTestCase): | ||||
|             self.get_constraints(HotelReservation._meta.db_table), | ||||
|         ) | ||||
|  | ||||
|     def test_index_transform(self): | ||||
|         constraint_name = 'first_index_equal' | ||||
|         constraint = ExclusionConstraint( | ||||
|             name=constraint_name, | ||||
|             expressions=[('field__0', RangeOperators.EQUAL)], | ||||
|         ) | ||||
|         with connection.schema_editor() as editor: | ||||
|             editor.add_constraint(IntegerArrayModel, constraint) | ||||
|         self.assertIn( | ||||
|             constraint_name, | ||||
|             self.get_constraints(IntegerArrayModel._meta.db_table), | ||||
|         ) | ||||
|  | ||||
|     def test_range_adjacent_initially_deferred(self): | ||||
|         constraint_name = 'ints_adjacent_deferred' | ||||
|         self.assertNotIn(constraint_name, self.get_constraints(RangesModel._meta.db_table)) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user