4
0

test_humidifier.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. """Tests for the humidifier 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.humidifier import (
  12. TuyaLocalHumidifier,
  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: "dehumidifier",
  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 (
  36. type(hass.data[DOMAIN]["dummy"]["humidifier_dehumidifier"])
  37. is TuyaLocalHumidifier
  38. )
  39. m_add_entities.assert_called_once()
  40. @pytest.mark.asyncio
  41. async def test_init_entry_fails_if_device_has_no_humidifier(hass):
  42. """Test initialisation when device has no matching entity"""
  43. entry = MockConfigEntry(
  44. domain=DOMAIN,
  45. data={
  46. CONF_TYPE: "kogan_heater",
  47. CONF_DEVICE_ID: "dummy",
  48. CONF_PROTOCOL_VERSION: "auto",
  49. },
  50. )
  51. # although async, the async_add_entities function passed to
  52. # async_setup_entry is called truly asynchronously. If we use
  53. # AsyncMock, it expects us to await the result.
  54. m_add_entities = Mock()
  55. m_device = AsyncMock()
  56. hass.data[DOMAIN] = {}
  57. hass.data[DOMAIN]["dummy"] = {}
  58. hass.data[DOMAIN]["dummy"]["device"] = m_device
  59. try:
  60. await async_setup_entry(hass, entry, m_add_entities)
  61. assert False
  62. except ValueError:
  63. pass
  64. m_add_entities.assert_not_called()
  65. @pytest.mark.asyncio
  66. async def test_init_entry_fails_if_config_is_missing(hass):
  67. """Test initialisation when device has no matching entity"""
  68. entry = MockConfigEntry(
  69. domain=DOMAIN,
  70. data={
  71. CONF_TYPE: "non_existing",
  72. CONF_DEVICE_ID: "dummy",
  73. CONF_PROTOCOL_VERSION: "auto",
  74. },
  75. )
  76. # although async, the async_add_entities function passed to
  77. # async_setup_entry is called truly asynchronously. If we use
  78. # AsyncMock, it expects us to await the result.
  79. m_add_entities = Mock()
  80. m_device = AsyncMock()
  81. hass.data[DOMAIN] = {}
  82. hass.data[DOMAIN]["dummy"] = {}
  83. hass.data[DOMAIN]["dummy"]["device"] = m_device
  84. try:
  85. await async_setup_entry(hass, entry, m_add_entities)
  86. assert False
  87. except ValueError:
  88. pass
  89. m_add_entities.assert_not_called()