test_qs_c01_curtain.py 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. """Tests for the QS C01 curtain module."""
  2. from homeassistant.components.cover import CoverDeviceClass, CoverEntityFeature
  3. from homeassistant.components.number import NumberDeviceClass
  4. from homeassistant.const import UnitOfTime
  5. from ..const import QS_C01_CURTAIN_PAYLOAD
  6. from ..helpers import assert_device_properties_set
  7. from ..mixins.number import BasicNumberTests
  8. from ..mixins.select import BasicSelectTests
  9. from .base_device_tests import TuyaDeviceTestCase
  10. COMMAND_DPS = "1"
  11. POSITION_DPS = "2"
  12. BACKMODE_DPS = "8"
  13. TRAVELTIME_DPS = "10"
  14. class TestQSC01Curtains(BasicNumberTests, BasicSelectTests, TuyaDeviceTestCase):
  15. __test__ = True
  16. def setUp(self):
  17. self.setUpForConfig("qs_c01_curtain.yaml", QS_C01_CURTAIN_PAYLOAD)
  18. self.subject = self.entities["cover_curtain"]
  19. self.setUpBasicNumber(
  20. TRAVELTIME_DPS,
  21. self.entities.get("number_travel_time"),
  22. min=1,
  23. max=60,
  24. device_class=NumberDeviceClass.DURATION,
  25. unit=UnitOfTime.SECONDS,
  26. )
  27. self.setUpBasicSelect(
  28. BACKMODE_DPS,
  29. self.entities.get("select_motor_reverse_mode"),
  30. {
  31. "forward": "Forward",
  32. "back": "Back",
  33. },
  34. )
  35. self.mark_secondary(["number_travel_time", "select_motor_reverse_mode"])
  36. def test_device_class_is_curtain(self):
  37. self.assertEqual(self.subject.device_class, CoverDeviceClass.CURTAIN)
  38. def test_supported_features(self):
  39. self.assertEqual(
  40. self.subject.supported_features,
  41. (
  42. CoverEntityFeature.OPEN
  43. | CoverEntityFeature.CLOSE
  44. | CoverEntityFeature.SET_POSITION
  45. | CoverEntityFeature.STOP
  46. ),
  47. )
  48. def test_current_cover_position(self):
  49. self.dps[POSITION_DPS] = 47
  50. self.assertEqual(self.subject.current_cover_position, 47)
  51. def test_is_opening(self):
  52. self.dps[COMMAND_DPS] = "open"
  53. self.dps[POSITION_DPS] = 100
  54. self.assertFalse(self.subject.is_opening)
  55. self.dps[POSITION_DPS] = 50
  56. self.assertIsNone(self.subject.is_opening)
  57. self.dps[COMMAND_DPS] = "close"
  58. self.assertIsNone(self.subject.is_opening)
  59. self.dps[COMMAND_DPS] = "stop"
  60. self.assertIsNone(self.subject.is_opening)
  61. def test_is_closing(self):
  62. self.dps[COMMAND_DPS] = "close"
  63. self.dps[POSITION_DPS] = 0
  64. self.assertFalse(self.subject.is_closing)
  65. self.dps[POSITION_DPS] = 50
  66. self.assertIsNone(self.subject.is_closing)
  67. self.dps[COMMAND_DPS] = "open"
  68. self.assertIsNone(self.subject.is_closing)
  69. self.dps[COMMAND_DPS] = "stop"
  70. self.assertIsNone(self.subject.is_closing)
  71. def test_is_closed(self):
  72. self.dps[COMMAND_DPS] = "close"
  73. self.dps[POSITION_DPS] = 100
  74. self.assertFalse(self.subject.is_closed)
  75. self.dps[POSITION_DPS] = 0
  76. self.assertTrue(self.subject.is_closed)
  77. async def test_open_cover(self):
  78. async with assert_device_properties_set(
  79. self.subject._device,
  80. {COMMAND_DPS: "open"},
  81. ):
  82. await self.subject.async_open_cover()
  83. async def test_close_cover(self):
  84. async with assert_device_properties_set(
  85. self.subject._device,
  86. {COMMAND_DPS: "close"},
  87. ):
  88. await self.subject.async_close_cover()
  89. async def test_stop_cover(self):
  90. async with assert_device_properties_set(
  91. self.subject._device,
  92. {COMMAND_DPS: "stop"},
  93. ):
  94. await self.subject.async_stop_cover()
  95. async def test_set_cover_position(self):
  96. async with assert_device_properties_set(
  97. self.subject._device,
  98. {POSITION_DPS: 20},
  99. ):
  100. # step is 10, so expect rounding to 20
  101. await self.subject.async_set_cover_position(23)