mirror of
				https://github.com/ansible-collections/community.mysql.git
				synced 2025-10-26 05:50:39 -07:00 
			
		
		
		
	Fix the collection to work with mysqlclient connector (#293)
* Integration tests: restrict exclusion mysqlclient + MariaDB only when testing the mysql_role module * Fix * Fix underlying issue * Fix units * Add changelog fragment
This commit is contained in:
		
					parent
					
						
							
								71a628f82d
							
						
					
				
			
			
				commit
				
					
						f00f06df76
					
				
			
		
					 5 changed files with 11 additions and 9 deletions
				
			
		
							
								
								
									
										4
									
								
								.github/workflows/ansible-test-plugins.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/ansible-test-plugins.yml
									
										
									
									
										vendored
									
									
								
							|  | @ -78,10 +78,6 @@ jobs: | ||||||
|             connector: pymysql==0.7.10 |             connector: pymysql==0.7.10 | ||||||
|           - db_engine_version: mariadb_10.5.9 |           - db_engine_version: mariadb_10.5.9 | ||||||
|             connector: pymysql==0.7.10 |             connector: pymysql==0.7.10 | ||||||
|           - db_engine_version: mariadb_10.3.34 |  | ||||||
|             connector: mysqlclient==2.0.1 |  | ||||||
|           - db_engine_version: mariadb_10.5.9 |  | ||||||
|             connector: mysqlclient==2.0.1 |  | ||||||
|           - python: 3.8 |           - python: 3.8 | ||||||
|             ansible: stable-2.9 |             ansible: stable-2.9 | ||||||
|           - python: 3.8 |           - python: 3.8 | ||||||
|  |  | ||||||
							
								
								
									
										2
									
								
								changelogs/fragments/0-mysqlclient.yml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								changelogs/fragments/0-mysqlclient.yml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | ||||||
|  | bugfixes: | ||||||
|  | - Collection core functions - fixes related to the mysqlclient Python connector (https://github.com/ansible-collections/community.mysql/issues/292). | ||||||
|  | @ -398,7 +398,7 @@ def privileges_get(cursor, user, host, maria_role=False): | ||||||
|     if not maria_role: |     if not maria_role: | ||||||
|         cursor.execute("SHOW GRANTS FOR %s@%s", (user, host)) |         cursor.execute("SHOW GRANTS FOR %s@%s", (user, host)) | ||||||
|     else: |     else: | ||||||
|         cursor.execute("SHOW GRANTS FOR %s", (user)) |         cursor.execute("SHOW GRANTS FOR %s", (user,)) | ||||||
|     grants = cursor.fetchall() |     grants = cursor.fetchall() | ||||||
| 
 | 
 | ||||||
|     def pick(x): |     def pick(x): | ||||||
|  | @ -618,7 +618,7 @@ def privileges_revoke(cursor, user, host, db_table, priv, grant_option, maria_ro | ||||||
|         params = (user, host) |         params = (user, host) | ||||||
|     else: |     else: | ||||||
|         query.append("FROM %s") |         query.append("FROM %s") | ||||||
|         params = (user) |         params = (user,) | ||||||
| 
 | 
 | ||||||
|     query = ' '.join(query) |     query = ' '.join(query) | ||||||
|     cursor.execute(query, params) |     cursor.execute(query, params) | ||||||
|  | @ -644,6 +644,10 @@ def privileges_grant(cursor, user, host, db_table, priv, tls_requires, maria_rol | ||||||
|     if 'GRANT' in priv: |     if 'GRANT' in priv: | ||||||
|         query.append("WITH GRANT OPTION") |         query.append("WITH GRANT OPTION") | ||||||
|     query = ' '.join(query) |     query = ' '.join(query) | ||||||
|  | 
 | ||||||
|  |     if isinstance(params, str): | ||||||
|  |         params = (params,) | ||||||
|  | 
 | ||||||
|     try: |     try: | ||||||
|         cursor.execute(query, params) |         cursor.execute(query, params) | ||||||
|     except (mysql_driver.ProgrammingError, mysql_driver.OperationalError, mysql_driver.InternalError) as e: |     except (mysql_driver.ProgrammingError, mysql_driver.OperationalError, mysql_driver.InternalError) as e: | ||||||
|  |  | ||||||
|  | @ -481,7 +481,7 @@ class MariaDBQueryBuilder(): | ||||||
|         Returns: |         Returns: | ||||||
|             tuple: (query_string, tuple_containing_parameters). |             tuple: (query_string, tuple_containing_parameters). | ||||||
|         """ |         """ | ||||||
|         return "SELECT count(*) FROM mysql.user WHERE user = %s AND is_role  = 'Y'", (self.name) |         return "SELECT count(*) FROM mysql.user WHERE user = %s AND is_role  = 'Y'", (self.name,) | ||||||
| 
 | 
 | ||||||
|     def role_grant(self, user): |     def role_grant(self, user): | ||||||
|         """Return a query to grant a role to a user or role. |         """Return a query to grant a role to a user or role. | ||||||
|  |  | ||||||
|  | @ -28,9 +28,9 @@ module = Module() | ||||||
| @pytest.mark.parametrize( | @pytest.mark.parametrize( | ||||||
|     'builder,output', |     'builder,output', | ||||||
|     [ |     [ | ||||||
|         (MariaDBQueryBuilder('role0'), ("SELECT count(*) FROM mysql.user WHERE user = %s AND is_role  = 'Y'", ('role0'))), |         (MariaDBQueryBuilder('role0'), ("SELECT count(*) FROM mysql.user WHERE user = %s AND is_role  = 'Y'", ('role0',))), | ||||||
|         (MySQLQueryBuilder('role0', '%'), ('SELECT count(*) FROM mysql.user WHERE user = %s AND host = %s', ('role0', '%'))), |         (MySQLQueryBuilder('role0', '%'), ('SELECT count(*) FROM mysql.user WHERE user = %s AND host = %s', ('role0', '%'))), | ||||||
|         (MariaDBQueryBuilder('role1'), ("SELECT count(*) FROM mysql.user WHERE user = %s AND is_role  = 'Y'", ('role1'))), |         (MariaDBQueryBuilder('role1'), ("SELECT count(*) FROM mysql.user WHERE user = %s AND is_role  = 'Y'", ('role1',))), | ||||||
|         (MySQLQueryBuilder('role1', 'fake'), ('SELECT count(*) FROM mysql.user WHERE user = %s AND host = %s', ('role1', 'fake'))), |         (MySQLQueryBuilder('role1', 'fake'), ('SELECT count(*) FROM mysql.user WHERE user = %s AND host = %s', ('role1', 'fake'))), | ||||||
|     ] |     ] | ||||||
| ) | ) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue