1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
#!/usr/bin/env python
# Copyright (c) 2017 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
"""
Resources to retrieve the task results
"""
import errno
import json
import logging
import os
import pkg_resources
import uuid
from flask import jsonify
from flasgger.utils import swag_from
from functest.api.base import ApiResource
from functest.api.common import api_utils
from functest.api.database.v1.handlers import TasksHandler
from functest.utils.constants import CONST
LOGGER = logging.getLogger(__name__)
class V1Task(ApiResource):
""" V1Task Resource class"""
@swag_from(pkg_resources.resource_filename(
'functest', 'api/swagger/task.yaml'))
def get(self, task_id): # pylint: disable=no-self-use
""" GET the result of the task id """
try:
uuid.UUID(task_id)
except ValueError:
return api_utils.result_handler(status=1, data='Invalid task id')
task_handler = TasksHandler()
try:
task = task_handler.get_task_by_taskid(task_id)
except ValueError:
return api_utils.result_handler(status=1, data='No such task id')
status = task.status
LOGGER.debug('Task status is: %s', status)
if status not in ['IN PROGRESS', 'FAIL', 'FINISHED']:
return api_utils.result_handler(status=1,
data='internal server error')
switcher = {'IN PROGRESS': 0, 'FAIL': 1, 'FINISHED': 2}
if status == 'IN PROGRESS':
result = {'status': switcher.get(status), 'result': ''}
elif status == 'FAIL':
result = {'status': switcher.get(status), 'error': task.error}
else:
result = {'status': switcher.get(status),
'result': json.loads(task.result)}
return jsonify(result)
class V1TaskLog(ApiResource):
""" V1TaskLog Resource class"""
@swag_from(pkg_resources.resource_filename(
'functest', 'api/swagger/task_log.yaml'))
def get(self, task_id): # pylint: disable=no-self-use
""" GET the log of the task id """
try:
uuid.UUID(task_id)
except ValueError:
return api_utils.result_handler(status=1, data='Invalid task id')
task_handler = TasksHandler()
try:
task = task_handler.get_task_by_taskid(task_id)
except ValueError:
return api_utils.result_handler(status=1, data='No such task id')
task_log_dir = getattr(CONST, 'dir_results')
# pylint: disable=maybe-no-member
index = int(self._get_args().get('index', 0))
try:
with open(os.path.join(task_log_dir,
'{}.log'.format(task_id)), 'r') as log_file:
log_file.seek(index)
data = log_file.readlines()
index = log_file.tell()
except OSError as err:
if err.errno == errno.ENOENT:
return api_utils.result_handler(
status=1, data='Log file does not exist')
return api_utils.result_handler(
status=1, data='Error with log file')
return_data = {'data': data, 'index': index}
switcher = {'IN PROGRESS': 0, 'FAIL': 1, 'FINISHED': 2}
return api_utils.result_handler(status=switcher.get(task.status),
data=return_data)
|