test_cc1101.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. # python-cc1101 - Python Library to Transmit RF Signals via C1101 Transceivers
  2. #
  3. # Copyright (C) 2020 Fabian Peter Hammerle <fabian@hammerle.me>
  4. #
  5. # This program is free software: you can redistribute it and/or modify
  6. # it under the terms of the GNU General Public License as published by
  7. # the Free Software Foundation, either version 3 of the License, or
  8. # any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program. If not, see <https://www.gnu.org/licenses/>.
  17. import unittest.mock
  18. import pytest
  19. import cc1101
  20. import cc1101.options
  21. # pylint: disable=protected-access
  22. _FREQUENCY_CONTROL_WORD_HERTZ_PARAMS = [
  23. ([0x10, 0xA7, 0x62], 433000000),
  24. ([0x10, 0xAB, 0x85], 433420000),
  25. ([0x10, 0xB1, 0x3B], 434000000),
  26. ([0x21, 0x62, 0x76], 868000000),
  27. ]
  28. @pytest.mark.parametrize(
  29. ("control_word", "hertz"), _FREQUENCY_CONTROL_WORD_HERTZ_PARAMS
  30. )
  31. def test__frequency_control_word_to_hertz(control_word, hertz):
  32. assert cc1101.CC1101._frequency_control_word_to_hertz(
  33. control_word
  34. ) == pytest.approx(hertz, abs=200)
  35. @pytest.mark.parametrize(
  36. ("control_word", "hertz"), _FREQUENCY_CONTROL_WORD_HERTZ_PARAMS
  37. )
  38. def test__hertz_to_frequency_control_word(control_word, hertz):
  39. assert cc1101.CC1101._hertz_to_frequency_control_word(hertz) == control_word
  40. _SYMBOL_RATE_MANTISSA_EXPONENT_REAL_PARAMS = [
  41. # > The default values give a data rate of 115.051 kBaud
  42. # > (closest setting to 115.2 kBaud), assuming a 26.0 MHz crystal.
  43. (34, 12, 115051),
  44. (34, 12 + 1, 115051 * 2),
  45. (34, 12 - 1, 115051 / 2),
  46. ]
  47. @pytest.mark.parametrize(
  48. ("mantissa", "exponent", "real"), _SYMBOL_RATE_MANTISSA_EXPONENT_REAL_PARAMS
  49. )
  50. def test__symbol_rate_floating_point_to_real(mantissa, exponent, real):
  51. assert cc1101.CC1101._symbol_rate_floating_point_to_real(
  52. mantissa=mantissa, exponent=exponent
  53. ) == pytest.approx(real, rel=1e-5)
  54. @pytest.mark.parametrize(
  55. ("mantissa", "exponent", "real"), _SYMBOL_RATE_MANTISSA_EXPONENT_REAL_PARAMS
  56. )
  57. def test__symbol_rate_real_to_floating_point(mantissa, exponent, real):
  58. assert cc1101.CC1101._symbol_rate_real_to_floating_point(real) == (
  59. mantissa,
  60. exponent,
  61. )
  62. def test_get_packet_length_bytes(transceiver):
  63. xfer_mock = transceiver._spi.xfer
  64. xfer_mock.return_value = [0, 8]
  65. assert transceiver.get_packet_length_bytes() == 8
  66. xfer_mock.assert_called_once_with([0x06 | 0x80, 0])
  67. @pytest.mark.parametrize("packet_length", [21])
  68. def test_set_packet_length_bytes(transceiver, packet_length):
  69. xfer_mock = transceiver._spi.xfer
  70. xfer_mock.return_value = [15, 15]
  71. transceiver.set_packet_length_bytes(packet_length)
  72. xfer_mock.assert_called_once_with([0x06 | 0x40, packet_length])
  73. @pytest.mark.parametrize("packet_length", [-21, 0, 256, 1024])
  74. def test_set_packet_length_bytes_fail(transceiver, packet_length):
  75. with pytest.raises(Exception):
  76. transceiver.set_packet_length_bytes(packet_length)
  77. transceiver._spi.xfer.assert_not_called()
  78. @pytest.mark.parametrize(
  79. ("pktctrl0", "expected_mode"),
  80. (
  81. (0b00000000, cc1101.options.PacketLengthMode.FIXED),
  82. (0b00000001, cc1101.options.PacketLengthMode.VARIABLE),
  83. (0b01000100, cc1101.options.PacketLengthMode.FIXED),
  84. (0b01000101, cc1101.options.PacketLengthMode.VARIABLE),
  85. ),
  86. )
  87. def test_get_packet_length_mode(transceiver, pktctrl0, expected_mode):
  88. xfer_mock = transceiver._spi.xfer
  89. xfer_mock.return_value = [0, pktctrl0]
  90. assert transceiver.get_packet_length_mode() == expected_mode
  91. xfer_mock.assert_called_once_with([0x08 | 0x80, 0])
  92. @pytest.mark.parametrize(
  93. ("pktctrl0_before", "pktctrl0_after", "mode"),
  94. (
  95. (0b00000000, 0b00000000, cc1101.options.PacketLengthMode.FIXED),
  96. (0b00000001, 0b00000000, cc1101.options.PacketLengthMode.FIXED),
  97. (0b00000001, 0b00000001, cc1101.options.PacketLengthMode.VARIABLE),
  98. (0b00000010, 0b00000000, cc1101.options.PacketLengthMode.FIXED),
  99. (0b00000010, 0b00000001, cc1101.options.PacketLengthMode.VARIABLE),
  100. (0b01000100, 0b01000100, cc1101.options.PacketLengthMode.FIXED),
  101. (0b01000100, 0b01000101, cc1101.options.PacketLengthMode.VARIABLE),
  102. (0b01000101, 0b01000100, cc1101.options.PacketLengthMode.FIXED),
  103. (0b01000101, 0b01000101, cc1101.options.PacketLengthMode.VARIABLE),
  104. ),
  105. )
  106. def test_set_packet_length_mode(transceiver, pktctrl0_before, pktctrl0_after, mode):
  107. xfer_mock = transceiver._spi.xfer
  108. xfer_mock.return_value = [15, 15]
  109. with unittest.mock.patch.object(
  110. transceiver, "_read_single_byte", return_value=pktctrl0_before
  111. ):
  112. transceiver.set_packet_length_mode(mode)
  113. xfer_mock.assert_called_once_with([0x08 | 0x40, pktctrl0_after])