Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 1 | import pytest |
| 2 | import json |
| 3 | import utils |
Hanna Arhipova | 1eef831 | 2019-05-06 20:14:18 +0300 | [diff] [blame] | 4 | import logging |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 5 | |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 6 | def is_deb_in_exception(inconsistency_rule, package_name, error_node_list): |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 7 | short_names_in_error_nodes = [n.split('.')[0] for n in error_node_list] |
| 8 | for node, excluded_packages in inconsistency_rule.iteritems(): |
| 9 | if package_name in excluded_packages and node in short_names_in_error_nodes: |
| 10 | return True |
| 11 | return False |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 12 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 13 | @pytest.mark.full |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 14 | def test_check_package_versions(local_salt_client, nodes_in_group): |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 15 | """Validate package has same versions on all the nodes. |
| 16 | Steps: |
| 17 | 1) Collect packages for nodes_in_group |
| 18 | "salt -C '<group_of_nodes>' cmd.run 'lowpkg.list_pkgs'" |
| 19 | 2) Exclude nodes without packages and exceptions |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 20 | 3) Go through each package and save it with version from each node to the |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 21 | list. Mark 'No version' if package is not found. |
| 22 | If pachage name in the eception list or in inconsistency_rule, ignore it. |
| 23 | 4) Compare items in that list - they should be equal and match the amout of nodes |
| 24 | |
| 25 | """ |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 26 | # defines packages specific to the concrete nodes |
| 27 | inconsistency_rule = {"kvm03": ["rsync", "sysstat", "xz-utils"], "log01": ["python-elasticsearch"], "ctl01": ["python-gnocchiclient", "python-ujson"]} |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 28 | exclude_packages = utils.get_configuration().get("skipped_packages", []) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 29 | group, nodes = nodes_in_group |
| 30 | packages_versions = local_salt_client.cmd(tgt="L@"+','.join(nodes), |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 31 | fun='lowpkg.list_pkgs', |
| 32 | expr_form='compound') |
| 33 | # Let's exclude cid01 and dbs01 nodes from this check |
| 34 | exclude_nodes = local_salt_client.test_ping(tgt="I@galera:master or I@gerrit:client", |
| 35 | expr_form='compound').keys() |
Oleksii Zhurba | a3e79ce | 2019-06-04 17:26:51 -0500 | [diff] [blame] | 36 | # PROD-30833 |
| 37 | gtw01 = local_salt_client.pillar_get( |
| 38 | param='_param:openstack_gateway_node01_hostname') or 'gtw01' |
| 39 | cluster_domain = local_salt_client.pillar_get( |
| 40 | param='_param:cluster_domain') or '.local' |
| 41 | gtw01 += '.' + cluster_domain |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 42 | if gtw01 in nodes: |
| 43 | octavia = local_salt_client.cmd(tgt="L@" + ','.join(nodes), |
Oleksii Zhurba | 29baebd | 2019-06-12 16:11:40 -0500 | [diff] [blame] | 44 | fun='pillar.get', |
| 45 | param='octavia:manager:enabled', |
| 46 | expr_form='compound') |
| 47 | gtws = [gtw for gtw in octavia.values() if gtw] |
| 48 | if len(gtws) == 1: |
Oleksii Zhurba | a3e79ce | 2019-06-04 17:26:51 -0500 | [diff] [blame] | 49 | exclude_nodes.append(gtw01) |
| 50 | logging.info("gtw01 node is skipped in test_check_package_versions") |
| 51 | |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 52 | total_nodes = [i for i in nodes if i not in exclude_nodes] |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 53 | if len(total_nodes) < 2: |
| 54 | pytest.skip("Nothing to compare - only 1 node") |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 55 | nodes_with_packages = [] |
| 56 | packages_with_different_versions = [] |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 57 | packages_names = set() |
| 58 | |
| 59 | for node in total_nodes: |
| 60 | if not packages_versions[node]: |
| 61 | # TODO: do not skip node |
Hanna Arhipova | 1eef831 | 2019-05-06 20:14:18 +0300 | [diff] [blame] | 62 | logging.warning("Node {} is skipped".format(node)) |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 63 | continue |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 64 | nodes_with_packages.append(node) |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 65 | packages_names.update(packages_versions[node].keys()) |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 66 | for deb in packages_names: |
| 67 | if deb in exclude_packages: |
| 68 | continue |
| 69 | diff = [] |
| 70 | row = [] |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 71 | for node in nodes_with_packages: |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 72 | if not packages_versions[node]: |
| 73 | continue |
| 74 | if deb in packages_versions[node].keys(): |
| 75 | diff.append(packages_versions[node][deb]) |
| 76 | row.append("{}: {}".format(node, packages_versions[node][deb])) |
| 77 | else: |
| 78 | row.append("{}: No package".format(node)) |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 79 | |
| 80 | if diff.count(diff[0]) < len(nodes_with_packages): |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 81 | if not is_deb_in_exception(inconsistency_rule, deb, row): |
Ekaterina Chernova | 9c232f9 | 2019-07-26 16:02:18 +0300 | [diff] [blame] | 82 | row.sort() |
| 83 | row.insert(0, deb) |
| 84 | packages_with_different_versions.append(row) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 85 | assert len(packages_with_different_versions) == 0, ( |
| 86 | "Non-uniform package versions are installed on '{}' group of nodes:\n" |
| 87 | "{}".format( |
| 88 | group, json.dumps(packages_with_different_versions, indent=4)) |
| 89 | ) |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 90 | |
| 91 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 92 | @pytest.mark.full |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 93 | def test_packages_are_latest(local_salt_client, nodes_in_group): |
| 94 | config = utils.get_configuration() |
| 95 | skip = config.get("test_packages")["skip_test"] |
| 96 | if skip: |
| 97 | pytest.skip("Test for the latest packages is disabled") |
| 98 | skipped_pkg = config.get("test_packages")["skipped_packages"] |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 99 | group, nodes = nodes_in_group |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 100 | info_salt = local_salt_client.cmd( |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 101 | tgt='L@' + ','.join(nodes), |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 102 | param='apt list --upgradable 2>/dev/null | grep -v Listing', |
| 103 | expr_form='compound') |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 104 | for node in nodes: |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 105 | result = [] |
| 106 | if info_salt[node]: |
| 107 | upg_list = info_salt[node].split('\n') |
| 108 | for i in upg_list: |
| 109 | if i.split('/')[0] not in skipped_pkg: |
| 110 | result.append(i) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 111 | assert not result, ( |
| 112 | "Packages are not of latest version on '{}' node:\n{}".format( |
| 113 | node, "\n".join(result)) |
| 114 | ) |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 115 | |
| 116 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 117 | @pytest.mark.full |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 118 | def test_check_module_versions(local_salt_client, nodes_in_group): |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 119 | # defines modules specific to the concrete nodes |
| 120 | inconsistency_rule = {"ctl01": ["gnocchiclient", "ujson"], "log01": ["elasticsearch"]} |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 121 | exclude_modules = utils.get_configuration().get("skipped_modules", []) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 122 | group, nodes = nodes_in_group |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 123 | pre_check = local_salt_client.cmd( |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 124 | tgt="L@"+','.join(nodes), |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 125 | param='dpkg -l | grep "python-pip "', |
| 126 | expr_form='compound') |
| 127 | if pre_check.values().count('') > 0: |
| 128 | pytest.skip("pip is not installed on one or more nodes") |
| 129 | |
| 130 | exclude_nodes = local_salt_client.test_ping(tgt="I@galera:master or I@gerrit:client", |
| 131 | expr_form='compound').keys() |
Oleksii Zhurba | a3e79ce | 2019-06-04 17:26:51 -0500 | [diff] [blame] | 132 | |
| 133 | # PROD-30833 |
| 134 | gtw01 = local_salt_client.pillar_get( |
| 135 | param='_param:openstack_gateway_node01_hostname') or 'gtw01' |
| 136 | cluster_domain = local_salt_client.pillar_get( |
| 137 | param='_param:cluster_domain') or '.local' |
| 138 | gtw01 += '.' + cluster_domain |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 139 | if gtw01 in nodes: |
| 140 | octavia = local_salt_client.cmd(tgt="L@" + ','.join(nodes), |
Oleksii Zhurba | 29baebd | 2019-06-12 16:11:40 -0500 | [diff] [blame] | 141 | fun='pillar.get', |
| 142 | param='octavia:manager:enabled', |
| 143 | expr_form='compound') |
| 144 | gtws = [gtw for gtw in octavia.values() if gtw] |
| 145 | if len(gtws) == 1: |
Oleksii Zhurba | a3e79ce | 2019-06-04 17:26:51 -0500 | [diff] [blame] | 146 | exclude_nodes.append(gtw01) |
| 147 | logging.info("gtw01 node is skipped in test_check_module_versions") |
| 148 | |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 149 | total_nodes = [i for i in pre_check.keys() if i not in exclude_nodes] |
| 150 | |
| 151 | if len(total_nodes) < 2: |
| 152 | pytest.skip("Nothing to compare - only 1 node") |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 153 | list_of_pip_packages = local_salt_client.cmd( |
| 154 | tgt="L@"+','.join(nodes), |
| 155 | fun='pip.freeze', expr_form='compound') |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 156 | |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 157 | nodes_with_packages = [] |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 158 | |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 159 | modules_with_different_versions = [] |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 160 | packages_names = set() |
| 161 | |
| 162 | for node in total_nodes: |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 163 | nodes_with_packages.append(node) |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 164 | packages_names.update([x.split("=")[0] for x in list_of_pip_packages[node]]) |
| 165 | list_of_pip_packages[node] = dict([x.split("==") for x in list_of_pip_packages[node]]) |
| 166 | |
| 167 | for deb in packages_names: |
| 168 | if deb in exclude_modules: |
| 169 | continue |
| 170 | diff = [] |
| 171 | row = [] |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 172 | for node in nodes_with_packages: |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 173 | if deb in list_of_pip_packages[node].keys(): |
| 174 | diff.append(list_of_pip_packages[node][deb]) |
| 175 | row.append("{}: {}".format(node, list_of_pip_packages[node][deb])) |
| 176 | else: |
| 177 | row.append("{}: No module".format(node)) |
Ekaterina Chernova | 77594f7 | 2019-07-29 17:09:12 +0300 | [diff] [blame] | 178 | if diff.count(diff[0]) < len(nodes_with_packages): |
| 179 | if not is_deb_in_exception(inconsistency_rule, deb, row): |
| 180 | row.sort() |
| 181 | row.insert(0, deb) |
| 182 | modules_with_different_versions.append(row) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame^] | 183 | assert len(modules_with_different_versions) == 0, ( |
| 184 | "Non-uniform pip modules are installed on '{}' group of nodes:\n" |
| 185 | "{}".format( |
| 186 | group, json.dumps(modules_with_different_versions, indent=4)) |
| 187 | ) |