summaryrefslogtreecommitdiffstats
path: root/opnfv_testapi
diff options
context:
space:
mode:
Diffstat (limited to 'opnfv_testapi')
-rw-r--r--opnfv_testapi/resources/result_handlers.py92
-rw-r--r--opnfv_testapi/router/url_mappings.py2
2 files changed, 94 insertions, 0 deletions
diff --git a/opnfv_testapi/resources/result_handlers.py b/opnfv_testapi/resources/result_handlers.py
index d914696..c65c757 100644
--- a/opnfv_testapi/resources/result_handlers.py
+++ b/opnfv_testapi/resources/result_handlers.py
@@ -14,6 +14,7 @@ import tarfile
import io
import re
import uuid
+import memcache
from tornado import gen
from tornado import web
@@ -380,3 +381,94 @@ class ResultsGURHandler(GenericResultHandler):
query = {'_id': objectid.ObjectId(result_id)}
db_keys = []
self._update(query=query, db_keys=db_keys)
+
+#Api for results upload
+class ResultsFileUploadHandler(ResultsCLHandler):
+ @swagger.operation(nickname="uploadTestResult")
+ @web.asynchronous
+ @gen.coroutine
+ def post(self):
+ """
+ @description: upload and create a test result
+ @param body: result to be created
+ @type body: L{ResultCreateRequest}
+ @in body: body
+ @rtype: L{CreateResponse}
+ @return 200: result is created.
+ @raise 404: pod/project/testcase not exist
+ @raise 400: body/pod_name/project_name/case_name not provided
+ """
+ file_array = self.request.files.get('file', None)
+ 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:
+ # Deal with results that are in the 'root' of the tar
+ # file, instead of in results/
+ missing_results_dir = ''
+ tar_files = tar_in.getnames()
+ if 'results/results.json' not in tar_files:
+ missing_results_dir = '/results'
+ results = tar_in.extractfile('results.json').read()
+ else:
+ results = tar_in.extractfile('results/results.json').read()
+ except KeyError:
+ msg = 'Uploaded results must contain at least one passing test.'
+ self.finish_request({'code': 403, 'msg': msg})
+ return
+ # results = results.split('\n')
+ result_ids = []
+ version = ''
+ vnf_type = None
+ vnf_checksum = None
+ try:
+ self.json_args = json.loads(results).copy()
+ openid = self.get_secure_cookie(auth_const.OPENID)
+ if openid:
+ self.json_args['owner'] = openid
+ if self.is_onap:
+ self.json_args['is_onap'] = 'true'
+ vnf_type = self.json_args['vnf_type']
+ vnf_checksum = self.json_args['vnf_checksum']
+ # the result files used in the first release of OVP did not
+ # specify an OVP version
+ if (self.json_args['version'] == 'master'
+ or self.json_args['version'] == 'unknown'):
+ version = '2018.01'
+ else:
+ version = self.json_args['version']
+ build_tag = self.json_args['build_tag']
+ _id = yield self._inner_create()
+ result_ids.append(str(_id))
+ except ValueError:
+ msg = 'Uploaded results don''t appear to contain a '\
+ 'valid results.json file!'
+ self.finish_request({'code': 403, 'msg': msg})
+ return
+ # Build a test id from the build_tag, where this field takes a couple
+ # of different formats between Dovetail NFVI testing and VNF testing.
+ # If a valid UUID isn't part of the build_tag, we will generate one
+ # here.
+ test_id_match = re.search('[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-'
+ '[0-9A-F]{4}-[0-9A-F]{12}', build_tag)
+ if not test_id_match:
+ print('test_id doesn''t look to be a valid UUID, generating a '
+ 'new one...')
+ test_id = str(uuid.uuid4())
+ else:
+ test_id = test_id_match.group(1)
+ log_path = '/home/testapi/logs/%s%s' % (test_id, missing_results_dir)
+ tar_in.extractall(log_path)
+ log_filename = "/home/testapi/logs/log_%s.tar.gz" % (test_id)
+ with open(log_filename, "wb") as tar_out:
+ tar_out.write(fileinfo['body'])
+ resp = {'id': test_id, 'results': result_ids, 'version': version}
+ if vnf_type:
+ resp['vnf_type'] = vnf_type
+ resp['vnf_checksum'] = vnf_checksum
+ self.finish_request(resp)
diff --git a/opnfv_testapi/router/url_mappings.py b/opnfv_testapi/router/url_mappings.py
index f529302..2846819 100644
--- a/opnfv_testapi/router/url_mappings.py
+++ b/opnfv_testapi/router/url_mappings.py
@@ -74,4 +74,6 @@ onap_mappings = [
(r'/api/v1/onap/cvp/applications',
application_handlers.ApplicationsCLHandler, dict(is_onap=True)),
(r'/api/v1/onap/reviews', review_handlers.ReviewsCLHandler),
+ (r'/api/v1/onap/results/upload/data', result_handlers.ResultsFileUploadHandler,
+ dict(is_onap=True)),
]