From 721b70dab0be866573016fc43b69f41d722d9381 Mon Sep 17 00:00:00 2001 From: Shayan Patel Date: Mon, 1 Jul 2024 10:14:43 +0000 Subject: [PATCH] Minor improvements to how requests to router exporter are made --- tests/integration/test_exporter.py | 20 ++++++++------------ tests/integration/test_exporter_with_tls.py | 20 ++++++++------------ 2 files changed, 16 insertions(+), 24 deletions(-) diff --git a/tests/integration/test_exporter.py b/tests/integration/test_exporter.py index 5b20dd6b..90cc51a3 100644 --- a/tests/integration/test_exporter.py +++ b/tests/integration/test_exporter.py @@ -119,8 +119,7 @@ async def test_exporter_endpoint(ops_test: OpsTest, mysql_router_charm_series: s unit_address = await unit.get_public_address() try: - with requests.Session() as session: - session.get(f"http://{unit_address}:49152/metrics", stream=False) + requests.get(f"http://{unit_address}:49152/metrics", stream=False) except requests.exceptions.ConnectionError as e: assert "[Errno 111] Connection refused" in str(e), "❌ expected connection refused error" else: @@ -137,14 +136,12 @@ async def test_exporter_endpoint(ops_test: OpsTest, mysql_router_charm_series: s wait=tenacity.wait_fixed(10), ): with attempt: - with requests.Session() as session: - response = session.get(f"http://{unit_address}:49152/metrics", stream=False) - assert ( - response.status_code == 200 - ), "❌ cannot connect to metrics endpoint with relation with cos" - assert "mysqlrouter_route_health" in str( - response.text - ), "❌ did not find expected metric in response" + response = requests.get(f"http://{unit_address}:49152/metrics", stream=False) + response.raise_for_status() + assert ( + "mysqlrouter_route_health" in response.text + ), "❌ did not find expected metric in response" + response.close() logger.info("Removing relation between mysqlrouter and grafana agent") await mysql_router_app.remove_relation( @@ -158,8 +155,7 @@ async def test_exporter_endpoint(ops_test: OpsTest, mysql_router_charm_series: s ): with attempt: try: - with requests.Session() as session: - session.get(f"http://{unit_address}:49152/metrics", stream=False) + requests.get(f"http://{unit_address}:49152/metrics", stream=False) except requests.exceptions.ConnectionError as e: assert "[Errno 111] Connection refused" in str( e diff --git a/tests/integration/test_exporter_with_tls.py b/tests/integration/test_exporter_with_tls.py index b89277a6..d98ae7d8 100644 --- a/tests/integration/test_exporter_with_tls.py +++ b/tests/integration/test_exporter_with_tls.py @@ -160,8 +160,7 @@ async def test_exporter_endpoint(ops_test: OpsTest, mysql_router_charm_series: s ): with attempt: try: - with requests.Session() as session: - session.get(f"http://{unit_address}:49152/metrics", stream=False) + requests.get(f"http://{unit_address}:49152/metrics", stream=False) except requests.exceptions.ConnectionError as e: assert "[Errno 111] Connection refused" in str( e @@ -180,14 +179,12 @@ async def test_exporter_endpoint(ops_test: OpsTest, mysql_router_charm_series: s wait=tenacity.wait_fixed(10), ): with attempt: - with requests.Session() as session: - response = session.get(f"http://{unit_address}:49152/metrics", stream=False) - assert ( - response.status_code == 200 - ), "❌ cannot connect to metrics endpoint with relation with cos" - assert "mysqlrouter_route_health" in str( - response.text - ), "❌ did not find expected metric in response" + response = requests.get(f"http://{unit_address}:49152/metrics", stream=False) + response.raise_for_status() + assert ( + "mysqlrouter_route_health" in response.text + ), "❌ did not find expected metric in response" + response.close() for attempt in tenacity.Retrying( reraise=True, @@ -216,8 +213,7 @@ async def test_exporter_endpoint(ops_test: OpsTest, mysql_router_charm_series: s ): with attempt: try: - with requests.Session() as session: - session.get(f"http://{unit_address}:49152/metrics", stream=False) + requests.get(f"http://{unit_address}:49152/metrics", stream=False) except requests.exceptions.ConnectionError as e: assert "[Errno 111] Connection refused" in str( e