Close request object, not the whole connection. Allows keepalive

This merges [PR-269](https://github.com/plamere/spotipy/pull/269) from
the base spotipy project ahead of it getting merged in upstream.
This commit is contained in:
Nick Sonneveld 2018-03-30 15:06:04 +11:00 committed by David Todd
parent 4c2c1d763a
commit 9eb1c67726

View File

@ -107,11 +107,13 @@ class Spotify(object):
if self.trace_out: if self.trace_out:
print(url) print(url)
r = self._session.request(method, url, headers=headers, proxies=self.proxies, **args)
with self._session.request(method, url, headers=headers, proxies=self.proxies, **args) as r:
if self.trace: # pragma: no cover if self.trace: # pragma: no cover
print() print()
print ('headers', headers) print ('request headers', headers)
print ('response headers', r.headers)
print ('http status', r.status_code) print ('http status', r.status_code)
print(method, r.url) print(method, r.url)
if payload: if payload:
@ -120,23 +122,22 @@ class Spotify(object):
try: try:
r.raise_for_status() r.raise_for_status()
except: except:
if r.text and len(r.text) > 0 and r.text != 'null': try:
msg = r.json()['error']['message']
except:
msg = 'error'
raise SpotifyException(r.status_code, raise SpotifyException(r.status_code,
-1, '%s:\n %s' % (r.url, r.json()['error']['message']), -1, '%s:\n %s' % (r.url, msg), headers=r.headers)
headers=r.headers)
else: try:
raise SpotifyException(r.status_code,
-1, '%s:\n %s' % (r.url, 'error'), headers=r.headers)
finally:
r.connection.close()
if r.text and len(r.text) > 0 and r.text != 'null':
results = r.json() results = r.json()
except:
results = None
if self.trace: # pragma: no cover if self.trace: # pragma: no cover
print('RESP', results) print('RESP', results)
print() print()
return results return results
else:
return None
def _get(self, url, args=None, payload=None, **kwargs): def _get(self, url, args=None, payload=None, **kwargs):
if args: if args: