當前位置: 首頁>>代碼示例>>Python>>正文


Python hcl.load方法代碼示例

本文整理匯總了Python中hcl.load方法的典型用法代碼示例。如果您正苦於以下問題:Python hcl.load方法的具體用法?Python hcl.load怎麽用?Python hcl.load使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在hcl的用法示例。


在下文中一共展示了hcl.load方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __init__

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def __init__(self) -> None:
        """Parse the terraform.tfvars config file and make sure it contains every variable.

        Raises:
            InvalidConfigError: If any variable is defined in variables.tf but not terraform.tfvars.
        """
        with open(CONFIG_FILE) as f:
            self._config = hcl.load(f)  # Dict[str, Union[int, str]]

        with open(VARIABLES_FILE) as f:
            variable_names = hcl.load(f)['variable'].keys()

        for variable in variable_names:
            # Verify that the variable is defined.
            if variable not in self._config:
                raise InvalidConfigError(
                    'variable "{}" is not defined in {}'.format(variable, CONFIG_FILE)
                ) 
開發者ID:airbnb,項目名稱:binaryalert,代碼行數:20,代碼來源:config.py

示例2: get_url_content

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def get_url_content(url):
    """
    Return URL content

    Args:
        url (str): URL address to return
    Returns:
        str: Content of URL

    Raises:
        AssertionError: When couldn't load URL

    """
    log.debug(f"Download '{url}' content.")
    r = requests.get(url)
    assert r.ok, f"Couldn't load URL: {url} content! Status: {r.status_code}."
    return r.content 
開發者ID:red-hat-storage,項目名稱:ocs-ci,代碼行數:19,代碼來源:utils.py

示例3: remove_keys_from_tf_variable_file

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def remove_keys_from_tf_variable_file(tf_file, keys):
    """
    Removes the keys from the tf files and convert to json format

    Args:
        tf_file (str): path to tf file
        keys (list): list of keys to remove

    """
    # importing here to avoid dependencies
    from ocs_ci.utility.templating import dump_data_to_json
    with open(tf_file, 'r') as fd:
        obj = hcl.load(fd)
    for key in keys:
        obj['variable'].pop(key)

    dump_data_to_json(obj, f"{tf_file}.json")
    os.rename(tf_file, f"{tf_file}.backup") 
開發者ID:red-hat-storage,項目名稱:ocs-ci,代碼行數:20,代碼來源:utils.py

示例4: get_module_ip

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def get_module_ip(terraform_state_file, module):
    """
    Gets the bootstrap node IP from terraform.tfstate file

    Args:
        terraform_state_file (str): Path to terraform state file
        module (str): Module name in terraform.tfstate file
            e.g: constants.LOAD_BALANCER_MODULE

    Returns:
        str: IP of bootstrap node

    """
    with open(terraform_state_file) as fd:
        obj = hcl.load(fd)

        resources = obj['resources']
        log.debug(f"Extracting module information for {module}")
        log.debug(f"Resource in {terraform_state_file}: {resources}")
        for resource in resources:
            if resource['module'] == module:
                resource_body = resource['instances'][0]['attributes']['body']
                return resource_body.split("\"")[3] 
開發者ID:red-hat-storage,項目名稱:ocs-ci,代碼行數:25,代碼來源:utils.py

示例5: test_decoder

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def test_decoder(hcl_fname, json_fname, struct):

    with open(join(FIXTURE_DIR, hcl_fname), 'r') as fp:
        hcl_json = hcl.load(fp)

    assert json_fname is not None or struct is not None

    if json_fname is not None:
        with open(join(FIXTURE_DIR, json_fname), 'r') as fp:
            good_json = json.load(fp)

        assert hcl_json == good_json

    if struct is not None:
        assert hcl_json == struct 
開發者ID:virtuald,項目名稱:pyhcl,代碼行數:17,代碼來源:test_decoder.py

示例6: test_decoder_export_comments

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def test_decoder_export_comments(hcl_fname, sline_fname, mline_fname, aline_fname, export_comments):
    with open(join(FIXTURE_DIR, hcl_fname), 'r') as fp:
        hcl_json = hcl.load(fp, export_comments)

    json_fname = {
        "LINE": sline_fname,
        "MULTILINE": mline_fname,
        "ALL": aline_fname
    }

    with open(join(FIXTURE_DIR, json_fname[export_comments]), 'r') as fp:
            good_json = json.load(fp)

    assert hcl_json == good_json 
開發者ID:virtuald,項目名稱:pyhcl,代碼行數:16,代碼來源:test_decoder.py

示例7: _load

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def _load(path):
    try:
        with open(path) as settings_file:
            return hcl.load(settings_file)
    except IOError as error:
        errors.string_exit('Error reading settings: {}'.format(error))
    except Exception as error:
        errors.string_exit('Error parsing settings: {}'.format(error)) 
開發者ID:claranet,項目名稱:ssha,代碼行數:10,代碼來源:settings.py

示例8: load

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def load(**defaults):
    if defaults.get('verbose'):
        print('[ssha] finding settings file')
    update(defaults)

    settings_path = defaults.get('settings_path')
    path = _find_settings_path(settings_path)

    if defaults.get('verbose'):
        print('[ssha] loading {}'.format(path))
    data = _load(path)
    _validate_version(data)
    update(data) 
開發者ID:claranet,項目名稱:ssha,代碼行數:15,代碼來源:settings.py

