Fixed #32732 -- Removed usage of deprecated 'db' and 'passwd' connection options in MySQL backend.
The 'db' and 'passwd' connection options have been deprecated, use 'database' and 'password' instead (available since mysqlclient >= 1.3.8). This also allows the 'database' option in DATABASES['OPTIONS'] on MySQL.
This commit is contained in:
parent
d06c5b3581
commit
1061f52436
|
@ -200,9 +200,9 @@ class DatabaseWrapper(BaseDatabaseWrapper):
|
||||||
if settings_dict['USER']:
|
if settings_dict['USER']:
|
||||||
kwargs['user'] = settings_dict['USER']
|
kwargs['user'] = settings_dict['USER']
|
||||||
if settings_dict['NAME']:
|
if settings_dict['NAME']:
|
||||||
kwargs['db'] = settings_dict['NAME']
|
kwargs['database'] = settings_dict['NAME']
|
||||||
if settings_dict['PASSWORD']:
|
if settings_dict['PASSWORD']:
|
||||||
kwargs['passwd'] = settings_dict['PASSWORD']
|
kwargs['password'] = settings_dict['PASSWORD']
|
||||||
if settings_dict['HOST'].startswith('/'):
|
if settings_dict['HOST'].startswith('/'):
|
||||||
kwargs['unix_socket'] = settings_dict['HOST']
|
kwargs['unix_socket'] = settings_dict['HOST']
|
||||||
elif settings_dict['HOST']:
|
elif settings_dict['HOST']:
|
||||||
|
|
|
@ -8,7 +8,10 @@ class DatabaseClient(BaseDatabaseClient):
|
||||||
def settings_to_cmd_args_env(cls, settings_dict, parameters):
|
def settings_to_cmd_args_env(cls, settings_dict, parameters):
|
||||||
args = [cls.executable_name]
|
args = [cls.executable_name]
|
||||||
env = None
|
env = None
|
||||||
db = settings_dict['OPTIONS'].get('db', settings_dict['NAME'])
|
database = settings_dict['OPTIONS'].get(
|
||||||
|
'database',
|
||||||
|
settings_dict['OPTIONS'].get('db', settings_dict['NAME']),
|
||||||
|
)
|
||||||
user = settings_dict['OPTIONS'].get('user', settings_dict['USER'])
|
user = settings_dict['OPTIONS'].get('user', settings_dict['USER'])
|
||||||
password = settings_dict['OPTIONS'].get(
|
password = settings_dict['OPTIONS'].get(
|
||||||
'password',
|
'password',
|
||||||
|
@ -51,7 +54,7 @@ class DatabaseClient(BaseDatabaseClient):
|
||||||
args += ["--ssl-key=%s" % client_key]
|
args += ["--ssl-key=%s" % client_key]
|
||||||
if charset:
|
if charset:
|
||||||
args += ['--default-character-set=%s' % charset]
|
args += ['--default-character-set=%s' % charset]
|
||||||
if db:
|
if database:
|
||||||
args += [db]
|
args += [database]
|
||||||
args.extend(parameters)
|
args.extend(parameters)
|
||||||
return args, env
|
return args, env
|
||||||
|
|
|
@ -9,4 +9,4 @@ Django 3.2.3 fixes several bugs in 3.2.2.
|
||||||
Bugfixes
|
Bugfixes
|
||||||
========
|
========
|
||||||
|
|
||||||
* ...
|
* Prepared for ``mysqlclient`` > 2.0.3 support (:ticket:`32732`).
|
||||||
|
|
|
@ -50,41 +50,49 @@ class MySqlDbshellCommandTestCase(SimpleTestCase):
|
||||||
'optiondbname',
|
'optiondbname',
|
||||||
]
|
]
|
||||||
expected_env = {'MYSQL_PWD': 'optionpassword'}
|
expected_env = {'MYSQL_PWD': 'optionpassword'}
|
||||||
self.assertEqual(
|
for keys in [('database', 'password'), ('db', 'passwd')]:
|
||||||
self.settings_to_cmd_args_env({
|
with self.subTest(keys=keys):
|
||||||
'NAME': 'settingdbname',
|
database, password = keys
|
||||||
'USER': 'settinguser',
|
self.assertEqual(
|
||||||
'PASSWORD': 'settingpassword',
|
self.settings_to_cmd_args_env({
|
||||||
'HOST': 'settinghost',
|
'NAME': 'settingdbname',
|
||||||
'PORT': settings_port,
|
'USER': 'settinguser',
|
||||||
'OPTIONS': {
|
'PASSWORD': 'settingpassword',
|
||||||
'db': 'optiondbname',
|
'HOST': 'settinghost',
|
||||||
'user': 'optionuser',
|
'PORT': settings_port,
|
||||||
'passwd': 'optionpassword',
|
'OPTIONS': {
|
||||||
'host': 'optionhost',
|
database: 'optiondbname',
|
||||||
'port': options_port,
|
'user': 'optionuser',
|
||||||
},
|
password: 'optionpassword',
|
||||||
}),
|
'host': 'optionhost',
|
||||||
(expected_args, expected_env),
|
'port': options_port,
|
||||||
)
|
},
|
||||||
|
}),
|
||||||
|
(expected_args, expected_env),
|
||||||
|
)
|
||||||
|
|
||||||
def test_options_password(self):
|
def test_options_non_deprecated_keys_preferred(self):
|
||||||
expected_args = [
|
expected_args = [
|
||||||
'mysql',
|
'mysql',
|
||||||
'--user=someuser',
|
'--user=someuser',
|
||||||
'--host=somehost',
|
'--host=somehost',
|
||||||
'--port=444',
|
'--port=444',
|
||||||
'somedbname',
|
'optiondbname',
|
||||||
]
|
]
|
||||||
expected_env = {'MYSQL_PWD': 'optionpassword'}
|
expected_env = {'MYSQL_PWD': 'optionpassword'}
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
self.settings_to_cmd_args_env({
|
self.settings_to_cmd_args_env({
|
||||||
'NAME': 'somedbname',
|
'NAME': 'settingdbname',
|
||||||
'USER': 'someuser',
|
'USER': 'someuser',
|
||||||
'PASSWORD': 'settingpassword',
|
'PASSWORD': 'settingpassword',
|
||||||
'HOST': 'somehost',
|
'HOST': 'somehost',
|
||||||
'PORT': 444,
|
'PORT': 444,
|
||||||
'OPTIONS': {'password': 'optionpassword'},
|
'OPTIONS': {
|
||||||
|
'database': 'optiondbname',
|
||||||
|
'db': 'deprecatedoptiondbname',
|
||||||
|
'password': 'optionpassword',
|
||||||
|
'passwd': 'deprecatedoptionpassword',
|
||||||
|
},
|
||||||
}),
|
}),
|
||||||
(expected_args, expected_env),
|
(expected_args, expected_env),
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in New Issue