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:
Clay Gerrard 2014-06-25 20:21:28 -07:00
parent 53577c5117
commit 0a5b003345
2 changed files with 14 additions and 9 deletions

View File

@ -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:

View File

@ -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)