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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
|
#!/usr/bin/python
#
##############################################################################
# Copyright (c) 2015 Huawei Technologies Co.,Ltd and other.
#
# 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
##############################################################################
#
# This script is used to build dashboard ready json results
# It may be used for all the test case of the Yardstick project
# a new method format_<Test_case>_for_dashboard(results)
# v0.1: basic example with methods for Ping, Iperf, Netperf, Pktgen,
# Fio, Lmbench, Perf, Cyclictest.
#
def get_yardstick_cases():
"""
get the list of the supported test cases
TODO: update the list when adding a new test case for the dashboard
"""
return ["Ping", "Iperf", "Netperf", "Pktgen", "Fio", "Lmbench",
"Perf", "Cyclictest"]
def format_yardstick_for_dashboard(case, results):
"""
generic method calling the method corresponding to the test case
check that the testcase is properly declared first
then build the call to the specific method
"""
if check_yardstick_case_exist(case):
cmd = "format_" + case + "_for_dashboard(results)"
res = eval(cmd)
else:
res = []
print "Test cases not declared"
return res
def check_yardstick_case_exist(case):
"""
check if the testcase exists
if the test case is not defined or not declared in the list
return False
"""
yardstick_cases = get_yardstick_cases()
if (case is None or case not in yardstick_cases):
return False
else:
return True
def _get_test_status_bar(results):
nbTest = 0
nbTestOk = 0
for data in results:
nbTest += 1
records = [record for record in data['details']
if "benchmark" in record
and record["benchmark"]["errors"] != ""]
if len(records) == 0:
nbTestOk += 1
return nbTest, nbTestOk
def format_ping_for_dashboard(results):
"""
Post processing for the Ping test case
"""
test_data = [{'description': 'Ping results for Dashboard'}]
# Graph 1: Test_Duration = f(time)
# ********************************
new_element = []
for data in results:
records = [record["benchmark"]["data"]["rtt"]
for record in data['details']
if "benchmark" in record]
avg_rtt = sum(records) / len(records)
new_element.append({'x': data['creation_date'],
'y': avg_rtt})
test_data.append({'name': "ping duration",
'info': {'type': "graph",
'xlabel': 'time',
'ylabel': 'duration (s)'},
'data_set': new_element})
# Graph 2: bar
# ************
nbTest, nbTestOk = _get_test_status_bar(results)
test_data.append({'name': "ping status",
'info': {"type": "bar"},
'data_set': [{'Nb tests': nbTest,
'Nb Success': nbTestOk}]})
return test_data
def format_iperf_for_dashboard(results):
"""
Post processing for the Iperf test case
"""
test_data = [{'description': 'Iperf results for Dashboard'}]
return test_data
def format_netperf_for_dashboard(results):
"""
Post processing for the Netperf test case
"""
test_data = [{'description': 'Netperf results for Dashboard'}]
return test_data
def format_pktgen_for_dashboard(results):
"""
Post processing for the Pktgen test case
"""
test_data = [{'description': 'Pktgen results for Dashboard'}]
return test_data
def format_fio_for_dashboard(results):
"""
Post processing for the Fio test case
"""
test_data = [{'description': 'Fio results for Dashboard'}]
return test_data
def format_lmbench_for_dashboard(results):
"""
Post processing for the Lmbench test case
"""
test_data = [{'description': 'Lmbench results for Dashboard'}]
return test_data
def format_perf_for_dashboard(results):
"""
Post processing for the Perf test case
"""
test_data = [{'description': 'Perf results for Dashboard'}]
return test_data
def format_cyclictest_for_dashboard(results):
"""
Post processing for the Cyclictest test case
"""
test_data = [{'description': 'Cyclictest results for Dashboard'}]
return test_data
############################ For local test ################################
import json
import os
import requests
def _read_sample_output(filename):
curr_path = os.path.dirname(os.path.abspath(__file__))
output = os.path.join(curr_path, filename)
with open(output) as f:
sample_output = f.read()
result = json.loads(sample_output)
return result
# Copy form functest/testcases/Dashboard/dashboard_utils.py
# and did some minor modification for local test.
def _get_results(db_url, test_criteria):
test_project = test_criteria["project"]
testcase = test_criteria["testcase"]
# Build headers
headers = {'Content-Type': 'application/json'}
# build the request
# if criteria is all => remove criteria
url = db_url + "/results?project=" + test_project + "&case=" + testcase
# Send Request to Test DB
myData = requests.get(url, headers=headers)
# Get result as a json object
myNewData = json.loads(myData.text)
# Get results
myDataResults = myNewData['test_results']
return myDataResults
def _test():
db_url = "http://213.77.62.197"
result = _get_results(db_url,
{"project": "yardstick", "testcase": "Ping"})
print format_ping_for_dashboard(result)
if __name__ == '__main__':
_test()
|