############################################################################## # Copyright (c) 2016 Huawei Technologies Co.,Ltd and others. # # All rights reserved. This program and the accompanying materials # are made available under the terms of the Apache License, Version 2.0 # which accompanies this distribution, and is available at # http://www.apache.org/licenses/LICENSE-2.0 ############################################################################## from __future__ import absolute_import import logging import uuid from api.utils import influx as influx_utils from api.utils import common as common_utils from api.database.handlers import TasksHandler logger = logging.getLogger(__name__) def default(args): return getResult(args) def getResult(args): try: task_id = args['task_id'] uuid.UUID(task_id) except KeyError: message = 'task_id must be provided' return common_utils.error_handler(message) task = TasksHandler().get_task_by_taskid(task_id) def _unfinished(): return common_utils.result_handler(0, []) def _finished(): testcases = task.details.split(',') def get_data(testcase): query_template = "select * from %s where task_id='%s'" query_sql = query_template % (testcase, task_id) data = common_utils.translate_to_str(influx_utils.query(query_sql)) return data result = {k: get_data(k) for k in testcases} return common_utils.result_handler(1, result) def _error(): return common_utils.result_handler(2, task.error) try: status = task.status switcher = { 0: _unfinished, 1: _finished, 2: _error } return switcher.get(status, lambda: 'nothing')() except IndexError: return common_utils.error_handler('no such task')