-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmock_cli.py
107 lines (86 loc) · 3.42 KB
/
mock_cli.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
#! /usr/bin/env python3
# Copyright (c) 2020 HAW Hamburg
#
# This file is subject to the terms and conditions of the MIT License. See the
# file LICENSE in the top level directory for more details.
# SPDX-License-Identifier: MIT
"""Mock cli to a mock device.
Usage:
mock_cli.py [-h]
[--loglevel LOGLEVEL]
[--logmodules LOGMODULES [LOGMODULES ...]]
[--port PORT]
[--mm_path MM_PATH]
optional arguments:
-h, --help show this help message and exit
--loglevel LOGLEVEL Python logger log level, defaults to INFO.
--logmodules LOGMODULES [LOGMODULES ...]
Modules to enable logging.
--port PORT, -p PORT Serial device name, defaults to None.
--mm_path MM_PATH Path to memory map, defaults to None.
"""
import logging
import argparse
from mock_pal.mock_dev import MockDev, VirtualPortRunner
from mock_pal.mock_dev import log_level_module_control
from mock_pal.mock_if import MockIf
from mm_pal import MmCmd, serial_connect_wizard
class MockCli(MmCmd):
"""Command loop for the mock interface."""
prompt = "MOCK: "
def __init__(self, **kwargs):
"""Mock cli command loop wrapper.
Args:
**kwargs:
"""
self.logger = logging.getLogger(self.__class__.__name__)
hist = kwargs.pop('persistent_history_file', None)
cmd_kwargs = {"persistent_history_file": hist}
if 'dev_driver' in kwargs:
super().__init__(kwargs['dev_driver'], **cmd_kwargs)
return
if 'driver' in kwargs:
super().__init__(MockIf(driver=kwargs['driver']), **cmd_kwargs)
return
if "port" not in kwargs:
super().__init__(serial_connect_wizard(MockIf, **kwargs),
**cmd_kwargs)
else:
super().__init__(MockIf(**kwargs), **cmd_kwargs)
self.logger.debug("__init__(%r, %r)", kwargs, cmd_kwargs)
def do_special_cmd(self, arg):
"""Do nothing but show how to use special commands.
Usage:
special_cmd
"""
self.logger.debug("do_special_cmd(arg=%r)", arg)
self.poutput(self.dev_driver.special_cmd())
def main():
"""Run MockCli command loop."""
parser = argparse.ArgumentParser()
# pylint: disable=duplicate-code
parser.add_argument('--loglevel', default='INFO',
help='Python logger log level, defaults to INFO.')
parser.add_argument('--logmodules', nargs='+', default=None,
help='Modules to enable logging.')
parser.add_argument('--port', '-p', default=None,
help='Serial device name, defaults to None.')
parser.add_argument('--mm_path', default=None,
help='Path to memory map, defaults to None.')
parser.add_argument('--sim', default=False, action='store_true',
help='Simulate device, defaults to False.')
pargs = parser.parse_args()
log_level_module_control(pargs)
vpr = None
mdev = None
port = pargs.port
if pargs.sim:
vpr = VirtualPortRunner()
mdev = MockDev(port=vpr.mock_port)
mdev.start_thread_loop(func=mdev.run_app_json)
port = vpr.ext_port
MockCli(port=port, mm_path=pargs.mm_path).cmdloop()
if pargs.sim:
mdev.end_thread_loop()
if __name__ == '__main__':
main()