mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #35448 -- Fixed formatting of test --debug-sql output.
Also adds DatabaseOperations.format_debug_sql() hook for backends (e.g. NoSQL) to customize formatting.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							98767ba2ec
						
					
				
				
					commit
					d8f093908c
				
			| @@ -785,3 +785,7 @@ class BaseDatabaseOperations: | |||||||
|         rhs_expr = Col(rhs_table, rhs_field) |         rhs_expr = Col(rhs_table, rhs_field) | ||||||
|  |  | ||||||
|         return lhs_expr, rhs_expr |         return lhs_expr, rhs_expr | ||||||
|  |  | ||||||
|  |     def format_debug_sql(self, sql): | ||||||
|  |         # Hook for backends (e.g. NoSQL) to customize formatting. | ||||||
|  |         return sqlparse.format(sql, reindent=True, keyword_case="upper") | ||||||
|   | |||||||
| @@ -151,7 +151,7 @@ class CursorDebugWrapper(CursorWrapper): | |||||||
|             logger.debug( |             logger.debug( | ||||||
|                 "(%.3f) %s; args=%s; alias=%s", |                 "(%.3f) %s; args=%s; alias=%s", | ||||||
|                 duration, |                 duration, | ||||||
|                 sql, |                 self.db.ops.format_debug_sql(sql), | ||||||
|                 params, |                 params, | ||||||
|                 self.db.alias, |                 self.db.alias, | ||||||
|                 extra={ |                 extra={ | ||||||
|   | |||||||
| @@ -18,8 +18,6 @@ from contextlib import contextmanager | |||||||
| from importlib import import_module | from importlib import import_module | ||||||
| from io import StringIO | from io import StringIO | ||||||
|  |  | ||||||
| import sqlparse |  | ||||||
|  |  | ||||||
| import django | import django | ||||||
| from django.core.management import call_command | from django.core.management import call_command | ||||||
| from django.db import connections | from django.db import connections | ||||||
| @@ -97,9 +95,7 @@ class DebugSQLTextTestResult(unittest.TextTestResult): | |||||||
|             self.stream.writeln(self.separator2) |             self.stream.writeln(self.separator2) | ||||||
|             self.stream.writeln(err) |             self.stream.writeln(err) | ||||||
|             self.stream.writeln(self.separator2) |             self.stream.writeln(self.separator2) | ||||||
|             self.stream.writeln( |             self.stream.writeln(sql_debug) | ||||||
|                 sqlparse.format(sql_debug, reindent=True, keyword_case="upper") |  | ||||||
|             ) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class PDBDebugResult(unittest.TextTestResult): | class PDBDebugResult(unittest.TextTestResult): | ||||||
|   | |||||||
| @@ -77,7 +77,12 @@ class LastExecutedQueryTest(TestCase): | |||||||
|             connection.ops.last_executed_query(cursor, "", ()) |             connection.ops.last_executed_query(cursor, "", ()) | ||||||
|  |  | ||||||
|     def test_debug_sql(self): |     def test_debug_sql(self): | ||||||
|         list(Reporter.objects.filter(first_name="test")) |         qs = Reporter.objects.filter(first_name="test") | ||||||
|  |         ops = connections[qs.db].ops | ||||||
|  |         with mock.patch.object(ops, "format_debug_sql") as format_debug_sql: | ||||||
|  |             list(qs) | ||||||
|  |         # Queries are formatted with DatabaseOperations.format_debug_sql(). | ||||||
|  |         format_debug_sql.assert_called() | ||||||
|         sql = connection.queries[-1]["sql"].lower() |         sql = connection.queries[-1]["sql"].lower() | ||||||
|         self.assertIn("select", sql) |         self.assertIn("select", sql) | ||||||
|         self.assertIn(Reporter._meta.db_table, sql) |         self.assertIn(Reporter._meta.db_table, sql) | ||||||
|   | |||||||
| @@ -91,22 +91,26 @@ class TestDebugSQL(unittest.TestCase): | |||||||
|         ( |         ( | ||||||
|             """SELECT COUNT(*) AS "__count"\n""" |             """SELECT COUNT(*) AS "__count"\n""" | ||||||
|             """FROM "test_runner_person"\n""" |             """FROM "test_runner_person"\n""" | ||||||
|             """WHERE "test_runner_person"."first_name" = 'error';""" |             """WHERE "test_runner_person"."first_name" = 'error'; """ | ||||||
|  |             """args=('error',); alias=default""" | ||||||
|         ), |         ), | ||||||
|         ( |         ( | ||||||
|             """SELECT COUNT(*) AS "__count"\n""" |             """SELECT COUNT(*) AS "__count"\n""" | ||||||
|             """FROM "test_runner_person"\n""" |             """FROM "test_runner_person"\n""" | ||||||
|             """WHERE "test_runner_person"."first_name" = 'fail';""" |             """WHERE "test_runner_person"."first_name" = 'fail'; """ | ||||||
|  |             """args=('fail',); alias=default""" | ||||||
|         ), |         ), | ||||||
|         ( |         ( | ||||||
|             """SELECT COUNT(*) AS "__count"\n""" |             """SELECT COUNT(*) AS "__count"\n""" | ||||||
|             """FROM "test_runner_person"\n""" |             """FROM "test_runner_person"\n""" | ||||||
|             """WHERE "test_runner_person"."first_name" = 'subtest-error';""" |             """WHERE "test_runner_person"."first_name" = 'subtest-error'; """ | ||||||
|  |             """args=('subtest-error',); alias=default""" | ||||||
|         ), |         ), | ||||||
|         ( |         ( | ||||||
|             """SELECT COUNT(*) AS "__count"\n""" |             """SELECT COUNT(*) AS "__count"\n""" | ||||||
|             """FROM "test_runner_person"\n""" |             """FROM "test_runner_person"\n""" | ||||||
|             """WHERE "test_runner_person"."first_name" = 'subtest-fail';""" |             """WHERE "test_runner_person"."first_name" = 'subtest-fail'; """ | ||||||
|  |             """args=('subtest-fail',); alias=default""" | ||||||
|         ), |         ), | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
| @@ -122,14 +126,16 @@ class TestDebugSQL(unittest.TestCase): | |||||||
|         f"runTest ({test_class_path}.FailingSubTest{method_name}) ...", |         f"runTest ({test_class_path}.FailingSubTest{method_name}) ...", | ||||||
|         f"runTest ({test_class_path}.ErrorSubTest{method_name}) ...", |         f"runTest ({test_class_path}.ErrorSubTest{method_name}) ...", | ||||||
|         ( |         ( | ||||||
|             """SELECT COUNT(*) AS "__count" """ |             """SELECT COUNT(*) AS "__count"\n""" | ||||||
|             """FROM "test_runner_person" WHERE """ |             """FROM "test_runner_person"\nWHERE """ | ||||||
|             """"test_runner_person"."first_name" = 'pass';""" |             """"test_runner_person"."first_name" = 'pass'; """ | ||||||
|  |             """args=('pass',); alias=default""" | ||||||
|         ), |         ), | ||||||
|         ( |         ( | ||||||
|             """SELECT COUNT(*) AS "__count" """ |             """SELECT COUNT(*) AS "__count"\n""" | ||||||
|             """FROM "test_runner_person" WHERE """ |             """FROM "test_runner_person"\nWHERE """ | ||||||
|             """"test_runner_person"."first_name" = 'subtest-pass';""" |             """"test_runner_person"."first_name" = 'subtest-pass'; """ | ||||||
|  |             """args=('subtest-pass',); alias=default""" | ||||||
|         ), |         ), | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user