Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 1 | import json |
| 2 | import requests |
Oleksii Zhurba | 84ce7fe | 2018-01-16 21:34:01 +0000 | [diff] [blame] | 3 | import datetime |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 4 | import pytest |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 5 | |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 6 | import utils |
| 7 | import logging |
| 8 | |
| 9 | # ################################ FIXTURES ################################## |
| 10 | |
| 11 | |
| 12 | def prometheus_rules(): |
| 13 | salt = utils.init_salt_client() |
| 14 | |
| 15 | IP = salt.pillar_get(param='_param:cluster_public_host') |
| 16 | proto = salt.pillar_get( |
| 17 | param='_param:cluster_public_protocol') |
| 18 | proxies = {"http": None, "https": None} |
| 19 | |
| 20 | prometheus_password = ( |
| 21 | # new password in 2019.2.7 |
| 22 | salt.pillar_get( |
| 23 | tgt="nginx:server", |
| 24 | param='_param:nginx_proxy_prometheus_server_password') |
| 25 | |
| 26 | # Generated password ~2019.2.4 |
| 27 | or salt.pillar_get( |
| 28 | param='_param:prometheus_server_proxy_password_generated') |
| 29 | |
| 30 | # old password ~ 2019.2.0 |
| 31 | or salt.pillar_get( |
| 32 | param='_param:keepalived_prometheus_vip_password_generated') |
Hanna Arhipova | a9bd1d4 | 2020-05-20 16:23:57 +0300 | [diff] [blame] | 33 | |
| 34 | or "" |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 35 | ) |
| 36 | |
Hanna Arhipova | a9bd1d4 | 2020-05-20 16:23:57 +0300 | [diff] [blame] | 37 | if prometheus_password == "": |
| 38 | logging.warning("Got empty prometheus_password. \ |
| 39 | Possibly this cluster with no Stacklight component") |
| 40 | return dict() |
| 41 | |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 42 | response = requests.get( |
| 43 | '{0}://{1}:15010/api/v1/rules'.format(proto, IP), |
| 44 | proxies=proxies, |
| 45 | auth=('prometheus', prometheus_password), |
| 46 | verify=False) |
| 47 | |
| 48 | if not response.status_code == 200: |
Hanna Arhipova | a9bd1d4 | 2020-05-20 16:23:57 +0300 | [diff] [blame] | 49 | logging.warning( |
Valeriy Sakharov | 70cdb90 | 2022-04-11 14:35:10 +0400 | [diff] [blame] | 50 | "Got response with incorrect status: {}. Switch to the internal network".format(response)) |
| 51 | IP = salt.pillar_get(param='_param:prometheus_control_address') |
| 52 | proto = salt.pillar_get(param='_param:cluster_internal_protocol') |
| 53 | response = requests.get( |
| 54 | '{0}://{1}:15010/api/v1/rules'.format(proto, IP), |
| 55 | proxies=proxies, |
| 56 | auth=('prometheus', prometheus_password), |
| 57 | verify=False) |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 58 | |
| 59 | content = json.loads(response.content.decode()) |
| 60 | rules = content['data']['groups'][0]["rules"] |
| 61 | |
| 62 | # collect rules with dict {'rulename' : {<rulecontent>}} |
| 63 | alerts_by_name = {rule['name']: rule['alerts'] |
| 64 | for rule in rules |
| 65 | } |
| 66 | logging.debug("collected next rules: {}".format(alerts_by_name)) |
| 67 | return alerts_by_name |
| 68 | |
| 69 | |
| 70 | prometheus_rules = prometheus_rules() |
| 71 | |
| 72 | |
Hanna Arhipova | a9bd1d4 | 2020-05-20 16:23:57 +0300 | [diff] [blame] | 73 | @pytest.mark.usefixtures('check_prometheus') |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 74 | @pytest.fixture(scope='session', |
| 75 | ids=prometheus_rules.keys(), |
| 76 | params=prometheus_rules.values()) |
| 77 | def alert_in_prometheus(request): |
| 78 | return request.param |
| 79 | |
| 80 | # ############################## TESTS ####################################### |
| 81 | |
| 82 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 83 | @pytest.mark.sl_dup |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 84 | # ElasticsearchClusterHealthStatusMajor or stacklight-pytest |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 85 | @pytest.mark.full |
Oleksii Zhurba | 8ce9fcf | 2018-10-05 18:38:22 +0300 | [diff] [blame] | 86 | @pytest.mark.usefixtures('check_kibana') |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 87 | def test_elasticsearch_cluster(local_salt_client): |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 88 | salt_output = local_salt_client.pillar_get( |
| 89 | tgt='kibana:server', |
| 90 | param='_param:haproxy_elasticsearch_bind_host') |
Oleksii Zhurba | 7d4f07e | 2019-06-10 17:30:53 -0500 | [diff] [blame] | 91 | ssl = local_salt_client.pillar_get( |
| 92 | tgt='elasticsearch:server', |
| 93 | param='haproxy:proxy:listen:elasticsearch:binds:ssl:enabled') |
Oleksii Zhurba | 612ce7c | 2019-06-19 14:56:34 -0500 | [diff] [blame] | 94 | proto = "https" if ssl else "http" |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 95 | |
Oleksii Zhurba | e592ed1 | 2018-06-21 18:01:09 -0500 | [diff] [blame] | 96 | proxies = {"http": None, "https": None} |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 97 | IP = salt_output |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 98 | response = requests.get( |
| 99 | '{0}://{1}:9200/'.format(proto, IP), |
| 100 | proxies=proxies, |
| 101 | verify=False) |
| 102 | assert response.status_code == 200, ( |
| 103 | "Issues with accessing elasticsearch on {}.".format(IP)) |
| 104 | response = requests.get( |
| 105 | '{0}://{1}:9200/_cat/health'.format(proto, IP), |
| 106 | proxies=proxies, |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 107 | verify=False).content.decode() |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 108 | msg = "elasticsearch is not healthy:\n{}".format( |
| 109 | json.dumps(response, indent=4)) |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 110 | assert response.split()[3] == 'green', msg |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 111 | assert response.split()[4] == '3', msg |
| 112 | assert response.split()[5] == '3', msg |
| 113 | assert response.split()[10] == '0', msg |
| 114 | assert response.split()[13] == '100.0%', msg |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 115 | |
| 116 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 117 | @pytest.mark.sl_dup |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 118 | # stacklight-pytest |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 119 | @pytest.mark.full |
Oleksii Zhurba | 8ce9fcf | 2018-10-05 18:38:22 +0300 | [diff] [blame] | 120 | @pytest.mark.usefixtures('check_kibana') |
Ievgeniia Zadorozhna | 511f0ce | 2018-11-08 17:43:10 +0300 | [diff] [blame] | 121 | def test_kibana_status(local_salt_client): |
| 122 | proxies = {"http": None, "https": None} |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 123 | IP = local_salt_client.pillar_get(param='_param:stacklight_log_address') |
Oleksii Zhurba | 7d4f07e | 2019-06-10 17:30:53 -0500 | [diff] [blame] | 124 | ssl = local_salt_client.pillar_get( |
| 125 | tgt='kibana:server', |
| 126 | param='haproxy:proxy:listen:kibana:binds:ssl:enabled') |
Oleksii Zhurba | 612ce7c | 2019-06-19 14:56:34 -0500 | [diff] [blame] | 127 | proto = "https" if ssl else "http" |
Oleksii Zhurba | 7d4f07e | 2019-06-10 17:30:53 -0500 | [diff] [blame] | 128 | |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 129 | response = requests.get( |
| 130 | '{0}://{1}:5601/api/status'.format(proto, IP), |
| 131 | proxies=proxies, |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 132 | verify=False).content.decode() |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 133 | body = json.loads(response) |
| 134 | assert body['status']['overall']['state'] == "green", ( |
| 135 | "Kibana overall status is not 'green':\n{}".format( |
| 136 | body['status']['overall']) |
| 137 | ) |
Ievgeniia Zadorozhna | 511f0ce | 2018-11-08 17:43:10 +0300 | [diff] [blame] | 138 | for i in body['status']['statuses']: |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 139 | assert i['state'] == "green", ( |
| 140 | "Kibana statuses are unexpected:\n{}".format(i)) |
Ievgeniia Zadorozhna | 511f0ce | 2018-11-08 17:43:10 +0300 | [diff] [blame] | 141 | |
| 142 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 143 | @pytest.mark.smoke |
| 144 | #TODO: recheck |
Ievgeniia Zadorozhna | 511f0ce | 2018-11-08 17:43:10 +0300 | [diff] [blame] | 145 | @pytest.mark.usefixtures('check_kibana') |
Oleksii Zhurba | 84ce7fe | 2018-01-16 21:34:01 +0000 | [diff] [blame] | 146 | def test_elasticsearch_node_count(local_salt_client): |
| 147 | now = datetime.datetime.now() |
| 148 | today = now.strftime("%Y.%m.%d") |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 149 | salt_output = local_salt_client.pillar_get( |
| 150 | tgt='kibana:server', |
| 151 | param='_param:haproxy_elasticsearch_bind_host') |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 152 | |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 153 | IP = salt_output |
Oleksii Zhurba | 7d4f07e | 2019-06-10 17:30:53 -0500 | [diff] [blame] | 154 | ssl = local_salt_client.pillar_get( |
| 155 | tgt='elasticsearch:server', |
| 156 | param='haproxy:proxy:listen:elasticsearch:binds:ssl:enabled') |
Oleksii Zhurba | 612ce7c | 2019-06-19 14:56:34 -0500 | [diff] [blame] | 157 | proto = "https" if ssl else "http" |
Oleksii Zhurba | 7d4f07e | 2019-06-10 17:30:53 -0500 | [diff] [blame] | 158 | |
Tatyana Leontovich | ed57cb0 | 2019-01-11 16:26:32 +0200 | [diff] [blame] | 159 | headers = {'Content-type': 'application/json', 'Accept': 'text/plain'} |
Oleksii Zhurba | e592ed1 | 2018-06-21 18:01:09 -0500 | [diff] [blame] | 160 | proxies = {"http": None, "https": None} |
Tatyana Leontovich | ed57cb0 | 2019-01-11 16:26:32 +0200 | [diff] [blame] | 161 | data = ('{"size": 0, "aggs": ' |
| 162 | '{"uniq_hostname": ' |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 163 | '{"terms": {"size": 500, ' |
Tatyana Leontovich | ed57cb0 | 2019-01-11 16:26:32 +0200 | [diff] [blame] | 164 | '"field": "Hostname.keyword"}}}}') |
| 165 | response = requests.post( |
Oleksii Zhurba | 7d4f07e | 2019-06-10 17:30:53 -0500 | [diff] [blame] | 166 | '{0}://{1}:9200/log-{2}/_search?pretty'.format(proto, IP, today), |
Tatyana Leontovich | ed57cb0 | 2019-01-11 16:26:32 +0200 | [diff] [blame] | 167 | proxies=proxies, |
| 168 | headers=headers, |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 169 | verify=False, |
Tatyana Leontovich | ed57cb0 | 2019-01-11 16:26:32 +0200 | [diff] [blame] | 170 | data=data) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 171 | assert response.status_code == 200, ( |
| 172 | 'Issues with accessing elasticsearch on {}:\n{}'.format( |
| 173 | IP, response.text) |
| 174 | ) |
Tatyana Leontovich | ed57cb0 | 2019-01-11 16:26:32 +0200 | [diff] [blame] | 175 | resp = json.loads(response.text) |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 176 | cluster_domain = local_salt_client.pillar_get( |
| 177 | param='_param:cluster_domain') |
Oleksii Zhurba | d2847dc | 2018-02-16 15:13:09 -0600 | [diff] [blame] | 178 | monitored_nodes = [] |
Oleksii Zhurba | 7f46341 | 2018-03-21 16:32:44 -0500 | [diff] [blame] | 179 | for item_ in resp['aggregations']['uniq_hostname']['buckets']: |
Oleksii Zhurba | d2847dc | 2018-02-16 15:13:09 -0600 | [diff] [blame] | 180 | node_name = item_['key'] |
| 181 | monitored_nodes.append(node_name + '.' + cluster_domain) |
| 182 | missing_nodes = [] |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 183 | all_nodes = list(local_salt_client.test_ping(tgt='*').keys()) |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 184 | for node in all_nodes: |
Oleksii Zhurba | d2847dc | 2018-02-16 15:13:09 -0600 | [diff] [blame] | 185 | if node not in monitored_nodes: |
| 186 | missing_nodes.append(node) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 187 | assert len(missing_nodes) == 0, ( |
| 188 | "Not all nodes are in Elasticsearch. Expected {}, but found {} keys.\n" |
| 189 | "Missing nodes:\n{}".format( |
| 190 | len(monitored_nodes), len(all_nodes), missing_nodes) |
| 191 | ) |
Oleksii Zhurba | 84ce7fe | 2018-01-16 21:34:01 +0000 | [diff] [blame] | 192 | |
| 193 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 194 | @pytest.mark.sl_dup |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 195 | # DockerServiceMonitoring* |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 196 | @pytest.mark.full |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 197 | def test_stacklight_services_replicas(local_salt_client): |
Oleksii Zhurba | 8ce9fcf | 2018-10-05 18:38:22 +0300 | [diff] [blame] | 198 | # TODO |
| 199 | # change to docker:swarm:role:master ? |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 200 | salt_output = local_salt_client.cmd( |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 201 | tgt='I@docker:client:stack:monitoring and I@prometheus:server', |
| 202 | param='docker service ls', |
Oleksii Zhurba | 8ce9fcf | 2018-10-05 18:38:22 +0300 | [diff] [blame] | 203 | expr_form='compound') |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 204 | |
| 205 | if not salt_output: |
Oleksii Zhurba | 8ce9fcf | 2018-10-05 18:38:22 +0300 | [diff] [blame] | 206 | pytest.skip("docker:client:stack:monitoring or \ |
| 207 | prometheus:server pillars are not found on this environment.") |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 208 | |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 209 | wrong_items = [] |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 210 | for line in salt_output[list(salt_output.keys())[0]].split('\n'): |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 211 | if line[line.find('/') - 1] != line[line.find('/') + 1] \ |
| 212 | and 'replicated' in line: |
| 213 | wrong_items.append(line) |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 214 | assert len(wrong_items) == 0, ( |
| 215 | "Some monitoring services don't have the expected number of " |
| 216 | "replicas:\n{}".format(json.dumps(wrong_items, indent=4)) |
| 217 | ) |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 218 | |
| 219 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 220 | @pytest.mark.smoke |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 221 | def test_prometheus_alert_count(alert_in_prometheus): |
Hanna Arhipova | 3fc0657 | 2019-12-09 15:57:55 +0200 | [diff] [blame] | 222 | |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 223 | assert len(alert_in_prometheus) == 0, \ |
| 224 | '\n\n\tAlertManager page has some alerts!\n{} \n'.format( |
| 225 | '\n'.join( |
| 226 | [alert['annotations']['description'] |
| 227 | for alert in alert_in_prometheus] |
| 228 | )) |
Oleksii Zhurba | 468e6c7 | 2018-01-16 17:43:15 +0000 | [diff] [blame] | 229 | |
| 230 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 231 | @pytest.mark.sl_dup |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 232 | # DockerServiceMonitoring* ?? |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 233 | @pytest.mark.full |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 234 | def test_stacklight_containers_status(local_salt_client): |
| 235 | salt_output = local_salt_client.cmd( |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 236 | tgt='I@docker:swarm:role:master and I@prometheus:server', |
| 237 | param='docker service ps $(docker stack services -q monitoring)', |
Oleksii Zhurba | 8ce9fcf | 2018-10-05 18:38:22 +0300 | [diff] [blame] | 238 | expr_form='compound') |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 239 | |
| 240 | if not salt_output: |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 241 | pytest.skip("docker:swarm:role:master or prometheus:server pillars " |
| 242 | "are not found on this environment.") |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 243 | |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 244 | result = {} |
Oleksii Zhurba | 468e6c7 | 2018-01-16 17:43:15 +0000 | [diff] [blame] | 245 | # for old reclass models, docker:swarm:role:master can return |
| 246 | # 2 nodes instead of one. Here is temporary fix. |
| 247 | # TODO |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 248 | if len(list(salt_output.keys())) > 1: |
| 249 | if 'CURRENT STATE' not in salt_output[list(salt_output.keys())[0]]: |
| 250 | del salt_output[list(salt_output.keys())[0]] |
| 251 | for line in salt_output[list(salt_output.keys())[0]].split('\n')[1:]: |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 252 | shift = 0 |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 253 | if line.split()[1] == '\\_': |
| 254 | shift = 1 |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 255 | if line.split()[1 + shift] not in list(result.keys()): |
Oleksii Zhurba | 020fab4 | 2017-11-01 20:13:28 +0000 | [diff] [blame] | 256 | result[line.split()[1]] = 'NOT OK' |
| 257 | if line.split()[4 + shift] == 'Running' \ |
| 258 | or line.split()[4 + shift] == 'Ready': |
| 259 | result[line.split()[1 + shift]] = 'OK' |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 260 | assert 'NOT OK' not in list(result.values()), ( |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 261 | "Some containers have incorrect state:\n{}".format( |
| 262 | json.dumps(result, indent=4)) |
| 263 | ) |
Oleksii Zhurba | e592ed1 | 2018-06-21 18:01:09 -0500 | [diff] [blame] | 264 | |
| 265 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 266 | @pytest.mark.sl_dup |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 267 | # PrometheusTargetDown |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 268 | @pytest.mark.full |
Oleksii Zhurba | e592ed1 | 2018-06-21 18:01:09 -0500 | [diff] [blame] | 269 | def test_running_telegraf_services(local_salt_client): |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 270 | salt_output = local_salt_client.cmd(tgt='telegraf:agent', |
| 271 | fun='service.status', |
| 272 | param='telegraf', |
| 273 | expr_form='pillar',) |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 274 | |
| 275 | if not salt_output: |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 276 | pytest.skip("Telegraf or telegraf:agent pillars are not found on " |
| 277 | "this environment.") |
Oleksii Zhurba | 9848e21 | 2018-09-05 10:53:51 -0500 | [diff] [blame] | 278 | |
Oleksii Zhurba | e592ed1 | 2018-06-21 18:01:09 -0500 | [diff] [blame] | 279 | result = [{node: status} for node, status |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 280 | in list(salt_output.items()) |
Oleksii Zhurba | e592ed1 | 2018-06-21 18:01:09 -0500 | [diff] [blame] | 281 | if status is False] |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 282 | assert result == [], ( |
| 283 | "Telegraf service is not running on the following nodes:\n{}".format( |
| 284 | result) |
| 285 | ) |
Ievgeniia Zadorozhna | 6775eb7 | 2018-11-09 19:50:04 +0300 | [diff] [blame] | 286 | |
| 287 | |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 288 | @pytest.mark.sl_dup |
Hanna Arhipova | c6a022a | 2020-02-11 22:17:20 +0200 | [diff] [blame] | 289 | # PrometheusTargetDown |
Oleksii Zhurba | 23c1833 | 2019-05-09 18:53:40 -0500 | [diff] [blame] | 290 | @pytest.mark.full |
Ievgeniia Zadorozhna | 6775eb7 | 2018-11-09 19:50:04 +0300 | [diff] [blame] | 291 | def test_running_fluentd_services(local_salt_client): |
Hanna Arhipova | e6ed8e4 | 2019-05-15 16:27:08 +0300 | [diff] [blame] | 292 | salt_output = local_salt_client.cmd(tgt='fluentd:agent', |
| 293 | fun='service.status', |
| 294 | param='td-agent', |
Ievgeniia Zadorozhna | 6775eb7 | 2018-11-09 19:50:04 +0300 | [diff] [blame] | 295 | expr_form='pillar') |
| 296 | result = [{node: status} for node, status |
Ekaterina Chernova | c73bc4e | 2019-11-12 14:56:03 +0300 | [diff] [blame] | 297 | in list(salt_output.items()) |
Ievgeniia Zadorozhna | 6775eb7 | 2018-11-09 19:50:04 +0300 | [diff] [blame] | 298 | if status is False] |
Dmitriy Kruglov | bc0a88b | 2019-08-20 11:45:35 +0200 | [diff] [blame] | 299 | assert result == [], ( |
| 300 | "Fluentd check failed - td-agent service is not running on the " |
| 301 | "following nodes:\n{}".format(result) |
| 302 | ) |