mirror of
				https://github.com/django/django.git
				synced 2025-10-24 14:16:09 +00:00 
			
		
		
		
	Made prefetch_related SQL inspection tests less brittle.
After refs #16614, integers might appear outside the WHERE clause.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							e5e3747357
						
					
				
				
					commit
					ee1c1c696b
				
			| @@ -44,6 +44,13 @@ class PrefetchRelatedTests(TestCase): | |||||||
|         cls.reader1.books_read.add(cls.book1, cls.book4) |         cls.reader1.books_read.add(cls.book1, cls.book4) | ||||||
|         cls.reader2.books_read.add(cls.book2, cls.book4) |         cls.reader2.books_read.add(cls.book2, cls.book4) | ||||||
|  |  | ||||||
|  |     def assertWhereContains(self, sql, needle): | ||||||
|  |         where_idx = sql.index('WHERE') | ||||||
|  |         self.assertEqual( | ||||||
|  |             sql.count(str(needle), where_idx), 1, | ||||||
|  |             msg="WHERE clause doesn't contain %s, actual SQL: %s" % (needle, sql[where_idx:]) | ||||||
|  |         ) | ||||||
|  |  | ||||||
|     def test_m2m_forward(self): |     def test_m2m_forward(self): | ||||||
|         with self.assertNumQueries(2): |         with self.assertNumQueries(2): | ||||||
|             lists = [list(b.authors.all()) for b in Book.objects.prefetch_related('authors')] |             lists = [list(b.authors.all()) for b in Book.objects.prefetch_related('authors')] | ||||||
| @@ -238,21 +245,21 @@ class PrefetchRelatedTests(TestCase): | |||||||
|             list(Book.objects.prefetch_related('authors__addresses')) |             list(Book.objects.prefetch_related('authors__addresses')) | ||||||
|  |  | ||||||
|         sql = queries[-1]['sql'] |         sql = queries[-1]['sql'] | ||||||
|         self.assertEqual(sql.count(self.author1.name), 1) |         self.assertWhereContains(sql, self.author1.name) | ||||||
|  |  | ||||||
|     def test_m2m_then_m2m_object_ids(self): |     def test_m2m_then_m2m_object_ids(self): | ||||||
|         with CaptureQueriesContext(connection) as queries: |         with CaptureQueriesContext(connection) as queries: | ||||||
|             list(Book.objects.prefetch_related('authors__favorite_authors')) |             list(Book.objects.prefetch_related('authors__favorite_authors')) | ||||||
|  |  | ||||||
|         sql = queries[-1]['sql'] |         sql = queries[-1]['sql'] | ||||||
|         self.assertEqual(sql.count(self.author1.name), 1) |         self.assertWhereContains(sql, self.author1.name) | ||||||
|  |  | ||||||
|     def test_m2m_then_reverse_one_to_one_object_ids(self): |     def test_m2m_then_reverse_one_to_one_object_ids(self): | ||||||
|         with CaptureQueriesContext(connection) as queries: |         with CaptureQueriesContext(connection) as queries: | ||||||
|             list(Book.objects.prefetch_related('authors__authorwithage')) |             list(Book.objects.prefetch_related('authors__authorwithage')) | ||||||
|  |  | ||||||
|         sql = queries[-1]['sql'] |         sql = queries[-1]['sql'] | ||||||
|         self.assertEqual(sql.count(str(self.author1.id)), 1, sql) |         self.assertWhereContains(sql, self.author1.id) | ||||||
|  |  | ||||||
|  |  | ||||||
| class CustomPrefetchTests(TestCase): | class CustomPrefetchTests(TestCase): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user