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
|
##############################################################################
# Copyright (c) 2016 ZTE Corp 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
##############################################################################
import json
import importlib
import sys
from utils import logger_utils
logger = logger_utils.QtipLogger('suite_result').get
def get_benchmark_result(benchmark_name, suite_name):
benchmark_indices = importlib.import_module('{0}_benchmarks_indices'.format(suite_name))
methodToCall = getattr(benchmark_indices, '{0}_index'.format(benchmark_name))
return methodToCall()
def get_suite_result(suite_name):
suite_dict = {}
suite_bench_list = {'compute': ['DPI', 'Dhrystone', 'Whetstone', 'SSL', 'RamSpeed'],
'storage': ['FIO'],
'network': ['IPERF']}
temp = 0
l = len(suite_bench_list[suite_name])
for benchmark in suite_bench_list[suite_name]:
try:
suite_dict[benchmark] = get_benchmark_result(benchmark.lower(), suite_name)
temp = temp + float(suite_dict[benchmark]['index'])
except OSError:
l = l - 1
pass
if l == 0:
logger.info("No {0} suite results found".format(suite_name))
return False
else:
suite_index = temp / l
suite_dict_f = {'index': suite_index,
'suite_results': suite_dict}
with open('results/{0}_result.json'.format(suite_name), 'w+') as result_json:
json.dump(suite_dict_f, result_json, indent=4, sort_keys=True)
return True
def main():
get_suite_result(sys.argv[1])
if __name__ == "__main__":
main()
|