Fix double request in simple client
The SimpleClient.base_request method need only to call urllib2.urlopen once to get a response from the server. Remove the duplicate call. * fixup tests that were poorly mocking urllib2 * mock eventlet sleep because we're all busy Change-Id: I6da93c689200351e9dbd9416b9c4bf9544571f15
This commit is contained in:
parent
53577c5117
commit
0a5b003345
@ -764,7 +764,6 @@ class SimpleClient(object):
|
|||||||
|
|
||||||
req = urllib2.Request(url, headers=headers, data=contents)
|
req = urllib2.Request(url, headers=headers, data=contents)
|
||||||
req.get_method = lambda: method
|
req.get_method = lambda: method
|
||||||
urllib2.urlopen(req)
|
|
||||||
conn = urllib2.urlopen(req)
|
conn = urllib2.urlopen(req)
|
||||||
body = conn.read()
|
body = conn.read()
|
||||||
try:
|
try:
|
||||||
|
@ -1130,6 +1130,7 @@ class TestSimpleClient(unittest.TestCase):
|
|||||||
logger = FakeLogger()
|
logger = FakeLogger()
|
||||||
retval = sc.retry_request(
|
retval = sc.retry_request(
|
||||||
'GET', headers={'content-length': '123'}, logger=logger)
|
'GET', headers={'content-length': '123'}, logger=logger)
|
||||||
|
self.assertEqual(urlopen.call_count, 1)
|
||||||
request.assert_called_with('http://127.0.0.1?format=json',
|
request.assert_called_with('http://127.0.0.1?format=json',
|
||||||
headers={'content-length': '123'},
|
headers={'content-length': '123'},
|
||||||
data=None)
|
data=None)
|
||||||
@ -1181,25 +1182,30 @@ class TestSimpleClient(unittest.TestCase):
|
|||||||
def test_get_with_retries_all_failed(self, request, urlopen):
|
def test_get_with_retries_all_failed(self, request, urlopen):
|
||||||
# Simulate a failing request, ensure retries done
|
# Simulate a failing request, ensure retries done
|
||||||
request.return_value.get_type.return_value = "http"
|
request.return_value.get_type.return_value = "http"
|
||||||
request.side_effect = urllib2.URLError('')
|
urlopen.side_effect = urllib2.URLError('')
|
||||||
urlopen.return_value.read.return_value = ''
|
|
||||||
sc = internal_client.SimpleClient(url='http://127.0.0.1', retries=1)
|
sc = internal_client.SimpleClient(url='http://127.0.0.1', retries=1)
|
||||||
|
with mock.patch('swift.common.internal_client.sleep') as mock_sleep:
|
||||||
self.assertRaises(urllib2.URLError, sc.retry_request, 'GET')
|
self.assertRaises(urllib2.URLError, sc.retry_request, 'GET')
|
||||||
|
self.assertEqual(mock_sleep.call_count, 1)
|
||||||
self.assertEqual(request.call_count, 2)
|
self.assertEqual(request.call_count, 2)
|
||||||
|
self.assertEqual(urlopen.call_count, 2)
|
||||||
|
|
||||||
@mock.patch('eventlet.green.urllib2.urlopen')
|
@mock.patch('eventlet.green.urllib2.urlopen')
|
||||||
@mock.patch('eventlet.green.urllib2.Request')
|
@mock.patch('eventlet.green.urllib2.Request')
|
||||||
def test_get_with_retries(self, request, urlopen):
|
def test_get_with_retries(self, request, urlopen):
|
||||||
# First request fails, retry successful
|
# First request fails, retry successful
|
||||||
request.return_value.get_type.return_value = "http"
|
request.return_value.get_type.return_value = "http"
|
||||||
urlopen.return_value.read.return_value = ''
|
mock_resp = mock.MagicMock()
|
||||||
req = urllib2.Request('http://127.0.0.1', method='GET')
|
mock_resp.read.return_value = ''
|
||||||
request.side_effect = [urllib2.URLError(''), req]
|
urlopen.side_effect = [urllib2.URLError(''), mock_resp]
|
||||||
sc = internal_client.SimpleClient(url='http://127.0.0.1', retries=1,
|
sc = internal_client.SimpleClient(url='http://127.0.0.1', retries=1,
|
||||||
token='token')
|
token='token')
|
||||||
|
|
||||||
|
with mock.patch('swift.common.internal_client.sleep') as mock_sleep:
|
||||||
retval = sc.retry_request('GET')
|
retval = sc.retry_request('GET')
|
||||||
self.assertEqual(request.call_count, 3)
|
self.assertEqual(mock_sleep.call_count, 1)
|
||||||
|
self.assertEqual(request.call_count, 2)
|
||||||
|
self.assertEqual(urlopen.call_count, 2)
|
||||||
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)
|
||||||
|
Loading…
Reference in New Issue
Block a user