mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #24747 -- Allowed transforms in QuerySet.order_by() and distinct(*fields).
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							bf26f66029
						
					
				
				
					commit
					2162f0983d
				
			| @@ -141,6 +141,31 @@ class TestQuerying(PostgreSQLTestCase): | ||||
|             [self.objs[0]] | ||||
|         ) | ||||
|  | ||||
|     def test_ordering_by_transform(self): | ||||
|         objs = [ | ||||
|             JSONModel.objects.create(field={'ord': 93, 'name': 'bar'}), | ||||
|             JSONModel.objects.create(field={'ord': 22.1, 'name': 'foo'}), | ||||
|             JSONModel.objects.create(field={'ord': -1, 'name': 'baz'}), | ||||
|             JSONModel.objects.create(field={'ord': 21.931902, 'name': 'spam'}), | ||||
|             JSONModel.objects.create(field={'ord': -100291029, 'name': 'eggs'}), | ||||
|         ] | ||||
|         query = JSONModel.objects.filter(field__name__isnull=False).order_by('field__ord') | ||||
|         self.assertSequenceEqual(query, [objs[4], objs[2], objs[3], objs[1], objs[0]]) | ||||
|  | ||||
|     def test_deep_values(self): | ||||
|         query = JSONModel.objects.values_list('field__k__l') | ||||
|         self.assertSequenceEqual( | ||||
|             query, | ||||
|             [ | ||||
|                 (None,), (None,), (None,), (None,), (None,), (None,), | ||||
|                 (None,), (None,), ('m',), (None,), (None,), (None,), | ||||
|             ] | ||||
|         ) | ||||
|  | ||||
|     def test_deep_distinct(self): | ||||
|         query = JSONModel.objects.distinct('field__k__l').values_list('field__k__l') | ||||
|         self.assertSequenceEqual(query, [('m',), (None,)]) | ||||
|  | ||||
|     def test_isnull_key(self): | ||||
|         # key__isnull works the same as has_key='key'. | ||||
|         self.assertSequenceEqual( | ||||
|   | ||||
		Reference in New Issue
	
	Block a user