summaryrefslogtreecommitdiff
path: root/test-cli/test/tests/qduplex_ser.py
blob: 46fb5db3bfe8dd0d158afb47e6c512dd23045b9e (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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import unittest
import uuid
import serial
import time


class Qduplex(unittest.TestCase):
    params = None

    def __init__(self, testname, testfunc, varlist):
        self.params = varlist
        super(Qduplex, self).__init__(testfunc)
        if "port1" in varlist:
            self.__port1 = varlist["port1"]
        else:
            raise Exception('port1 param inside Qduplex must be defined')
        self.__serial1 = serial.Serial(self.__port1, timeout=1)

        if "port2" in varlist:
            self.__port2 = varlist["port2"]
        else:
            raise Exception('port2 param inside Qduplex must be defined')
        self.__serial2 = serial.Serial(self.__port2, timeout=1)

        if "baudrate" in varlist:
            self.__serial1.baudrate = varlist["baudrate"]
            self.__serial2.baudrate = varlist["baudrate"]
        else:
            raise Exception('baudrate param inside Qduplex must be defined')

        self._testMethodDoc = testname

    def __del__(self):
        self.__serial1.close()
        self.__serial2.close()

    def execute(self):
        self.__serial1.flushInput()
        self.__serial1.flushOutput()
        self.__serial2.flushInput()
        self.__serial2.flushOutput()
        test_uuid = str(uuid.uuid4()).encode()
        self.__serial1.write(test_uuid)
        time.sleep(0.05)  # there might be a small delay
        if self.__serial2.inWaiting() == 0:
            self.fail("failed: PORT {} wait timeout exceded, wrong communication?".format(self.__port2))
        else:
            if (self.__serial2.readline() != test_uuid):
                self.fail("failed: PORT {} write/read mismatch".format(self.__port2))

        test_uuid = str(uuid.uuid4()).encode()
        self.__serial2.write(test_uuid)
        time.sleep(0.05)  # there might be a small delay
        if self.__serial1.inWaiting() == 0:
            self.fail("failed: PORT {} wait timeout exceded, wrong communication?".format(self.__port1))
        else:
            if (self.__serial1.readline() != test_uuid):
                self.fail("failed: PORT {} write/read mismatch".format(self.__port1))