-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathtestCaseSuite.py
167 lines (140 loc) · 5.4 KB
/
testCaseSuite.py
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
#******************************************************************************
# * Copyright (c) 2019, XtremeDV. All rights reserved.
# *
# * Licensed under the Apache License, Version 2.0 (the "License");
# * you may not use this file except in compliance with the License.
# * You may obtain a copy of the License at
# *
# * http://www.apache.org/licenses/LICENSE-2.0
# *
# * Unless required by applicable law or agreed to in writing, software
# * distributed under the License is distributed on an "AS IS" BASIS,
# * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# * See the License for the specific language governing permissions and
# * limitations under the License.
# *
# * Author: Jude Zhang, Email: zhajio.1988@gmail.com
# *******************************************************************************
import os
import sys
import ostools
from test_report import (PASSED, WARNED, FAILED)
from globals import *
class testcaseSuite(object):
"""
A test case to be run in an independent simulation
"""
def __init__(self, testsWordDir, simCmd, simulator_if):
self._dir = testsWordDir
self._simCmd = simCmd
self._test = os.path.basename(testsWordDir)
self.name = os.path.basename(testsWordDir)
self._run = TestRun(simulator_if=simulator_if,
testWordDir=self._dir,
simCmd = self._simCmd,
test_cases=[self._test])
@property
def test_result_file(self):
return self._run.get_test_result()
@property
def test_information(self):
"""
Returns the test information
"""
return self._test
def run(self, *args, **kwargs):
"""
Run the test case using the output_path
"""
results = self._run.run(*args, **kwargs)
return results
class TestRun(object):
"""
A single simulation run yielding the results for one or several test cases
"""
def __init__(self, simulator_if, testWordDir, simCmd, test_cases):
self._simulator_if = simulator_if
self._testWordDir = testWordDir
self._simCmd = simCmd
self._test_cases = test_cases
def set_test_cases(self, test_cases):
self._test_cases = test_cases
def get_test_result(self):
return get_result_file_name(self._testWordDir)
def run(self):
"""
Run selected test cases within the test suite
Returns a dictionary of test results
"""
results = {}
for name in self._test_cases:
results[name] = {}
results[name]['reasonMsg'] = ''
results[name]['status'] = FAILED
# Ensure result file exists
ostools.write_file(get_result_file_name(self._testWordDir), "")
sim_ok = self._simulate()
results = self._read_test_results(file_name=get_result_file_name(self._testWordDir))
# Do not run post check unless all passed
for status in results.values():
if status != PASSED:
return results
#if not self._config.call_post_check(output_path, read_output):
# for name in self._test_cases:
# results[name] = FAILED
return results
def _simulate(self):
"""
Run simulation
"""
return self._simulator_if.simulate(
testWordDir=self._testWordDir,
simCmd = self._simCmd)
def _read_test_results(self, file_name):
"""
Read test results from yasa_results file
"""
results = {}
for name in self._test_cases:
results[name] = {}
results[name]['reasonMsg'] = ''
results[name]['status'] = FAILED
if not ostools.file_exists(file_name):
return results
test_results = ostools.read_file(file_name)
(userSimCheckFunc, userSimCheckFile) = userSimCheck()
if userSimCheckFile:
sys.path.append(os.path.dirname(userSimCheckFile))
from userSimCheck import userSimCheck as simCheck
checker=simCheck()
else:
checker= self._simulator_if.simCheck
#elif self._simulator_if.name =='vcs':
# from Simulator.vcsInterface import vcsSimCheck
# checker=vcsSimCheck()
#elif self._simulator_if.name =='irun':
# from Simulator.incisiveInterface import irunSimCheck
# checker=irunSimCheck()
#elif self._simulator_if.name =='xrun':
# from Simulator.xceliumInterface import xrunSimCheck
# checker=xrunSimCheck()
checker.resetStatus()
for line in test_results.splitlines():
line = line.strip()
checker.check(line)
status, reasonMsg = checker.status
for test_name in self._test_cases:
if status == 'PASS':
results[test_name]['status'] = PASSED
else:
results[test_name]['reasonMsg'] = reasonMsg
if status == 'WARN':
results[test_name]['status'] = WARNED
elif status == 'FAIL':
results[test_name]['status'] = FAILED
for test_name in results:
if test_name not in self._test_cases:
raise RuntimeError("Got unknown test case %s" % test_name)
return results
def get_result_file_name(output_path):
return os.path.join(output_path, "sim.log")