-
Notifications
You must be signed in to change notification settings - Fork 140
/
Copy pathbenchmarkfactory.py
68 lines (61 loc) · 2.11 KB
/
benchmarkfactory.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
import copy
import itertools
import settings
from benchmark.radosbench import Radosbench
from benchmark.fio import Fio
from benchmark.hsbench import Hsbench
from benchmark.rbdfio import RbdFio
from benchmark.rawfio import RawFio
from benchmark.kvmrbdfio import KvmRbdFio
from benchmark.librbdfio import LibrbdFio
from benchmark.nullbench import Nullbench
from benchmark.cosbench import Cosbench
from benchmark.cephtestrados import CephTestRados
from benchmark.getput import Getput
def get_all(archive, cluster, iteration):
for benchmark, config in sorted(settings.benchmarks.items()):
default = {"benchmark": benchmark,
"iteration": iteration}
for current in all_configs(config):
current.update(default)
yield get_object(archive, cluster, benchmark, current)
def all_configs(config):
"""
return all parameter combinations for config
config: dict - list of params
iterate over all top-level lists in config
"""
cycle_over_lists = []
cycle_over_names = []
default = {}
for param, value in list(config.items()):
# acceptable applies to benchmark as a whole, no need to it to
# the set for permutation
if param == 'acceptable':
default[param] = value
elif isinstance(value, list):
cycle_over_lists.append(value)
cycle_over_names.append(param)
else:
default[param] = value
for permutation in itertools.product(*cycle_over_lists):
current = copy.deepcopy(default)
current.update(list(zip(cycle_over_names, permutation)))
yield current
def get_object(archive, cluster, benchmark, bconfig):
benchmarks = {
'nullbench': Nullbench,
'radosbench': Radosbench,
'fio': Fio,
'hsbench': Hsbench,
'rbdfio': RbdFio,
'kvmrbdfio': KvmRbdFio,
'rawfio': RawFio,
'librbdfio': LibrbdFio,
'cosbench': Cosbench,
'cephtestrados': CephTestRados,
'getput': Getput}
try:
return benchmarks[benchmark](archive, cluster, bconfig)
except KeyError:
return None