-
Notifications
You must be signed in to change notification settings - Fork 213
Expand file tree
/
Copy pathhttp_client.py
More file actions
83 lines (68 loc) · 3.12 KB
/
http_client.py
File metadata and controls
83 lines (68 loc) · 3.12 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import requests
class MinimalHttpClient:
def __init__(self, verify=True, proxies=None, timeout=None):
self.session = requests.Session()
self.session.verify = verify
self.session.proxies = proxies
self.timeout = timeout
def post(self, url, params=None, data=None, headers=None, **kwargs):
assert not kwargs, "Our stack shouldn't leak extra kwargs: %s" % kwargs
return MinimalResponse(requests_resp=self.session.post(
url, params=params, data=data, headers=headers,
timeout=self.timeout))
def get(self, url, params=None, headers=None, **kwargs):
assert not kwargs, "Our stack shouldn't leak extra kwargs: %s" % kwargs
return MinimalResponse(requests_resp=self.session.get(
url, params=params, headers=headers, timeout=self.timeout))
def close(self): # Not required, but we use it to avoid a warning in unit test
self.session.close()
class MinimalResponse(object): # Not for production use
def __init__(self, requests_resp=None, status_code=None, text=None, headers=None):
self.status_code = status_code or requests_resp.status_code
self.text = text if text is not None else requests_resp.text
if headers:
# Early versions of MSAL did not require http response to contain headers.
# As of April 2025, some Azure Identity code paths still yield response without headers.
# Here we mimic the behavior of header-less response by default,
# so that test cases can cover header-less response scenarios.
self.headers = headers
self._raw_resp = requests_resp
def raise_for_status(self):
if self._raw_resp is not None: # Turns out `if requests.response` won't work
# cause it would be True when 200<=status<400
self._raw_resp.raise_for_status()
class RecordingHttpClient(object):
def __init__(self):
self.get_calls = []
self.post_calls = []
self._get_routes = []
self._post_routes = []
def add_get_route(self, matcher, responder):
self._get_routes.append((matcher, responder))
def add_post_route(self, matcher, responder):
self._post_routes.append((matcher, responder))
def get(self, url, params=None, headers=None, **kwargs):
call = {
"url": url,
"params": params,
"headers": headers,
"kwargs": kwargs,
}
self.get_calls.append(call)
for matcher, responder in self._get_routes:
if matcher(call):
return responder(call)
return MinimalResponse(status_code=404, text="")
def post(self, url, params=None, data=None, headers=None, **kwargs):
call = {
"url": url,
"params": params,
"data": data,
"headers": headers,
"kwargs": kwargs,
}
self.post_calls.append(call)
for matcher, responder in self._post_routes:
if matcher(call):
return responder(call)
return MinimalResponse(status_code=404, text="")