From 35afabc9a4bcd25fbda8d6acda987476bbcd1f3d Mon Sep 17 00:00:00 2001 From: Julien Perrochet Date: Thu, 30 Nov 2023 10:08:21 +0100 Subject: [PATCH] [uss_qualifier] async session queries also return headers --- monitoring/monitorlib/infrastructure.py | 30 +++++++++++++++---- ...est_isa_simple_heavy_traffic_concurrent.py | 14 ++++----- ...eration_simple_heavy_traffic_concurrent.py | 10 +++---- 3 files changed, 37 insertions(+), 17 deletions(-) diff --git a/monitoring/monitorlib/infrastructure.py b/monitoring/monitorlib/infrastructure.py index 093ef73c28..6b88b9d515 100644 --- a/monitoring/monitorlib/infrastructure.py +++ b/monitoring/monitorlib/infrastructure.py @@ -3,7 +3,7 @@ import functools from typing import Dict, List, Optional import urllib.parse -from aiohttp import ClientSession +from aiohttp import ClientSession, ClientResponse import jwt import requests @@ -190,32 +190,52 @@ def adjust_request_kwargs(self, url, method, kwargs): return kwargs async def put(self, url, **kwargs): + """Returns (status, headers, json)""" url = self._prefix_url + url if "auth" not in kwargs: kwargs = self.adjust_request_kwargs(url, "PUT", kwargs) async with self._client.put(url, **kwargs) as response: - return response.status, await response.json() + return ( + response.status, + {k: v for k, v in response.headers.items()}, + await response.json(), + ) async def get(self, url, **kwargs): + """Returns (status, headers, json)""" url = self._prefix_url + url if "auth" not in kwargs: kwargs = self.adjust_request_kwargs(url, "GET", kwargs) async with self._client.get(url, **kwargs) as response: - return response.status, await response.json() + return ( + response.status, + {k: v for k, v in response.headers.items()}, + await response.json(), + ) async def post(self, url, **kwargs): + """Returns (status, headers, json)""" url = self._prefix_url + url if "auth" not in kwargs: kwargs = self.adjust_request_kwargs(url, "POST", kwargs) async with self._client.post(url, **kwargs) as response: - return response.status, await response.json() + return ( + response.status, + {k: v for k, v in response.headers.items()}, + await response.json(), + ) async def delete(self, url, **kwargs): + """Returns (status, headers, json)""" url = self._prefix_url + url if "auth" not in kwargs: kwargs = self.adjust_request_kwargs(url, "DELETE", kwargs) async with self._client.delete(url, **kwargs) as response: - return response.status, await response.json() + return ( + response.status, + {k: v for k, v in response.headers.items()}, + await response.json(), + ) def default_scopes(scopes: List[str]): diff --git a/monitoring/prober/rid/v1/test_isa_simple_heavy_traffic_concurrent.py b/monitoring/prober/rid/v1/test_isa_simple_heavy_traffic_concurrent.py index d22d26b07e..b85e59cae9 100644 --- a/monitoring/prober/rid/v1/test_isa_simple_heavy_traffic_concurrent.py +++ b/monitoring/prober/rid/v1/test_isa_simple_heavy_traffic_concurrent.py @@ -107,8 +107,8 @@ def test_create_isa_concurrent(ids, session_ridv1_async): ) ) for isa_id, resp in results: - assert resp[0] == 200, resp[1] - data = resp[1] + assert resp[0] == 200, resp[2] + data = resp[2] assert data["service_area"]["id"] == isa_id assert data["service_area"]["flights_url"] == "https://example.com/dss" assert_datetimes_are_equal( @@ -133,9 +133,9 @@ def test_get_isa_by_ids_concurrent(ids, session_ridv1_async): ) ) for isa_id, resp in results: - assert resp[0] == 200, resp[1] + assert resp[0] == 200, resp[2] - data = resp[1] + data = resp[2] assert data["service_area"]["id"] == isa_id assert data["service_area"]["flights_url"] == FLIGHTS_URL @@ -162,8 +162,8 @@ def test_delete_isa_concurrent(ids, session_ridv1_async): ) for isa_id, resp in results: - assert resp[0] == 200, resp[1] - version = resp[1]["service_area"]["version"] + assert resp[0] == 200, resp[2] + version = resp[2]["service_area"]["version"] version_map[isa_id] = version # Delete ISAs concurrently @@ -178,4 +178,4 @@ def test_delete_isa_concurrent(ids, session_ridv1_async): ) for isa_id, resp in results: - assert resp[0], resp[1] + assert resp[0], resp[2] diff --git a/monitoring/prober/scd/test_operation_simple_heavy_traffic_concurrent.py b/monitoring/prober/scd/test_operation_simple_heavy_traffic_concurrent.py index 8a9d8d21e0..a885e7469a 100644 --- a/monitoring/prober/scd/test_operation_simple_heavy_traffic_concurrent.py +++ b/monitoring/prober/scd/test_operation_simple_heavy_traffic_concurrent.py @@ -258,7 +258,7 @@ def test_create_ops_concurrent(ids, scd_api, scd_session_async): op_id = req_map[0] op_resp_map[op_id] = {} op_resp_map[op_id]["status_code"] = resp[0][0] - op_resp_map[op_id]["content"] = resp[0][1] + op_resp_map[op_id]["content"] = resp[0][2] for op_id, resp in op_resp_map.items(): if resp["status_code"] != 201: try: @@ -342,7 +342,7 @@ def test_get_ops_by_ids_concurrent(ids, scd_api, scd_session_async): for op_id, resp in zip(map(ids, OP_TYPES), results): op_resp_map[op_id] = {} op_resp_map[op_id]["status_code"] = resp[0] - op_resp_map[op_id]["content"] = resp[1] + op_resp_map[op_id]["content"] = resp[2] for op_id, resp in op_resp_map.items(): assert resp["status_code"] == 200, resp["content"] @@ -381,7 +381,7 @@ def test_get_ops_by_search_concurrent(ids, scd_api, scd_session_async): for idx, resp in zip(range(len(OP_TYPES)), results): op_resp_map[idx] = {} op_resp_map[idx]["status_code"] = resp[0] - op_resp_map[idx]["content"] = resp[1] + op_resp_map[idx]["content"] = resp[2] for idx, resp in op_resp_map.items(): assert resp["status_code"] == 200, resp["content"] @@ -431,7 +431,7 @@ def test_mutate_ops_concurrent(ids, scd_api, scd_session, scd_session_async): op_id = req_map[0] op_resp_map[op_id] = {} op_resp_map[op_id]["status_code"] = resp[0][0] - op_resp_map[op_id]["content"] = resp[0][1] + op_resp_map[op_id]["content"] = resp[0][2] ovn_map.clear() @@ -486,7 +486,7 @@ def test_delete_op_concurrent(ids, scd_api, scd_session_async): for op_id, resp in zip(map(ids, OP_TYPES), results): op_resp_map[op_id] = {} op_resp_map[op_id]["status_code"] = resp[0] - op_resp_map[op_id]["content"] = resp[1] + op_resp_map[op_id]["content"] = resp[2] assert len(op_resp_map) == len(OP_TYPES)