From c0670267e8ca78ac38e902343dae5b30da883c97 Mon Sep 17 00:00:00 2001 From: Peter Sabaini Date: Wed, 4 Sep 2024 20:32:28 +0200 Subject: [PATCH] COS testing fix Don't require trusted certs for getting grafana api info Signed-off-by: Peter Sabaini --- .../charm_tests/ceph/mon/integration.py | 46 +++++++++++-------- 1 file changed, 27 insertions(+), 19 deletions(-) diff --git a/zaza/openstack/charm_tests/ceph/mon/integration.py b/zaza/openstack/charm_tests/ceph/mon/integration.py index 7ba18299b..6028d0079 100644 --- a/zaza/openstack/charm_tests/ceph/mon/integration.py +++ b/zaza/openstack/charm_tests/ceph/mon/integration.py @@ -63,23 +63,27 @@ def application_present(name): def get_up_osd_count(prometheus_url): """Get the number of up OSDs from prometheus.""" - query = 'ceph_osd_up' - response = requests.get(f'{prometheus_url}/query', params={'query': query}) + query = "ceph_osd_up" + response = requests.get( + f"{prometheus_url}/query", params={"query": query}, verify=False + ) data = response.json() - if data['status'] != 'success': + if data["status"] != "success": raise Exception(f"Query failed: {data.get('error', 'Unknown error')}") - results = data['data']['result'] - up_osd_count = sum(int(result['value'][1]) for result in results) + results = data["data"]["result"] + up_osd_count = sum(int(result["value"][1]) for result in results) return up_osd_count def extract_pool_names(prometheus_url): """Extract pool names from prometheus.""" - query = 'ceph_pool_metadata' - response = requests.get(f'{prometheus_url}/query', params={'query': query}) + query = "ceph_pool_metadata" + response = requests.get( + f"{prometheus_url}/query", params={"query": query}, verify=False + ) data = response.json() - if data['status'] != 'success': + if data["status"] != "success": raise Exception(f"Query failed: {data.get('error', 'Unknown error')}") pool_names = [] @@ -95,42 +99,45 @@ def extract_pool_names(prometheus_url): def get_alert_rules(prometheus_url): """Get the alert rules from prometheus.""" - response = requests.get(f'{prometheus_url}/rules') + response = requests.get(f"{prometheus_url}/rules", verify=False) data = response.json() - if data['status'] != 'success': + if data["status"] != "success": raise Exception(f"Query failed: {data.get('error', 'Unknown error')}") alert_names = set() - for obj in data['data']['groups']: - rules = obj.get('rules', []) + for obj in data["data"]["groups"]: + rules = obj.get("rules", []) for rule in rules: - name = rule.get('name') + name = rule.get("name") if name: alert_names.add(name) return alert_names -@tenacity.retry(wait=tenacity.wait_fixed(5), - stop=tenacity.stop_after_delay(180)) +@tenacity.retry( + wait=tenacity.wait_fixed(5), stop=tenacity.stop_after_delay(180) +) def get_prom_api_url(grafana_agent): """Get the prometheus API URL from the grafana-agent config.""" ga_yaml = zaza.model.file_contents( f"{grafana_agent}/leader", "/etc/grafana-agent.yaml" ) ga = yaml.safe_load(ga_yaml) - url = ga['integrations']['prometheus_remote_write'][0]['url'] + url = ga["integrations"]["prometheus_remote_write"][0]["url"] if url.endswith("/write"): url = url[:-6] # lob off the /write return url -@tenacity.retry(wait=tenacity.wait_fixed(5), - stop=tenacity.stop_after_delay(180)) +@tenacity.retry( + wait=tenacity.wait_fixed(5), stop=tenacity.stop_after_delay(180) +) def get_dashboards(url, user, passwd): """Retrieve a list of dashboards from Grafana.""" response = requests.get( f"{url}/api/search?type=dash-db", - auth=(user, passwd) + auth=(user, passwd), + verify=False, ) if response.status_code != 200: raise Exception(f"Failed to retrieve dashboards: {response}") @@ -162,6 +169,7 @@ def setUpClass(cls): def test_100_integration_setup(self): """Test: check that the grafana-agent is related to the ceph-mon.""" + async def have_rel(): app = await zaza.model.async_get_application(self.application_name) spec = f"{self.grafana_agent}:cos-agent"