mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #29886 -- Fixed unaccent lookup when PostgreSQL's standard_conforming_strings option is off.
Thanks Tom McClure for the patch.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							74ddd0e83b
						
					
				
				
					commit
					dfcdc8992f
				
			| @@ -121,7 +121,7 @@ class DatabaseWrapper(BaseDatabaseWrapper): | |||||||
|     # |     # | ||||||
|     # Note: we use str.format() here for readability as '%' is used as a wildcard for |     # Note: we use str.format() here for readability as '%' is used as a wildcard for | ||||||
|     # the LIKE operator. |     # the LIKE operator. | ||||||
|     pattern_esc = r"REPLACE(REPLACE(REPLACE({}, '\', '\\'), '%%', '\%%'), '_', '\_')" |     pattern_esc = r"REPLACE(REPLACE(REPLACE({}, E'\\', E'\\\\'), E'%%', E'\\%%'), E'_', E'\\_')" | ||||||
|     pattern_ops = { |     pattern_ops = { | ||||||
|         'contains': "LIKE '%%' || {} || '%%'", |         'contains': "LIKE '%%' || {} || '%%'", | ||||||
|         'icontains': "LIKE '%%' || UPPER({}) || '%%'", |         'icontains': "LIKE '%%' || UPPER({}) || '%%'", | ||||||
|   | |||||||
| @@ -1,3 +1,4 @@ | |||||||
|  | from django.db import connection | ||||||
| from django.test import modify_settings | from django.test import modify_settings | ||||||
|  |  | ||||||
| from . import PostgreSQLTestCase | from . import PostgreSQLTestCase | ||||||
| @@ -42,6 +43,24 @@ class UnaccentTest(PostgreSQLTestCase): | |||||||
|             ordered=False |             ordered=False | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     def test_unaccent_with_conforming_strings_off(self): | ||||||
|  |         """SQL is valid when standard_conforming_strings is off.""" | ||||||
|  |         with connection.cursor() as cursor: | ||||||
|  |             cursor.execute('SHOW standard_conforming_strings') | ||||||
|  |             disable_conforming_strings = cursor.fetchall()[0][0] == 'on' | ||||||
|  |             if disable_conforming_strings: | ||||||
|  |                 cursor.execute('SET standard_conforming_strings TO off') | ||||||
|  |             try: | ||||||
|  |                 self.assertQuerysetEqual( | ||||||
|  |                     self.Model.objects.filter(field__unaccent__endswith='éÖ'), | ||||||
|  |                     ['àéÖ', 'aeO'], | ||||||
|  |                     transform=lambda instance: instance.field, | ||||||
|  |                     ordered=False, | ||||||
|  |                 ) | ||||||
|  |             finally: | ||||||
|  |                 if disable_conforming_strings: | ||||||
|  |                     cursor.execute('SET standard_conforming_strings TO on') | ||||||
|  |  | ||||||
|     def test_unaccent_accentuated_needle(self): |     def test_unaccent_accentuated_needle(self): | ||||||
|         self.assertQuerysetEqual( |         self.assertQuerysetEqual( | ||||||
|             self.Model.objects.filter(field__unaccent="aéÖ"), |             self.Model.objects.filter(field__unaccent="aéÖ"), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user