From 30e5356c2ecb220e0ac866a7860aefbc90b97aa0 Mon Sep 17 00:00:00 2001 From: Aymeric Augustin Date: Sat, 14 Feb 2015 09:53:17 +0100 Subject: [PATCH] [1.8.x] Cleaned up init_connection_state in the psycopg2 backend. settings_dict['TIME_ZONE'] is set in ConnectionHandler.ensure_defaults. Backport of 28e97a9bdc6c672a1304570aa75f6311fb1112e2 from master --- .../db/backends/postgresql_psycopg2/base.py | 37 +++++++++---------- 1 file changed, 18 insertions(+), 19 deletions(-) diff --git a/django/db/backends/postgresql_psycopg2/base.py b/django/db/backends/postgresql_psycopg2/base.py index d2e114fea57..2efb904997f 100644 --- a/django/db/backends/postgresql_psycopg2/base.py +++ b/django/db/backends/postgresql_psycopg2/base.py @@ -186,27 +186,26 @@ class DatabaseWrapper(BaseDatabaseWrapper): return connection def init_connection_state(self): - settings_dict = self.settings_dict self.connection.set_client_encoding('UTF8') - tz = 'UTC' if settings.USE_TZ else settings_dict.get('TIME_ZONE') - if tz: - try: - get_parameter_status = self.connection.get_parameter_status - except AttributeError: - # psycopg2 < 2.0.12 doesn't have get_parameter_status - conn_tz = None - else: - conn_tz = get_parameter_status('TimeZone') - if conn_tz != tz: - cursor = self.connection.cursor() - try: - cursor.execute(self.ops.set_time_zone_sql(), [tz]) - finally: - cursor.close() - # Commit after setting the time zone (see #17062) - if not self.get_autocommit(): - self.connection.commit() + tz = self.settings_dict['TIME_ZONE'] + try: + get_parameter_status = self.connection.get_parameter_status + except AttributeError: + # psycopg2 < 2.0.12 doesn't have get_parameter_status + conn_tz = None + else: + conn_tz = get_parameter_status('TimeZone') + + if conn_tz != tz: + cursor = self.connection.cursor() + try: + cursor.execute(self.ops.set_time_zone_sql(), [tz]) + finally: + cursor.close() + # Commit after setting the time zone (see #17062) + if not self.get_autocommit(): + self.connection.commit() def create_cursor(self): cursor = self.connection.cursor()