Fix swift-dispersion-populate bug when using SimpleClient class
Commit 7fcbbebb
changed the internal client a little bit and removed the
class variable self.attempts in SimpleClient. This is currently still
needed in swift-dispersion-populate to track the number of retries, thus
re-adding it again.
Closes-Bug: 1351323
Change-Id: I98ba6441607158b34708b2dbb2d1a63788681d63
This commit is contained in:
parent
9bc3b0ebd8
commit
8ad37b2217
@ -728,6 +728,7 @@ class SimpleClient(object):
|
|||||||
max_backoff=5, retries=5):
|
max_backoff=5, retries=5):
|
||||||
self.url = url
|
self.url = url
|
||||||
self.token = token
|
self.token = token
|
||||||
|
self.attempts = 0 # needed in swif-dispersion-populate
|
||||||
self.starting_backoff = starting_backoff
|
self.starting_backoff = starting_backoff
|
||||||
self.max_backoff = max_backoff
|
self.max_backoff = max_backoff
|
||||||
self.retries = retries
|
self.retries = retries
|
||||||
@ -796,14 +797,14 @@ class SimpleClient(object):
|
|||||||
|
|
||||||
def retry_request(self, method, **kwargs):
|
def retry_request(self, method, **kwargs):
|
||||||
retries = kwargs.pop('retries', self.retries)
|
retries = kwargs.pop('retries', self.retries)
|
||||||
attempts = 0
|
self.attempts = 0
|
||||||
backoff = self.starting_backoff
|
backoff = self.starting_backoff
|
||||||
while attempts <= retries:
|
while self.attempts <= retries:
|
||||||
attempts += 1
|
self.attempts += 1
|
||||||
try:
|
try:
|
||||||
return self.base_request(method, **kwargs)
|
return self.base_request(method, **kwargs)
|
||||||
except (socket.error, httplib.HTTPException, urllib2.URLError):
|
except (socket.error, httplib.HTTPException, urllib2.URLError):
|
||||||
if attempts > retries:
|
if self.attempts > retries:
|
||||||
raise
|
raise
|
||||||
sleep(backoff)
|
sleep(backoff)
|
||||||
backoff = min(backoff * 2, self.max_backoff)
|
backoff = min(backoff * 2, self.max_backoff)
|
||||||
|
@ -1211,6 +1211,7 @@ class TestSimpleClient(unittest.TestCase):
|
|||||||
request.assert_called_with('http://127.0.0.1?format=json', data=None,
|
request.assert_called_with('http://127.0.0.1?format=json', data=None,
|
||||||
headers={'X-Auth-Token': 'token'})
|
headers={'X-Auth-Token': 'token'})
|
||||||
self.assertEqual([None, None], retval)
|
self.assertEqual([None, None], retval)
|
||||||
|
self.assertEqual(sc.attempts, 2)
|
||||||
|
|
||||||
@mock.patch('eventlet.green.urllib2.urlopen')
|
@mock.patch('eventlet.green.urllib2.urlopen')
|
||||||
def test_get_with_retries_param(self, mock_urlopen):
|
def test_get_with_retries_param(self, mock_urlopen):
|
||||||
|
Loading…
Reference in New Issue
Block a user