mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #30148 -- Logged COPY ... TO statements in connection.queries on PostgreSQL.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							f7408b49a5
						
					
				
				
					commit
					673fe2e3ec
				
			| @@ -11,6 +11,9 @@ from django.conf import settings | ||||
| from django.core.exceptions import ImproperlyConfigured | ||||
| from django.db import connections | ||||
| from django.db.backends.base.base import BaseDatabaseWrapper | ||||
| from django.db.backends.utils import ( | ||||
|     CursorDebugWrapper as BaseCursorDebugWrapper, | ||||
| ) | ||||
| from django.db.utils import DatabaseError as WrappedDatabaseError | ||||
| from django.utils.functional import cached_property | ||||
| from django.utils.safestring import SafeString | ||||
| @@ -281,3 +284,16 @@ class DatabaseWrapper(BaseDatabaseWrapper): | ||||
|     def pg_version(self): | ||||
|         with self.temporary_connection(): | ||||
|             return self.connection.server_version | ||||
|  | ||||
|     def make_debug_cursor(self, cursor): | ||||
|         return CursorDebugWrapper(cursor, self) | ||||
|  | ||||
|  | ||||
| class CursorDebugWrapper(BaseCursorDebugWrapper): | ||||
|     def copy_expert(self, sql, file, *args): | ||||
|         with self.debug_sql(sql): | ||||
|             return self.cursor.copy_expert(sql, file, *args) | ||||
|  | ||||
|     def copy_to(self, file, table, *args, **kwargs): | ||||
|         with self.debug_sql(sql='COPY %s TO STDOUT' % table): | ||||
|             return self.cursor.copy_to(file, table, *args, **kwargs) | ||||
|   | ||||
| @@ -201,6 +201,8 @@ Models | ||||
|   :class:`~django.db.models.functions.Trunc` database functions determines the | ||||
|   treatment of nonexistent and ambiguous datetimes. | ||||
|  | ||||
| * ``connection.queries`` now shows ``COPY … TO`` statements on PostgreSQL. | ||||
|  | ||||
| Requests and Responses | ||||
| ~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| import unittest | ||||
| from io import StringIO | ||||
| from unittest import mock | ||||
|  | ||||
| from django.core.exceptions import ImproperlyConfigured | ||||
| from django.db import DatabaseError, connection, connections | ||||
| from django.test import TestCase | ||||
| from django.test import TestCase, override_settings | ||||
|  | ||||
|  | ||||
| @unittest.skipUnless(connection.vendor == 'postgresql', 'PostgreSQL tests') | ||||
| @@ -176,3 +177,15 @@ class Tests(TestCase): | ||||
|             self.assertEqual(psycopg2_version(), (4, 2, 1)) | ||||
|         with mock.patch('psycopg2.__version__', '4.2b0.dev1 (dt dec pq3 ext lo64)'): | ||||
|             self.assertEqual(psycopg2_version(), (4, 2)) | ||||
|  | ||||
|     @override_settings(DEBUG=True) | ||||
|     def test_copy_cursors(self): | ||||
|         out = StringIO() | ||||
|         copy_expert_sql = 'COPY django_session TO STDOUT (FORMAT CSV, HEADER)' | ||||
|         with connection.cursor() as cursor: | ||||
|             cursor.copy_expert(copy_expert_sql, out) | ||||
|             cursor.copy_to(out, 'django_session') | ||||
|         self.assertEqual( | ||||
|             [q['sql'] for q in connection.queries], | ||||
|             [copy_expert_sql, 'COPY django_session TO STDOUT'], | ||||
|         ) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user