mirror of
				https://github.com/ansible-collections/community.mysql.git
				synced 2025-10-25 05:24:01 -07:00 
			
		
		
		
	mysql_user: fixed encrypted option for MySQL 8.0 and test coverage (#79)
* mysql_user: fixed encrypted option for MySQL 8.0 and test coverage The purpose of this change was originally to expand test coverage to unblock #76, but an issue was detected with the encrypted parameter on MySQL 8.0 in the process of writing the tests. Additionally, user_password_update_test.yml had been disabled at some point, so I opted to replace it with two new files that will focus on the password and plugin auth paths. * Updated tests to cover a couple of missing branches * Skip tests that rely on sha256_password if pymysql < 0.9 * Cover the case where pymysql isn't installed for plugin tests * Added better plugin auth checking to tests and other minor changes * Fixed version detection to explicitly handle MariaDB * Removed unneeded import from previous change * Remove whitespace that was introduced by change that was removed * Added unit tests for missing coverage
This commit is contained in:
		
					parent
					
						
							
								2de3a57021
							
						
					
				
			
			
				commit
				
					
						06907715d7
					
				
			
		
					 12 changed files with 781 additions and 200 deletions
				
			
		
							
								
								
									
										0
									
								
								tests/unit/plugins/module_utils/__init__.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								tests/unit/plugins/module_utils/__init__.py
									
										
									
									
									
										Normal file
									
								
							
							
								
								
									
										24
									
								
								tests/unit/plugins/module_utils/test_mysql.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								tests/unit/plugins/module_utils/test_mysql.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,24 @@ | |||
| from __future__ import (absolute_import, division, print_function) | ||||
| __metaclass__ = type | ||||
| 
 | ||||
| import pytest | ||||
| 
 | ||||
| from ansible_collections.community.mysql.plugins.module_utils.mysql import get_server_version | ||||
| from ..utils import dummy_cursor_class | ||||
| 
 | ||||
| 
 | ||||
| @pytest.mark.parametrize( | ||||
|     'cursor_return_version,cursor_return_type', | ||||
|     [ | ||||
|         ('5.7.0-mysql', 'dict'), | ||||
|         ('8.0.0-mysql', 'list'), | ||||
|         ('10.5.0-mariadb', 'dict'), | ||||
|         ('10.5.1-mariadb', 'list'), | ||||
|     ] | ||||
| ) | ||||
| def test_get_server_version(cursor_return_version, cursor_return_type): | ||||
|     """ | ||||
|     Test that server versions are handled properly by get_server_version() whether they're returned as a list or dict. | ||||
|     """ | ||||
|     cursor = dummy_cursor_class(cursor_return_version, cursor_return_type) | ||||
|     assert get_server_version(cursor) == cursor_return_version | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue