1
0
mirror of https://github.com/django/django.git synced 2025-10-24 14:16:09 +00:00

Refs #33308 -- Modernized database wrapper in the PostgreSQL backend.

- Used connection.info instead of connection.get_parameter_status() and
  connection.server_info which don't exist in psycopg 3.
- Set encoding using the client_encoding connection parameter instead
  of connection.set_client_encoding() that doesn't exist in psycopg 3.
- Used the dbname connection parameter instead of deprecated
  alias - database.
This commit is contained in:
Florian Apolloner
2022-12-06 11:37:25 +01:00
committed by Mariusz Felisiak
parent 29b6a177d8
commit 6a21658163
2 changed files with 6 additions and 7 deletions

View File

@@ -186,16 +186,16 @@ class DatabaseWrapper(BaseDatabaseWrapper):
self.ops.max_name_length(), self.ops.max_name_length(),
) )
) )
conn_params = {} conn_params = {"client_encoding": "UTF8"}
if settings_dict["NAME"]: if settings_dict["NAME"]:
conn_params = { conn_params = {
"database": settings_dict["NAME"], "dbname": settings_dict["NAME"],
**settings_dict["OPTIONS"], **settings_dict["OPTIONS"],
} }
elif settings_dict["NAME"] is None: elif settings_dict["NAME"] is None:
# Connect to the default 'postgres' db. # Connect to the default 'postgres' db.
settings_dict.get("OPTIONS", {}).pop("service", None) settings_dict.get("OPTIONS", {}).pop("service", None)
conn_params = {"database": "postgres", **settings_dict["OPTIONS"]} conn_params = {"dbname": "postgres", **settings_dict["OPTIONS"]}
else: else:
conn_params = {**settings_dict["OPTIONS"]} conn_params = {**settings_dict["OPTIONS"]}
@@ -239,7 +239,7 @@ class DatabaseWrapper(BaseDatabaseWrapper):
def ensure_timezone(self): def ensure_timezone(self):
if self.connection is None: if self.connection is None:
return False return False
conn_timezone_name = self.connection.get_parameter_status("TimeZone") conn_timezone_name = self.connection.info.parameter_status("TimeZone")
timezone_name = self.timezone_name timezone_name = self.timezone_name
if timezone_name and conn_timezone_name != timezone_name: if timezone_name and conn_timezone_name != timezone_name:
with self.connection.cursor() as cursor: with self.connection.cursor() as cursor:
@@ -249,7 +249,6 @@ class DatabaseWrapper(BaseDatabaseWrapper):
def init_connection_state(self): def init_connection_state(self):
super().init_connection_state() super().init_connection_state()
self.connection.set_client_encoding("UTF8")
timezone_changed = self.ensure_timezone() timezone_changed = self.ensure_timezone()
if timezone_changed: if timezone_changed:
@@ -365,7 +364,7 @@ class DatabaseWrapper(BaseDatabaseWrapper):
@cached_property @cached_property
def pg_version(self): def pg_version(self):
with self.temporary_connection(): with self.temporary_connection():
return self.connection.server_version return self.connection.info.server_version
def make_debug_cursor(self, cursor): def make_debug_cursor(self, cursor):
return CursorDebugWrapper(cursor, self) return CursorDebugWrapper(cursor, self)

View File

@@ -164,7 +164,7 @@ class Tests(TestCase):
settings["NAME"] = None settings["NAME"] = None
settings["OPTIONS"] = {"service": "django_test"} settings["OPTIONS"] = {"service": "django_test"}
params = DatabaseWrapper(settings).get_connection_params() params = DatabaseWrapper(settings).get_connection_params()
self.assertEqual(params["database"], "postgres") self.assertEqual(params["dbname"], "postgres")
self.assertNotIn("service", params) self.assertNotIn("service", params)
def test_connect_and_rollback(self): def test_connect_and_rollback(self):