test_fan.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. """Tests for the fan entity."""
  2. from pytest_homeassistant_custom_component.common import MockConfigEntry
  3. from unittest.mock import AsyncMock, Mock
  4. from custom_components.tuya_local.const import (
  5. CONF_FAN,
  6. CONF_DEVICE_ID,
  7. CONF_TYPE,
  8. DOMAIN,
  9. )
  10. from custom_components.tuya_local.generic.fan import TuyaLocalFan
  11. from custom_components.tuya_local.fan import async_setup_entry
  12. async def test_init_entry(hass):
  13. """Test the initialisation."""
  14. entry = MockConfigEntry(
  15. domain=DOMAIN,
  16. data={CONF_TYPE: "goldair_fan", CONF_DEVICE_ID: "dummy"},
  17. )
  18. # although async, the async_add_entities function passed to
  19. # async_setup_entry is called truly asynchronously. If we use
  20. # AsyncMock, it expects us to await the result.
  21. m_add_entities = Mock()
  22. m_device = AsyncMock()
  23. hass.data[DOMAIN] = {}
  24. hass.data[DOMAIN]["dummy"] = {}
  25. hass.data[DOMAIN]["dummy"]["device"] = m_device
  26. await async_setup_entry(hass, entry, m_add_entities)
  27. assert type(hass.data[DOMAIN]["dummy"][CONF_FAN]) == TuyaLocalFan
  28. m_add_entities.assert_called_once()
  29. async def test_init_entry_as_secondary(hass):
  30. """Test initialisation when fan is a secondary entity"""
  31. entry = MockConfigEntry(
  32. domain=DOMAIN,
  33. data={
  34. CONF_TYPE: "goldair_dehumidifier",
  35. CONF_DEVICE_ID: "dummy",
  36. },
  37. )
  38. # although async, the async_add_entities function passed to
  39. # async_setup_entry is called truly asynchronously. If we use
  40. # AsyncMock, it expects us to await the result.
  41. m_add_entities = Mock()
  42. m_device = AsyncMock()
  43. hass.data[DOMAIN] = {}
  44. hass.data[DOMAIN]["dummy"] = {}
  45. hass.data[DOMAIN]["dummy"]["device"] = m_device
  46. await async_setup_entry(hass, entry, m_add_entities)
  47. assert type(hass.data[DOMAIN]["dummy"][CONF_FAN]) == TuyaLocalFan
  48. m_add_entities.assert_called_once()
  49. async def test_init_entry_fails_if_device_has_no_fan(hass):
  50. """Test initialisation when device has no matching entity"""
  51. entry = MockConfigEntry(
  52. domain=DOMAIN,
  53. data={CONF_TYPE: "kogan_heater", CONF_DEVICE_ID: "dummy"},
  54. )
  55. # although async, the async_add_entities function passed to
  56. # async_setup_entry is called truly asynchronously. If we use
  57. # AsyncMock, it expects us to await the result.
  58. m_add_entities = Mock()
  59. m_device = AsyncMock()
  60. hass.data[DOMAIN] = {}
  61. hass.data[DOMAIN]["dummy"] = {}
  62. hass.data[DOMAIN]["dummy"]["device"] = m_device
  63. try:
  64. await async_setup_entry(hass, entry, m_add_entities)
  65. assert False
  66. except ValueError:
  67. pass
  68. m_add_entities.assert_not_called()
  69. async def test_init_entry_fails_if_config_is_missing(hass):
  70. """Test initialisation when device has no matching entity"""
  71. entry = MockConfigEntry(
  72. domain=DOMAIN,
  73. data={CONF_TYPE: "non_existing", CONF_DEVICE_ID: "dummy"},
  74. )
  75. # although async, the async_add_entities function passed to
  76. # async_setup_entry is called truly asynchronously. If we use
  77. # AsyncMock, it expects us to await the result.
  78. m_add_entities = Mock()
  79. m_device = AsyncMock()
  80. hass.data[DOMAIN] = {}
  81. hass.data[DOMAIN]["dummy"] = {}
  82. hass.data[DOMAIN]["dummy"]["device"] = m_device
  83. try:
  84. await async_setup_entry(hass, entry, m_add_entities)
  85. assert False
  86. except ValueError:
  87. pass
  88. m_add_entities.assert_not_called()