mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
[PR #8005/e0dbe9c9 backport][stable-8] modprobe: Avoid FileNotFoundError when directories don't exist. (#8028)
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
153456f6aa
commit
d9e72cf75e
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…
Reference in a new issue