Merge "[docs] Update mailing list to use #yardstick" into stable/gambia
[yardstick.git] / yardstick / common / httpClient.py
index 11c2d75..5b78311 100644 (file)
@@ -9,6 +9,7 @@
 from __future__ import absolute_import
 
 import logging
+import time
 
 from oslo_serialization import jsonutils
 import requests
@@ -18,19 +19,24 @@ logger = logging.getLogger(__name__)
 
 class HttpClient(object):
 
-    def post(self, url, data):
+    def post(self, url, data, timeout=0):
         data = jsonutils.dump_as_bytes(data)
         headers = {'Content-Type': 'application/json'}
-        try:
-            response = requests.post(url, data=data, headers=headers)
-            result = response.json()
-            logger.debug('The result is: %s', result)
-
-            return result
-        except Exception as e:
-            logger.debug('Failed: %s', e)
-            raise
+        t_end = time.time() + timeout
+        while True:
+            try:
+                response = requests.post(url, data=data, headers=headers)
+                response.raise_for_status()
+                result = response.json()
+                logger.debug('The result is: %s', result)
+                return result
+            except Exception: # pylint: disable=broad-except
+                if time.time() > t_end:
+                    logger.exception('')
+                    raise
+            time.sleep(1)
 
     def get(self, url):
         response = requests.get(url)
+        response.raise_for_status()
         return response.json()