forked from mordechai/benchmark-runner
-
Notifications
You must be signed in to change notification settings - Fork 0
/
workloads.py
44 lines (36 loc) · 1.29 KB
/
workloads.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
import inspect
import importlib
from benchmark_runner.common.logger.logger_time_stamp import logger_time_stamp, logger
from benchmark_runner.workloads.workloads_operations import WorkloadsOperations
class Workloads(WorkloadsOperations):
"""
This class run workload
"""
def __init__(self):
"""
All inherit from WorkloadsOperations
"""
super().__init__()
@logger_time_stamp
def run(self):
"""
The method run workload
:return:
"""
# kata use pod module - replace kata to pod
workload = self._workload.replace('kata', 'pod')
# load the workload module before doing anything else (in case it fails)
workload_module = importlib.import_module(f'benchmark_runner.workloads.{workload}')
try:
self.initialize_workload()
success = True
# extract workload module and class
for cls in inspect.getmembers(workload_module, inspect.isclass):
if workload.replace('_', '').lower() == cls[0].lower():
if cls[1]().run() == False:
success = False
self.finalize_workload()
return success
except Exception as err:
self.finalize_workload()
raise err