mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	[PR #8005/e0dbe9c9 backport][stable-7] modprobe: Avoid FileNotFoundError when directories don't exist. (#8027)
modprobe: Avoid FileNotFoundError when directories don't exist. (#8005)
* Avoid FileNotFoundError when directories don't exist.
* Adds changelog fragment.
* Update changelogs/fragments/7717-prevent-modprobe-error.yml
Co-authored-by: Felix Fontein <felix@fontein.de>
---------
Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit e0dbe9c98d)
Co-authored-by: Nate Douglas <ndouglas@users.noreply.github.com>
	
	
This commit is contained in:
		
					parent
					
						
							
								3fd8c520c6
							
						
					
				
			
			
				commit
				
					
						faa3b7349f
					
				
			
		
					 2 changed files with 6 additions and 0 deletions
				
			
		
							
								
								
									
										2
									
								
								changelogs/fragments/7717-prevent-modprobe-error.yml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								changelogs/fragments/7717-prevent-modprobe-error.yml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | ||||||
|  | bugfixes: | ||||||
|  |   - modprobe - listing modules files or modprobe files could trigger a FileNotFoundError if ``/etc/modprobe.d`` or ``/etc/modules-load.d`` did not exist. Relevant functions now return empty lists if the directories do not exist to avoid crashing the module (https://github.com/ansible-collections/community.general/issues/7717). | ||||||
|  | @ -232,12 +232,16 @@ class Modprobe(object): | ||||||
| 
 | 
 | ||||||
|     @property |     @property | ||||||
|     def modules_files(self): |     def modules_files(self): | ||||||
|  |         if not os.path.isdir(MODULES_LOAD_LOCATION): | ||||||
|  |             return [] | ||||||
|         modules_paths = [os.path.join(MODULES_LOAD_LOCATION, path) |         modules_paths = [os.path.join(MODULES_LOAD_LOCATION, path) | ||||||
|                          for path in os.listdir(MODULES_LOAD_LOCATION)] |                          for path in os.listdir(MODULES_LOAD_LOCATION)] | ||||||
|         return [path for path in modules_paths if os.path.isfile(path)] |         return [path for path in modules_paths if os.path.isfile(path)] | ||||||
| 
 | 
 | ||||||
|     @property |     @property | ||||||
|     def modprobe_files(self): |     def modprobe_files(self): | ||||||
|  |         if not os.path.isdir(PARAMETERS_FILES_LOCATION): | ||||||
|  |             return [] | ||||||
|         modules_paths = [os.path.join(PARAMETERS_FILES_LOCATION, path) |         modules_paths = [os.path.join(PARAMETERS_FILES_LOCATION, path) | ||||||
|                          for path in os.listdir(PARAMETERS_FILES_LOCATION)] |                          for path in os.listdir(PARAMETERS_FILES_LOCATION)] | ||||||
|         return [path for path in modules_paths if os.path.isfile(path)] |         return [path for path in modules_paths if os.path.isfile(path)] | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue