|
@@ -0,0 +1,64 @@
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+import unittest.mock
|
|
|
|
+
|
|
|
|
+import pytest
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+@pytest.mark.parametrize(
|
|
|
|
+ ("mdmcfg4", "exponent"),
|
|
|
|
+ (
|
|
|
|
+ (0b10001100, 12),
|
|
|
|
+ (0b10001001, 9),
|
|
|
|
+ (0b10001111, 15),
|
|
|
|
+ (0b10000000, 0),
|
|
|
|
+ (0b10111100, 12),
|
|
|
|
+ (0b10111111, 15),
|
|
|
|
+ (0b10110000, 0),
|
|
|
|
+ ),
|
|
|
|
+)
|
|
|
|
+def test__get_symbol_rate_exponent(transceiver, mdmcfg4, exponent):
|
|
|
|
+ transceiver._spi.xfer.return_value = [15, mdmcfg4]
|
|
|
|
+ assert transceiver._get_symbol_rate_exponent() == exponent
|
|
|
|
+ transceiver._spi.xfer.assert_called_once_with([0x10 | 0x80, 0])
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+@pytest.mark.parametrize(
|
|
|
|
+ ("mdmcfg4_before", "mdmcfg4_after", "exponent"),
|
|
|
|
+ (
|
|
|
|
+ (0b10001100, 0b10001100, 12),
|
|
|
|
+ (0b10001100, 0b10001111, 15),
|
|
|
|
+ (0b10001100, 0b10000000, 0),
|
|
|
|
+ (0b10001100, 0b10001010, 0b1010),
|
|
|
|
+ (0b01111100, 0b01111100, 12),
|
|
|
|
+ (0b01111100, 0b01111111, 15),
|
|
|
|
+ (0b01111100, 0b01110000, 0),
|
|
|
|
+ (0b01110001, 0b01111100, 12),
|
|
|
|
+ ),
|
|
|
|
+)
|
|
|
|
+def test__set_symbol_rate_exponent(
|
|
|
|
+ transceiver, mdmcfg4_before, mdmcfg4_after, exponent
|
|
|
|
+):
|
|
|
|
+ transceiver._spi.xfer.return_value = [0x0F, 0x0F]
|
|
|
|
+ with unittest.mock.patch.object(
|
|
|
|
+ transceiver, "_read_single_byte", return_value=mdmcfg4_before
|
|
|
|
+ ):
|
|
|
|
+ transceiver._set_symbol_rate_exponent(exponent)
|
|
|
|
+ transceiver._spi.xfer.assert_called_once_with([0x10 | 0x40, mdmcfg4_after])
|