aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Xu <xudan16@huawei.com>2018-08-27 01:52:59 +0000
committerGerrit Code Review <gerrit@opnfv.org>2018-08-27 01:52:59 +0000
commita3d5e939c9fef190f34a60a6ea6c378f9b97ce44 (patch)
tree1c0af039cd1091ded45745662d6ae0e4cdf09980
parentceb367ce04446cef1b2a79420fe1ae0184500737 (diff)
parent701c05ab78d6ca7df03d729351c52483d26f7784 (diff)
Merge "Resolve internal errors 500"
-rw-r--r--opnfv_testapi/resources/result_handlers.py16
1 files changed, 13 insertions, 3 deletions
diff --git a/opnfv_testapi/resources/result_handlers.py b/opnfv_testapi/resources/result_handlers.py
index 1f6ec73..b7b5c2b 100644
--- a/opnfv_testapi/resources/result_handlers.py
+++ b/opnfv_testapi/resources/result_handlers.py
@@ -245,9 +245,19 @@ class ResultsUploadHandler(ResultsCLHandler):
@raise 404: pod/project/testcase not exist
@raise 400: body/pod_name/project_name/case_name not provided
"""
- fileinfo = self.request.files['file'][0]
- tar_in = tarfile.open(fileobj=io.BytesIO(fileinfo['body']),
- mode="r:gz")
+ file_array = self.request.files.get('file', None)
+ if file_array is None:
+ msg = 'Please upload a file.'
+ self.finish_request({'code': 403, 'msg': msg})
+ return
+ fileinfo = file_array[0]
+ try:
+ tar_in = tarfile.open(fileobj=io.BytesIO(fileinfo['body']),
+ mode="r:gz")
+ except tarfile.ReadError:
+ msg = 'Please upload a valid gzip file.'
+ self.finish_request({'code': 403, 'msg': msg})
+ return
try:
results = tar_in.extractfile('results/results.json').read()
except KeyError: