summaryrefslogtreecommitdiff
path: root/test-cli/test/tests/qserial.py
blob: d798578bea3097b73ed3786d75d72a37fb09b69e (plain)
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
import unittest
import uuid
import serial
import time


class Qserial(unittest.TestCase):
    params = None

    def __init__(self, testname, testfunc, varlist):
        self.params = varlist
        super(Qserial, self).__init__(testfunc)
        if "port" in varlist:
            self.__port = varlist["port"]
        else:
            raise Exception('port param inside Qserial must be defined')
        self.__serial = serial.Serial(self.__port, timeout=1)
        if "baudrate" in varlist:
            self.__baudrate = varlist["baudrate"]
        else:
            raise Exception('baudrate param inside Qserial must be defined')
        self._testMethodDoc = testname

    def __del__(self):
        self.__serial.close()

    def execute(self):
        self.__serial.flushInput()
        self.__serial.flushOutput()
        #generate a random uuid
        test_uuid = str(uuid.uuid4()).encode()
        #send the uuid through serial port
        self.__serial.write(test_uuid)
        time.sleep(0.05)  # there might be a small delay
        if self.__serial.inWaiting() == 0:
            self.fail("failed: PORT {} wait timeout exceded, wrong communication?".format(self.__port))
        else:
            # check if what it was sent is equal to what has been received
            if (self.__serial.readline() != test_uuid):
                self.fail("failed: PORT {} write/read mismatch".format(self.__port))