Merge "Correct failure message output when downloading"

This commit is contained in:
Jenkins 2017-03-13 17:33:33 +00:00 committed by Gerrit Code Review
commit 0e7c8ddaf2
4 changed files with 27 additions and 7 deletions

View File

@ -143,6 +143,7 @@ class ImageDownloadError(RESTError):
def __init__(self, image_id, msg): def __init__(self, image_id, msg):
details = 'Download of image id {} failed: {}'.format(image_id, msg) details = 'Download of image id {} failed: {}'.format(image_id, msg)
self.secondary_message = msg
super(ImageDownloadError, self).__init__(details) super(ImageDownloadError, self).__init__(details)

View File

@ -204,17 +204,15 @@ class ImageDownload(object):
failtime = time.time() - self._time failtime = time.time() - self._time
log_msg = ('URL: {}; time: {} ' log_msg = ('URL: {}; time: {} '
'seconds. Error: {}').format( 'seconds. Error: {}').format(
url, failtime, e.details) url, failtime, e.secondary_message)
LOG.warning('Image download failed. %s', log_msg) LOG.warning(log_msg)
details += log_msg details.append(log_msg)
continue continue
else: else:
break break
else: else:
details = '/n'.join(details) details = '\n '.join(details)
msg = ('Image download failed for all URLs with following errors: ' raise errors.ImageDownloadError(image_info['id'], details)
'{}'.format(details))
raise errors.ImageDownloadError(image_info['id'], msg)
def _download_file(self, image_info, url): def _download_file(self, image_info, url):
"""Opens a download stream for the given URL. """Opens a download stream for the given URL.

View File

@ -899,3 +899,21 @@ class TestImageDownload(test_base.BaseTestCase):
cert=None, verify=True, cert=None, verify=True,
stream=True, proxies={}) stream=True, proxies={})
self.assertEqual(image_info['checksum'], image_download.md5sum()) self.assertEqual(image_info['checksum'], image_download.md5sum())
@mock.patch('time.time', autospec=True)
@mock.patch('requests.get', autospec=True)
def test_download_image_fail(self, requests_mock, time_mock):
response = requests_mock.return_value
response.status_code = 401
response.text = 'Unauthorized'
time_mock.return_value = 0.0
image_info = _build_fake_image_info()
msg = ('Error downloading image: Download of image id fake_id failed: '
'URL: http://example.org; time: 0.0 seconds. Error: '
'Received status code 401 from http://example.org, expected '
'200. Response body: Unauthorized')
self.assertRaisesRegexp(errors.ImageDownloadError, msg,
standby.ImageDownload, image_info)
requests_mock.assert_called_once_with(image_info['urls'][0],
cert=None, verify=True,
stream=True, proxies={})

View File

@ -0,0 +1,3 @@
---
fixes:
- Correct message output when failed to download image.