4
0

test_water_heater.py 2.9 KB

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