Upload the contribution of vstf as bottleneck network framework.
[bottlenecks.git] / vstf / vstf / controller / fabricant.py
1 from vstf.rpc_frame_work import constant as const
2 import vstf.common.constants as cst
3
4
5 class Fabricant(object):
6     def __init__(self, target, conn):
7         self.conn = conn
8         self.target = target
9
10         self.all_commands = self.declare_commands
11         self.instance_commands()
12
13     @property
14     def declare_commands(self):
15         driver = {"install_drivers", "clean_drivers", "autoneg_on", "autoneg_off", "autoneg_query"}
16
17         builder = {"build_env", "clean_env"}
18
19         cpu = {"affctl_load", "affctl_list", "run_cpuwatch", "kill_cpuwatch"}
20
21         perf = {"perf_run", "run_vnstat", "kill_vnstat", "force_clean"}
22
23         device_mgr = {"get_device_detail", "list_nic_devices", "get_device_verbose"}
24
25         netns = {"clean_all_namespace", "config_dev", "recover_dev", "ping"}
26
27         collect = {"collect_host_info"}
28
29         cmdline = {"execute"}
30
31         spirent = {"send_packet", "stop_flow", "mac_learning", "run_rfc2544suite", "run_rfc2544_throughput",
32                    "run_rfc2544_frameloss", "run_rfc2544_latency"}
33
34         equalizer = {"get_numa_core", "get_nic_numa", "get_nic_interrupt_proc", "get_vm_info", "bind_cpu",
35                      "catch_thread_info"}
36
37         return driver | cpu | builder | perf | device_mgr | netns | cmdline | collect | spirent | equalizer
38
39     def instance_commands(self):
40         for command in self.all_commands:
41             setattr(self, command, self.__transfer_msg(command))
42
43     def __transfer_msg(self, command):
44         def infunc(timeout=cst.TIMEOUT, **kwargs):
45             msg = self.conn.make_msg(command, **kwargs)
46             return self.conn.call(msg, self.target, timeout)
47
48         infunc.__name__ = command
49         return infunc