示例9: find_min_required

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def find_min_required(path):
    """Inspect terraform files and find minimum version."""
    found_min_required = ''
    for filename in glob.glob(os.path.join(path, '*.tf')):
        with open(filename, 'r') as stream:
            tf_config = hcl.load(stream)
            if tf_config.get('terraform', {}).get('required_version'):
                found_min_required = tf_config.get('terraform',
                                                   {}).get('required_version')
                break

    if found_min_required:
        if re.match(r'^!=.+', found_min_required):
            LOGGER.error('Min required Terraform version is a negation (%s) '
                         '- unable to determine required version',
                         found_min_required)
            sys.exit(1)
        else:
            found_min_required = re.search(r'[0-9]*\.[0-9]*(?:\.[0-9]*)?',
                                           found_min_required).group(0)
            LOGGER.debug("Detected minimum terraform version is %s",
                         found_min_required)
            return found_min_required
    LOGGER.error('Terraform version specified as min-required, but unable to '
                 'find a specified version requirement in this module\'s tf '
                 'files')
    sys.exit(1) 
開發者ID:onicagroup,項目名稱:runway,代碼行數:29,代碼來源:tfenv.py

示例10: change_mem_and_cpu

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def change_mem_and_cpu():
    """
    Increase CPUs and memory for nodes
    """
    worker_num_cpus = config.ENV_DATA.get('worker_num_cpus')
    master_num_cpus = config.ENV_DATA.get('master_num_cpus')
    worker_memory = config.ENV_DATA.get('compute_memory')
    master_memory = config.ENV_DATA.get('master_memory')
    if (
            worker_num_cpus
            or master_num_cpus
            or master_memory
            or worker_memory
    ):
        with open(constants.VSPHERE_MAIN, 'r') as fd:
            obj = hcl.load(fd)
            if worker_num_cpus:
                obj['module']['compute']['num_cpu'] = worker_num_cpus
            if master_num_cpus:
                obj['module']['control_plane']['num_cpu'] = master_num_cpus
            if worker_memory:
                obj['module']['compute']['memory'] = worker_memory
            if master_memory:
                obj['module']['control_plane']['memory'] = master_memory
        # Dump data to json file since hcl module
        # doesn't support dumping of data in HCL format
        dump_data_to_json(obj, f"{constants.VSPHERE_MAIN}.json")
        os.rename(constants.VSPHERE_MAIN, f"{constants.VSPHERE_MAIN}.backup") 
開發者ID:red-hat-storage,項目名稱:ocs-ci,代碼行數:30,代碼來源:vmware.py

示例11: get_infra_id

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def get_infra_id(cluster_path):
    """
    Get infraID from metadata.json in given cluster_path

    Args:
        cluster_path: path to cluster install directory

    Returns:
        str: metadata.json['infraID']

    """
    metadata_file = os.path.join(cluster_path, "metadata.json")
    with open(metadata_file) as f:
        metadata = json.load(f)
    return metadata["infraID"] 
開發者ID:red-hat-storage,項目名稱:ocs-ci,代碼行數:17,代碼來源:utils.py

示例12: generate_terraform_vars_with_out_folder

# 需要導入模塊: import hcl [as 別名]
# 或者: from hcl import load [as 別名]
def generate_terraform_vars_with_out_folder():
    """
    Generates the normal ( old structure ) terraform.tfvars file
    """
    logger.info("Generating terraform variables without folder structure")

    # upload bootstrap ignition to public access server
    bootstrap_path = os.path.join(
        config.ENV_DATA.get('cluster_path'),
        constants.BOOTSTRAP_IGN
    )
    remote_path = os.path.join(
        config.ENV_DATA.get('path_to_upload'),
        f"{config.RUN.get('run_id')}_{constants.BOOTSTRAP_IGN}"
    )
    upload_file(
        config.ENV_DATA.get('httpd_server'),
        bootstrap_path,
        remote_path,
        config.ENV_DATA.get('httpd_server_user'),
        config.ENV_DATA.get('httpd_server_password')
    )

    # generate bootstrap ignition url
    path_to_bootstrap_on_remote = remote_path.replace("/var/www/html/", "")
    bootstrap_ignition_url = (
        f"http://{config.ENV_DATA.get('httpd_server')}/"
        f"{path_to_bootstrap_on_remote}"
    )
    logger.info(f"bootstrap_ignition_url: {bootstrap_ignition_url}")
    config.ENV_DATA['bootstrap_ignition_url'] = bootstrap_ignition_url

    # load master and worker ignitions to variables
    master_ignition_path = os.path.join(
        config.ENV_DATA.get('cluster_path'),
        constants.MASTER_IGN
    )
    master_ignition = read_file_as_str(f"{master_ignition_path}")
    config.ENV_DATA['control_plane_ignition'] = master_ignition

    worker_ignition_path = os.path.join(
        config.ENV_DATA.get('cluster_path'),
        constants.WORKER_IGN
    )
    worker_ignition = read_file_as_str(f"{worker_ignition_path}")
    config.ENV_DATA['compute_ignition'] = worker_ignition

    cluster_domain = (
        f"{config.ENV_DATA.get('cluster_name')}."
        f"{config.ENV_DATA.get('base_domain')}"
    )
    config.ENV_DATA['cluster_domain'] = cluster_domain

    # generate terraform variables from template
    create_terraform_var_file("terraform.tfvars.j2") 
開發者ID:red-hat-storage,項目名稱:ocs-ci,代碼行數:57,代碼來源:vmware.py


注:本文中的hcl.load方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。