123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- # python-cc1101 - Python Library to Transmit RF Signals via CC1101 Transceivers
- #
- # Copyright (C) 2020 Fabian Peter Hammerle <fabian@hammerle.me>
- #
- # This program is free software: you can redistribute it and/or modify
- # it under the terms of the GNU General Public License as published by
- # the Free Software Foundation, either version 3 of the License, or
- # any later version.
- #
- # This program is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- # GNU General Public License for more details.
- #
- # You should have received a copy of the GNU General Public License
- # along with this program. If not, see <https://www.gnu.org/licenses/>.
- import unittest.mock
- import pytest
- # pylint: disable=protected-access
- @pytest.mark.parametrize(
- ("mdmcfg4", "real"),
- [
- (0b10001100, 203e3),
- (0b10001010, 203e3),
- (0b10001110, 203e3),
- (0b11111100, 58e3),
- (0b01011100, 325e3),
- ],
- )
- def test__get_filter_bandwidth_hertz(transceiver, mdmcfg4, real):
- transceiver._spi.xfer.return_value = [15, mdmcfg4]
- assert transceiver._get_filter_bandwidth_hertz() == pytest.approx(real, rel=1e-3)
- transceiver._spi.xfer.assert_called_once_with([0x10 | 0x80, 0])
- @pytest.mark.parametrize(
- ("mdmcfg4_before", "mdmcfg4_after", "exponent", "mantissa"),
- [
- (0b00001010, 0b10111010, 0b10, 0b11),
- (0b00001100, 0b01001100, 0b01, 0b00),
- (0b00001100, 0b10111100, 0b10, 0b11),
- (0b00001100, 0b11011100, 0b11, 0b01),
- (0b01011100, 0b11011100, 0b11, 0b01),
- (0b11111100, 0b11011100, 0b11, 0b01),
- ],
- )
- def test__set_filter_bandwidth(
- transceiver, mdmcfg4_before, mdmcfg4_after, exponent, mantissa
- ):
- transceiver._spi.xfer.return_value = [15, 15]
- with unittest.mock.patch.object(
- transceiver, "_read_single_byte", return_value=mdmcfg4_before
- ):
- transceiver._set_filter_bandwidth(mantissa=mantissa, exponent=exponent)
- transceiver._spi.xfer.assert_called_once_with([0x10 | 0x40, mdmcfg4_after])
- @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])
|