1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/dist/tests/if_lib/dut_shell.py

88 lines
2.8 KiB
Python
Raw Normal View History

# Copyright (C) 2018 Kevin Weiss <kevin.weiss@haw-hamburg.de>
#
# This file is subject to the terms and conditions of the GNU Lesser
# General Public License v2.1. See the file LICENSE in the top level
# directory for more details.
"""@package PyToAPI
This module handles parsing of information from RIOT shell base tests.
"""
import logging
from .base_device import BaseDevice
class DutShell(BaseDevice):
"""Parses commands and resposes from the shell."""
COMMAND = 'Command: '
SUCCESS = 'Success: '
ERROR = 'Error: '
TIMEOUT = 'Timeout: '
RESULT_SUCCESS = 'Success'
RESULT_ERROR = 'Error'
RESULT_TIMEOUT = 'Timeout'
@staticmethod
def _try_parse_data(data):
if ('[' in data) and (']' in data):
parsed_data = []
data = data[data.find("[")+1:data.find("]")]
data_list = data.split(', ')
for value in data_list:
try:
parsed_data.append(int(value, 0))
except ValueError:
parsed_data.append(value)
logging.debug(parsed_data)
return parsed_data
return None
def send_cmd(self, send_cmd):
"""Returns a dictionary with information from the event.
msg - The message from the response, only used for information.
cmd - The command sent, used to track what has occured.
data - Parsed information of the data requested.
result - Either success, error or timeout.
"""
self._write(send_cmd)
response = self._read()
cmd_info = {'cmd': send_cmd, 'data': None}
while response != '':
if self.COMMAND in response:
cmd_info['msg'] = response.replace(self.COMMAND, '')
cmd_info['cmd'] = cmd_info['msg'].replace('\n', '')
if self.SUCCESS in response:
clean_msg = response.replace(self.SUCCESS, '')
cmd_info['msg'] = clean_msg.replace('\n', '')
cmd_info['result'] = self.RESULT_SUCCESS
cmd_info['data'] = self._try_parse_data(cmd_info['msg'])
break
if self.ERROR in response:
clean_msg = response.replace(self.ERROR, '')
cmd_info['msg'] = clean_msg.replace('\n', '')
cmd_info['result'] = self.RESULT_ERROR
break
response = self._read()
if response == '':
cmd_info['result'] = self.RESULT_TIMEOUT
logging.debug(self.RESULT_TIMEOUT)
return cmd_info
def test_node():
"""Simple test to ensure commuication with the node."""
b_if = DutShell()
b_if.send_cmd('i2c_get_id')
def main():
"""Tests TestShellIf class"""
logging.getLogger().setLevel(logging.DEBUG)
test_node()
if __name__ == "__main__":
main()