mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2024-09-14 20:13:21 +02:00 
			
		
		
		
	fix order of dnf api operations so transactions don't fail (#50038)
* fix order of dnf api operations so transactions don't fail Previously dnf.base.fill_sack() was called before dnf.base.update_cache() which apparently breaks dnf transaction logic as per https://bugzilla.redhat.com/show_bug.cgi?id=1658694 Fixes #49060 Signed-off-by: Adam Miller <admiller@redhat.com> * add changelog and test case Signed-off-by: Adam Miller <admiller@redhat.com>
This commit is contained in:
		
							parent
							
								
									4c473ecef4
								
							
						
					
					
						commit
						ca084889c7
					
				
					 3 changed files with 13 additions and 9 deletions
				
			
		|  | @ -0,0 +1,3 @@ | |||
| --- | ||||
| bugfixes: | ||||
|   - "dnf - fix update_cache combined with install operation to not cause dnf transaction failure" | ||||
|  | @ -588,6 +588,15 @@ class DnfModule(YumDnf): | |||
|         except AttributeError: | ||||
|             pass  # older versions of dnf didn't require this and don't have these methods | ||||
|         try: | ||||
|             if self.update_cache: | ||||
|                 try: | ||||
|                     base.update_cache() | ||||
|                 except dnf.exceptions.RepoError as e: | ||||
|                     self.module.fail_json( | ||||
|                         msg="{0}".format(to_text(e)), | ||||
|                         results=[], | ||||
|                         rc=1 | ||||
|                     ) | ||||
|             base.fill_sack(load_system_repo='auto') | ||||
|         except dnf.exceptions.RepoError as e: | ||||
|             self.module.fail_json( | ||||
|  | @ -601,15 +610,6 @@ class DnfModule(YumDnf): | |||
|         if self.security: | ||||
|             key = {'advisory_type__eq': 'security'} | ||||
|             base._update_security_filters = [base.sack.query().filter(**key)] | ||||
|         if self.update_cache: | ||||
|             try: | ||||
|                 base.update_cache() | ||||
|             except dnf.exceptions.RepoError as e: | ||||
|                 self.module.fail_json( | ||||
|                     msg="{0}".format(to_text(e)), | ||||
|                     results=[], | ||||
|                     rc=1 | ||||
|                 ) | ||||
| 
 | ||||
|         return base | ||||
| 
 | ||||
|  |  | |||
|  | @ -50,6 +50,7 @@ | |||
|   dnf: | ||||
|     name: sos | ||||
|     state: present | ||||
|     update_cache: True | ||||
|   register: dnf_result | ||||
| 
 | ||||
| - name: check sos with rpm | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue