| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257 |
- from homeassistant.components.climate.const import (
- CURRENT_HVAC_COOL,
- CURRENT_HVAC_HEAT,
- CURRENT_HVAC_IDLE,
- HVAC_MODE_COOL,
- HVAC_MODE_HEAT,
- PRESET_AWAY,
- PRESET_HOME,
- SUPPORT_PRESET_MODE,
- SUPPORT_TARGET_TEMPERATURE,
- )
- from homeassistant.components.sensor import SensorDeviceClass
- from homeassistant.const import POWER_WATT, TEMP_CELSIUS
- from ..const import SASWELL_C16_THERMOSTAT_PAYLOAD
- from ..helpers import assert_device_properties_set
- from ..mixins.climate import TargetTemperatureTests
- from ..mixins.lock import BasicLockTests
- from ..mixins.number import MultiNumberTests
- from ..mixins.select import MultiSelectTests
- from ..mixins.sensor import BasicSensorTests
- from ..mixins.switch import BasicSwitchTests
- from .base_device_tests import TuyaDeviceTestCase
- TEMPERATURE_DPS = "2"
- PRESET_DPS = "3"
- UNKNOWN4_DPS = "4"
- CURRENTTEMP_DPS = "5"
- FLOORTEMPLIMIT_DPS = "6"
- INSTALL_DPS = "7"
- FLOORTEMP_DPS = "8"
- HVACMODE_DPS = "9"
- ADAPTIVE_DPS = "10"
- LOCK_DPS = "11"
- SCHED_DPS = "12"
- UNKNOWN14_DPS = "14"
- UNKNOWN15_DPS = "15"
- UNKNOWN17_DPS = "17"
- UNKNOWN21_DPS = "21"
- POWERRATING_DPS = "22"
- UNKNOWN23_DPS = "23"
- HVACACTION_DPS = "24"
- UNKNOWN26_DPS = "26"
- class TestSaswellC16Thermostat(
- BasicLockTests,
- BasicSensorTests,
- BasicSwitchTests,
- MultiNumberTests,
- MultiSelectTests,
- TargetTemperatureTests,
- TuyaDeviceTestCase,
- ):
- __test__ = True
- def setUp(self):
- self.setUpForConfig(
- "saswell_c16_thermostat.yaml", SASWELL_C16_THERMOSTAT_PAYLOAD
- )
- self.subject = self.entities.get("climate")
- self.setUpTargetTemperature(
- TEMPERATURE_DPS,
- self.subject,
- min=5.0,
- max=40.0,
- scale=10,
- step=5,
- )
- self.setUpBasicLock(LOCK_DPS, self.entities.get("lock_child_lock"))
- self.setUpBasicSensor(
- FLOORTEMP_DPS,
- self.entities.get("sensor_floor_temperature"),
- device_class=SensorDeviceClass.TEMPERATURE,
- state_class="measurement",
- unit=TEMP_CELSIUS,
- testdata=(218, 21.8),
- )
- self.setUpBasicSwitch(ADAPTIVE_DPS, self.entities.get("switch_adaptive"))
- self.setUpMultiNumber(
- [
- {
- "name": "number_floor_temperature_limit",
- "dps": FLOORTEMPLIMIT_DPS,
- "min": 20.0,
- "max": 50.0,
- "scale": 10,
- "step": 0.5,
- "unit": TEMP_CELSIUS,
- },
- {
- "name": "number_power_rating",
- "dps": POWERRATING_DPS,
- "max": 3500,
- "unit": POWER_WATT,
- },
- ]
- )
- self.setUpMultiSelect(
- [
- {
- "name": "select_installation",
- "dps": INSTALL_DPS,
- "options": {
- True: "Office",
- False: "Home",
- },
- },
- {
- "name": "select_schedule",
- "dps": SCHED_DPS,
- "options": {
- "5_1_1": "Weekdays+Sat+Sun",
- "7": "Daily",
- },
- },
- ]
- )
- self.mark_secondary(
- [
- "lock_child_lock",
- "sensor_floor_temperature",
- "switch_adaptive",
- "number_floor_temperature_limit",
- "number_power_rating",
- "select_installation",
- "select_schedule",
- ]
- )
- def test_supported_features(self):
- self.assertEqual(
- self.subject.supported_features,
- SUPPORT_TARGET_TEMPERATURE | SUPPORT_PRESET_MODE,
- )
- def test_icon(self):
- self.dps[PRESET_DPS] = "Smart"
- self.assertEqual(self.subject.icon, "mdi:home-thermometer")
- self.dps[PRESET_DPS] = "Manual"
- self.assertEqual(self.subject.icon, "mdi:cursor-pointer")
- self.dps[PRESET_DPS] = "Anti_frozen"
- self.assertEqual(self.subject.icon, "mdi:snowflake-melt")
- self.dps[LOCK_DPS] = True
- self.assertEqual(self.basicLock.icon, "mdi:hand-back-right-off")
- self.dps[LOCK_DPS] = False
- self.assertEqual(self.basicLock.icon, "mdi:hand-back-right")
- def test_temperature_unit(self):
- self.assertEqual(
- self.subject.temperature_unit,
- self.subject._device.temperature_unit,
- )
- def test_current_temperature(self):
- self.dps[CURRENTTEMP_DPS] = 250
- self.assertEqual(self.subject.current_temperature, 25.0)
- def test_hvac_mode(self):
- self.dps[HVACMODE_DPS] = True
- self.assertEqual(self.subject.hvac_mode, HVAC_MODE_COOL)
- self.dps[HVACMODE_DPS] = False
- self.assertEqual(self.subject.hvac_mode, HVAC_MODE_HEAT)
- def test_hvac_modes(self):
- self.assertCountEqual(
- self.subject.hvac_modes,
- [HVAC_MODE_COOL, HVAC_MODE_HEAT],
- )
- async def test_set_hvac_mode_cool(self):
- with self.assertRaises(TypeError):
- await self.subject.async_set_hvac_mode(HVAC_MODE_COOL)
- async def test_set_hvac_mode_heat(self):
- with self.assertRaises(TypeError):
- await self.subject.async_set_hvac_mode(HVAC_MODE_HEAT)
- def test_hvac_action(self):
- self.dps[HVACACTION_DPS] = "Cooling"
- self.assertEqual(self.subject.hvac_action, CURRENT_HVAC_COOL)
- self.dps[HVACACTION_DPS] = "Heating"
- self.assertEqual(self.subject.hvac_action, CURRENT_HVAC_HEAT)
- self.dps[HVACACTION_DPS] = "Standby"
- self.assertEqual(self.subject.hvac_action, CURRENT_HVAC_IDLE)
- def test_preset_mode(self):
- self.dps[PRESET_DPS] = "Smart"
- self.assertEqual(self.subject.preset_mode, PRESET_HOME)
- self.dps[PRESET_DPS] = "Manual"
- self.assertEqual(self.subject.preset_mode, "manual")
- self.dps[PRESET_DPS] = "Anti_frozen"
- self.assertEqual(self.subject.preset_mode, PRESET_AWAY)
- def test_preset_modes(self):
- self.assertCountEqual(
- self.subject.preset_modes,
- [PRESET_HOME, PRESET_AWAY, "manual"],
- )
- async def test_set_preset_to_away(self):
- async with assert_device_properties_set(
- self.subject._device,
- {PRESET_DPS: "Anti_frozen"},
- ):
- await self.subject.async_set_preset_mode(PRESET_AWAY)
- async def test_set_preset_to_home(self):
- async with assert_device_properties_set(
- self.subject._device,
- {PRESET_DPS: "Smart"},
- ):
- await self.subject.async_set_preset_mode(PRESET_HOME)
- async def test_set_preset_to_manual(self):
- async with assert_device_properties_set(
- self.subject._device,
- {PRESET_DPS: "Manual"},
- ):
- await self.subject.async_set_preset_mode("manual")
- def test_extra_state_attributes(self):
- self.dps[UNKNOWN4_DPS] = 4
- self.dps[FLOORTEMPLIMIT_DPS] = 355
- self.dps[INSTALL_DPS] = True
- self.dps[FLOORTEMP_DPS] = 251
- self.dps[ADAPTIVE_DPS] = False
- self.dps[SCHED_DPS] = "5_1_1"
- self.dps[UNKNOWN14_DPS] = 14
- self.dps[UNKNOWN15_DPS] = 15
- self.dps[UNKNOWN17_DPS] = 17
- self.dps[UNKNOWN21_DPS] = True
- self.dps[POWERRATING_DPS] = 2000
- self.dps[UNKNOWN23_DPS] = 23
- self.dps[UNKNOWN26_DPS] = 26
- self.assertDictEqual(
- self.subject.extra_state_attributes,
- {
- "unknown_4": 4,
- "floor_temp_limit": 35.5,
- "installation": "Office",
- "floor_temperature": 25.1,
- "adaptive": False,
- "schedule": "5_1_1",
- "unknown_14": 14,
- "unknown_15": 15,
- "unknown_17": 17,
- "unknown_21": True,
- "power_rating": 2000,
- "unknown_23": 23,
- "unknown_26": 26,
- },
- )
|