summaryrefslogtreecommitdiffstats
path: root/glucometerutils/drivers/tests/test_contourusb.py
blob: 107b4d4e18797184315a4b0d2f80d9a34e1490cb (plain) (blame)
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
108
109
110
111
112
113
# SPDX-FileCopyrightText: 2013 The glucometerutils Authors
#
# SPDX-License-Identifier: MIT

"""Tests for the common ContourUSB functions.."""

# pylint: disable=protected-access,missing-docstring

from unittest.mock import Mock

from absl.testing import absltest

from glucometerutils.support import contourusb


class TestContourUSB(absltest.TestCase):
    header_record = b"\x04\x021H|\\^&||7w3LBL|Bayer7390^01.24\\01.04\\09.02.20^7390-2336773^7403-|A=1^C=63^G=1^I=0200^R=0^S=1^U=0^V=10600^X=070070070070180130150250^Y=360126090050099050300089^Z=1|1714||||||1|201909221304\r\x17D7\r\n\x05"

    mock_dev = Mock()

    def test_get_datetime(self):
        import datetime

        self.datetime = "201908071315"  # returned by
        self.assertEqual(
            datetime.datetime(2019, 8, 7, 13, 15),
            contourusb.ContourHidDevice.get_datetime(self),
        )

    def test_RECORD_FORMAT_match(self):
        # first decode the header record frame
        header_record_decoded = self.header_record.decode()
        stx = header_record_decoded.find("\x02")

        _RECORD_FORMAT = contourusb._RECORD_FORMAT
        result = _RECORD_FORMAT.match(header_record_decoded[stx:]).group("text")

        self.assertEqual(
            "H|\\^&||7w3LBL|Bayer7390^01.24\\01.04\\09.02.20^7390-2336773^7403-|A=1^C=63^G=1^I=0200^R=0^S=1^U=0^V=10600^X=070070070070180130150250^Y=360126090050099050300089^Z=1|1714||||||1|201909221304",
            result,
        )

    def test_parse_header_record(self):
        _RECORD_FORMAT = contourusb._RECORD_FORMAT

        header_record_decoded = self.header_record.decode()
        stx = header_record_decoded.find("\x02")

        result = _RECORD_FORMAT.match(header_record_decoded[stx:]).group("text")
        contourusb.ContourHidDevice.parse_header_record(self.mock_dev, result)

        self.assertEqual(self.mock_dev.field_del, "\\")
        self.assertEqual(self.mock_dev.repeat_del, "^")
        self.assertEqual(self.mock_dev.component_del, "&")
        self.assertEqual(self.mock_dev.escape_del, "|")

        self.assertEqual(self.mock_dev.product_code, "Bayer7390")

        self.assertEqual(self.mock_dev.dig_ver, "01.24")
        self.assertEqual(self.mock_dev.anlg_ver, "01.04")
        self.assertEqual(self.mock_dev.agp_ver, "09.02.20")
        self.assertEqual(self.mock_dev.serial_num, "7390-2336773")
        self.assertEqual(self.mock_dev.sku_id, "7403-")
        self.assertEqual(self.mock_dev.res_marking, "1")
        self.assertEqual(self.mock_dev.config_bits, "63")
        self.assertEqual(self.mock_dev.lang, "1")
        self.assertEqual(self.mock_dev.interv, "0200")
        self.assertEqual(self.mock_dev.ref_method, "0")
        self.assertEqual(self.mock_dev.internal, "1")
        self.assertEqual(self.mock_dev.unit, "0")
        self.assertEqual(self.mock_dev.lo_bound, "10")
        self.assertEqual(self.mock_dev.hi_bound, "600")

        self.assertEqual(self.mock_dev.hypo_limit, "070")
        self.assertEqual(self.mock_dev.overall_low, "070")
        self.assertEqual(self.mock_dev.pre_food_low, "070")
        self.assertEqual(self.mock_dev.post_food_low, "070")
        self.assertEqual(self.mock_dev.overall_high, "180")
        self.assertEqual(self.mock_dev.pre_food_high, "130")
        self.assertEqual(self.mock_dev.post_food_high, "150")
        self.assertEqual(self.mock_dev.hyper_limit, "250")

        self.assertEqual(self.mock_dev.upp_hyper, "360")
        self.assertEqual(self.mock_dev.low_hyper, "126")
        self.assertEqual(self.mock_dev.upp_hypo, "090")
        self.assertEqual(self.mock_dev.low_hypo, "050")
        self.assertEqual(self.mock_dev.upp_low_target, "099")
        self.assertEqual(self.mock_dev.low_low_target, "050")
        self.assertEqual(self.mock_dev.upp_hi_target, "300")
        self.assertEqual(self.mock_dev.low_hi_target, "089")
        self.assertEqual(self.mock_dev.trends, "1")
        self.assertEqual(self.mock_dev.total, "1714")
        self.assertEqual(self.mock_dev.spec_ver, "1")

        self.assertEqual(self.mock_dev.datetime, "201909221304")

    # TO-DO checksum and checkframe unit tests

    def test_parse_result_record(self):
        # first decode the header record frame
        result_record = "R|8|^^^Glucose|133|mg/dL^P||B/X||201202052034"
        result_dict = contourusb.ContourHidDevice.parse_result_record(
            self.mock_dev, result_record
        )

        self.assertEqual(result_dict["record_type"], "R")
        self.assertEqual(result_dict["seq_num"], "8")
        self.assertEqual(result_dict["test_id"], "Glucose")
        self.assertEqual(result_dict["value"], "133")
        self.assertEqual(result_dict["unit"], "mg/dL")
        self.assertEqual(result_dict["ref_method"], "P")
        self.assertEqual(result_dict["markers"], "B/X")
        self.assertEqual(result_dict["datetime"], "201202052034")