mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	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:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						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), | ||||||
|         ) |         ) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user