123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- import unittest.mock
- import pytest
- @pytest.mark.parametrize(
- ("frend0", "setting_index"),
- [
- (0b01000, 0),
- (0b01001, 1),
- (0b01111, 7),
- (0b10000, 0),
- (0b10001, 1),
- (0b10111, 7),
- (0b10101, 5),
- ],
- )
- def test__get_power_amplifier_setting_index(transceiver, frend0, setting_index):
- transceiver._spi.xfer.return_value = [15, frend0]
- assert transceiver._get_power_amplifier_setting_index() == setting_index
- transceiver._spi.xfer.assert_called_once_with([0x22 | 0x80, 0])
- @pytest.mark.parametrize(
- ("frend0_before", "frend0_after", "setting_index"),
- [
- (0b01000, 0b01000, 0),
- (0b01000, 0b01001, 1),
- (0b01000, 0b01111, 7),
- (0b10000, 0b10000, 0),
- (0b10000, 0b10001, 1),
- (0b10000, 0b10111, 7),
- ],
- )
- def test__set_power_amplifier_setting_index(
- transceiver, frend0_before, frend0_after, setting_index
- ):
- transceiver._spi.xfer.return_value = [15, 15]
- with unittest.mock.patch.object(
- transceiver, "_read_single_byte", return_value=frend0_before
- ):
- transceiver._set_power_amplifier_setting_index(setting_index)
- transceiver._spi.xfer.assert_called_once_with([0x22 | 0x40, frend0_after])
- @pytest.mark.parametrize("setting_index", (-1, 8, 21))
- def test__set_power_amplifier_setting_index_invalid(transceiver, setting_index):
- with pytest.raises(Exception):
- transceiver._set_power_amplifier_setting_index(setting_index)
- transceiver._spi.xfer.assert_not_called()
|