Рефакторинг этой функции, чтобы уменьшить ее когнитивную сложность с 17 до 15 ... как это сделать? - PullRequest
0 голосов
/ 30 сентября 2019

как уменьшить познавательную сложность с 17? как рефакторинг это? У меня есть метод утилит ниже, и я использую несколько операторов if и получаю проблему когнитивной сложности. Я перебрал некоторые ссылки, но я не могу понять, как я должен изменить свой код, не затрагивая пользователей этого метода

def check_nova_parameter_format(prop, yaml_file):

    formats = {
        "string": {
            "name": re.compile(r"(.+?)_name_\d+$"),
            "flavor": re.compile(r"(.+?)_flavor_name$"),
            "image": re.compile(r"(.+?)_image_name$"),
        },
        "comma_delimited_list": {"name": re.compile(r"(.+?)_names$")},
    }

    with open(yaml_file) as fh:
        yml = yaml.load(fh)

    # skip if resources are not defined
    if "resources" not in yml:
        pytest.skip("No resources specified in the heat template")

    # skip if resources are not defined
    if "parameters" not in yml:
        pytest.skip("No parameters specified in the heat template")

    invalid_parameters = []

    for k, v in yml["resources"].items():
        if not isinstance(v, dict):
            continue
        if v.get("type") != "OS::Nova::Server":
            continue

        prop_val = v.get("properties", {}).get(prop, {})
        prop_param = prop_val.get("get_param", "") if isinstance(prop_val, dict) else ""

        if not prop_param:
            pytest.skip("{} doesn't have property {}".format(k, prop))
        elif isinstance(prop_param, list):
            prop_param = prop_param[0]

        template_param_type = yml.get("parameters", {}).get(prop_param, {}).get("type")

        if not template_param_type:
            pytest.skip("could not determine param type for {}".format(prop_param))

        format_match = formats.get(template_param_type, {}).get(prop)

        if not format_match or not format_match.match(prop_param):
            msg = (
                "Invalid parameter format ({}) on Resource ID ({}) property" " ({})"
            ).format(prop_param, k, prop)
            invalid_parameters.append(msg)

...