mirror of
				https://github.com/ansible-collections/community.mysql.git
				synced 2025-10-25 13:34:03 -07:00 
			
		
		
		
	mysql_info: Add support for source terminology for slave_status filter (#747)
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Plugins CI / Sanity (Ⓐdevel) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Sanity (Ⓐstable-2.17) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Sanity (Ⓐstable-2.18) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Sanity (Ⓐstable-2.19) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐdevel, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐdevel, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐdevel, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐdevel, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐdevel, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐdevel, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.16, DB: mariadb 10.11.8, connector: pymysql 0.10.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.17, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.17, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.17, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.17, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.17, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.17, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 10.11.8, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.0.38, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 10.11.8, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.0.38, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 10.11.8, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.0.38, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 10.11.8, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.0.38, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 10.11.8, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.0.38, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 10.11.8, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.0.38, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐdevel, Python3.10) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐdevel, Python3.11) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐstable-2.18, Python3.10) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐstable-2.18, Python3.11) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐstable-2.18, Python3.8) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐstable-2.18, Python3.9) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐstable-2.19, Python3.10) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐstable-2.19, Python3.11) (push) Has been cancelled
				
			
		
			
				
	
				Plugins CI / Units (Ⓐstable-2.19, Python3.9) (push) Has been cancelled
				
			
		
		
	
	
		
	
		
			Some checks failed
		
		
	
	Plugins CI / Sanity (Ⓐdevel) (push) Has been cancelled
				
			Plugins CI / Sanity (Ⓐstable-2.17) (push) Has been cancelled
				
			Plugins CI / Sanity (Ⓐstable-2.18) (push) Has been cancelled
				
			Plugins CI / Sanity (Ⓐstable-2.19) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐdevel, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐdevel, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐdevel, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐdevel, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐdevel, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐdevel, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.16, DB: mariadb 10.11.8, connector: pymysql 0.10.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.17, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.17, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.17, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.17, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.17, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.17, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 10.11.8, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.0.38, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 10.11.8, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.0.38, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 10.11.8, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.0.38, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.18, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 10.11.8, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 11.4.5, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.0.38, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.4.1, connector: pymysql 0.9.3) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 10.11.8, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 11.4.5, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.0.38, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.4.1, connector: pymysql 1.0.2) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 10.11.8, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mariadb 11.4.5, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.0.38, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Integration (Ⓐstable-2.19, DB: mysql 8.4.1, connector: pymysql 1.1.1) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐdevel, Python3.10) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐdevel, Python3.11) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐstable-2.18, Python3.10) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐstable-2.18, Python3.11) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐstable-2.18, Python3.8) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐstable-2.18, Python3.9) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐstable-2.19, Python3.10) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐstable-2.19, Python3.11) (push) Has been cancelled
				
			Plugins CI / Units (Ⓐstable-2.19, Python3.9) (push) Has been cancelled
				
			* mysql_info: Add support for source terminology for slave_status filter * Update changelogs/fragments/mysql_info_fix_slave_status_for_source_terminology.yaml --------- Co-authored-by: Luca Keidel <luca.keidel@check24.de> Co-authored-by: Laurent Indermühle <laurent.indermuehle@pm.me>
This commit is contained in:
		
					parent
					
						
							
								f6cec49238
							
						
					
				
			
			
				commit
				
					
						fad6bc7564
					
				
			
		
					 5 changed files with 37 additions and 4 deletions
				
			
		|  | @ -0,0 +1,2 @@ | |||
| bugfixes: | ||||
|   - mysql_info - Fix slave status for source terminology introduced in MySQL 8.0.23 (https://github.com/ansible-collections/community.mysql/issues/682). | ||||
|  | @ -531,20 +531,20 @@ class MySQL_Info(object): | |||
|         res = self.__exec_sql(query) | ||||
|         if res: | ||||
|             for line in res: | ||||
|                 host = line['Master_Host'] | ||||
|                 host = line.get('Master_Host') or line.get('Source_Host') | ||||
|                 if host not in self.info['slave_status']: | ||||
|                     self.info['slave_status'][host] = {} | ||||
| 
 | ||||
|                 port = line['Master_Port'] | ||||
|                 port = line.get('Master_Port') or line.get('Source_Port') | ||||
|                 if port not in self.info['slave_status'][host]: | ||||
|                     self.info['slave_status'][host][port] = {} | ||||
| 
 | ||||
|                 user = line['Master_User'] | ||||
|                 user = line.get('Master_User') or line.get('Source_User') | ||||
|                 if user not in self.info['slave_status'][host][port]: | ||||
|                     self.info['slave_status'][host][port][user] = {} | ||||
| 
 | ||||
|                 for vname, val in line.items(): | ||||
|                     if vname not in ('Master_Host', 'Master_Port', 'Master_User'): | ||||
|                     if vname not in ('Master_Host', 'Master_Port', 'Master_User', 'Source_Host', 'Source_Port', 'Source_User'): | ||||
|                         self.info['slave_status'][host][port][user][vname] = self.__convert(val) | ||||
| 
 | ||||
|     def __get_slaves(self): | ||||
|  |  | |||
|  | @ -4,6 +4,7 @@ mysql_user: root | |||
| mysql_password: msandbox | ||||
| mysql_host: '{{ gateway_addr }}' | ||||
| mysql_primary_port: 3307 | ||||
| mysql_replica1_port: 3308 | ||||
| 
 | ||||
| db_name: data | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,28 @@ | |||
| --- | ||||
| 
 | ||||
| - vars: | ||||
|     mysql_parameters: &mysql_params | ||||
|       login_user: '{{ mysql_user }}' | ||||
|       login_password: '{{ mysql_password }}' | ||||
|       login_host: '{{ mysql_host }}' | ||||
|       login_port: '{{ mysql_replica1_port }}' | ||||
| 
 | ||||
|   block: | ||||
| 
 | ||||
|     - name: Skip non-affected versions | ||||
|       meta: end_play | ||||
|       when: | ||||
|         - db_engine != 'mysql' or db_version is version('8.0.23', '<') | ||||
| 
 | ||||
|     - name: Test mysql_info with slave_status filter on replica database | ||||
|       mysql_info: | ||||
|         <<: *mysql_params | ||||
|         filter: slave_status | ||||
|       register: slave_status_result | ||||
|       ignore_errors: yes | ||||
| 
 | ||||
|     - name: Assert that mysql_info with slave_status returns data | ||||
|       assert: | ||||
|         that: | ||||
|           - slave_status_result is not failed | ||||
|         fail_msg: "mysql_info with slave_status filter crashed: {{ slave_status_result.msg | default('Unknown error') }}" | ||||
|  | @ -141,3 +141,5 @@ | |||
|     - name: Import tasks file to tests users_info filter | ||||
|       ansible.builtin.import_tasks: | ||||
|         file: filter_users_info.yml | ||||
| 
 | ||||
|     - include_tasks: issue-682.yml | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue