From 7f1e26167affd88739d8ff0810f0a9fa4f239e4e Mon Sep 17 00:00:00 2001 From: Abhijeet Kasurde <akasurde@redhat.com> Date: Thu, 15 Oct 2020 19:03:06 +0530 Subject: [PATCH] iso_create: Error handling while importing Pycdlib (#1090) --- plugins/modules/files/iso_create.py | 41 +++++++++++++++++++++-------- 1 file changed, 30 insertions(+), 11 deletions(-) diff --git a/plugins/modules/files/iso_create.py b/plugins/modules/files/iso_create.py index 6f8e046804..bf6359b14a 100644 --- a/plugins/modules/files/iso_create.py +++ b/plugins/modules/files/iso_create.py @@ -8,7 +8,7 @@ from __future__ import absolute_import, division, print_function __metaclass__ = type -DOCUMENTATION = ''' +DOCUMENTATION = r''' --- module: iso_create short_description: Generate ISO file with specified files or folders @@ -16,7 +16,9 @@ description: - This module is used to generate ISO file with specified path of files. author: - Diane Wang (@Tomorrow9) <dianew@vmware.com> -requirements: ["pycdlib", "python >= 2.7"] +requirements: +- "pycdlib" +- "python >= 2.7" version_added: '0.2.0' options: @@ -52,20 +54,22 @@ options: rock_ridge: description: - Whether to make this ISO have the Rock Ridge extensions or not. - - 'Valid values are C(1.09), C(1.10) or C(1.12), means adding the specified Rock Ridge version to the ISO. If - unsure, set C(1.09) to ensure maximum compatibility.' + - Valid values are C(1.09), C(1.10) or C(1.12), means adding the specified Rock Ridge version to the ISO. + - If unsure, set C(1.09) to ensure maximum compatibility. - If not specified, then not add Rock Ridge extension to the ISO. type: str choices: ['1.09', '1.10', '1.12'] joliet: description: - - Support levels and valid values are C(1), C(2), or C(3). Level C(3) is by far the most common. + - Support levels and valid values are C(1), C(2), or C(3). + - Level C(3) is by far the most common. - If not specified, then no Joliet support is added. type: int choices: [1, 2, 3] udf: description: - - Whether to add UDF support to this ISO. If set to C(True), then version 2.60 of the UDF spec is used. + - Whether to add UDF support to this ISO. + - If set to C(True), then version 2.60 of the UDF spec is used. - If not specified or set to C(False), then no UDF support is added. type: bool default: False @@ -87,6 +91,15 @@ EXAMPLES = r''' - /root/testfolder dest_iso: /tmp/test.iso rock_ridge: 1.09 + +- name: Create an ISO file with Joliet support + community.general.iso_create: + src_files: + - ./windows_config/Autounattend.xml + dest_iso: ./test.iso + interchange_level: 3 + joliet: 3 + vol_ident: WIN_AUTOINSTALL ''' RETURN = r''' @@ -129,14 +142,17 @@ udf: ''' import os -HAS_PYCDLIB = False +import traceback + +PYCDLIB_IMP_ERR = None try: import pycdlib HAS_PYCDLIB = True except ImportError: - pass + PYCDLIB_IMP_ERR = traceback.format_exc() + HAS_PYCDLIB = False -from ansible.module_utils.basic import AnsibleModule +from ansible.module_utils.basic import AnsibleModule, missing_required_lib from ansible.module_utils._text import to_native @@ -160,7 +176,7 @@ def add_file(module, iso_file=None, src_file=None, file_path=None, rock_ridge=No try: iso_file.add_file(src_file, iso_path=file_in_iso_path, rr_name=rr_name, joliet_path=joliet_path, udf_path=udf_path) except Exception as err: - module.fail_json(msg="Add file %s to ISO file failed due to %s" % (src_file, to_native(err))) + module.fail_json(msg="Failed to add file %s to ISO file due to %s" % (src_file, to_native(err))) def add_directory(module, iso_file=None, dir_path=None, rock_ridge=None, use_joliet=None, use_udf=None): @@ -177,7 +193,7 @@ def add_directory(module, iso_file=None, dir_path=None, rock_ridge=None, use_jol try: iso_file.add_directory(iso_path=iso_dir_path, rr_name=rr_name, joliet_path=joliet_path, udf_path=udf_path) except Exception as err: - module.fail_json(msg="Add directory %s to ISO file failed due to %s" % (dir_path, to_native(err))) + module.fail_json(msg="Failed to directory %s to ISO file due to %s" % (dir_path, to_native(err))) def main(): @@ -194,6 +210,9 @@ def main(): argument_spec=argument_spec, supports_check_mode=True, ) + if not HAS_PYCDLIB: + module.fail_json(missing_required_lib('pycdlib'), exception=PYCDLIB_IMP_ERR) + src_file_list = module.params.get('src_files') if src_file_list and len(src_file_list) == 0: module.fail_json(msg='Please specify source file and/or directory list using src_files parameter.')