test_lock.py 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. """Tests for the lock 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_LOCK,
  6. CONF_DEVICE_ID,
  7. CONF_TYPE,
  8. DOMAIN,
  9. )
  10. from custom_components.tuya_local.generic.lock import TuyaLocalLock
  11. from custom_components.tuya_local.lock import async_setup_entry
  12. async def test_init_entry(hass):
  13. """Test the initialisation."""
  14. entry = MockConfigEntry(
  15. domain=DOMAIN,
  16. data={
  17. CONF_TYPE: "goldair_gpph_heater",
  18. CONF_DEVICE_ID: "dummy",
  19. "lock_child_lock": True,
  20. },
  21. )
  22. # although async, the async_add_entities function passed to
  23. # async_setup_entry is called truly asynchronously. If we use
  24. # AsyncMock, it expects us to await the result.
  25. m_add_entities = Mock()
  26. m_device = AsyncMock()
  27. hass.data[DOMAIN] = {}
  28. hass.data[DOMAIN]["dummy"] = {}
  29. hass.data[DOMAIN]["dummy"]["device"] = m_device
  30. await async_setup_entry(hass, entry, m_add_entities)
  31. assert type(hass.data[DOMAIN]["dummy"]["lock_child_lock"]) == TuyaLocalLock
  32. m_add_entities.assert_called_once()
  33. async def test_init_entry_fails_if_device_has_no_lock(hass):
  34. """Test initialisation when device has no matching entity"""
  35. entry = MockConfigEntry(
  36. domain=DOMAIN,
  37. data={CONF_TYPE: "kogan_switch", CONF_DEVICE_ID: "dummy", CONF_LOCK: True},
  38. )
  39. # although async, the async_add_entities function passed to
  40. # async_setup_entry is called truly asynchronously. If we use
  41. # AsyncMock, it expects us to await the result.
  42. m_add_entities = Mock()
  43. m_device = AsyncMock()
  44. hass.data[DOMAIN] = {}
  45. hass.data[DOMAIN]["dummy"] = {}
  46. hass.data[DOMAIN]["dummy"]["device"] = m_device
  47. try:
  48. await async_setup_entry(hass, entry, m_add_entities)
  49. assert False
  50. except ValueError:
  51. pass
  52. m_add_entities.assert_not_called()
  53. async def test_init_entry_fails_if_config_is_missing(hass):
  54. """Test initialisation when device has no matching entity"""
  55. entry = MockConfigEntry(
  56. domain=DOMAIN,
  57. data={CONF_TYPE: "non_existing", CONF_DEVICE_ID: "dummy", CONF_LOCK: True},
  58. )
  59. # although async, the async_add_entities function passed to
  60. # async_setup_entry is called truly asynchronously. If we use
  61. # AsyncMock, it expects us to await the result.
  62. m_add_entities = Mock()
  63. m_device = AsyncMock()
  64. hass.data[DOMAIN] = {}
  65. hass.data[DOMAIN]["dummy"] = {}
  66. hass.data[DOMAIN]["dummy"]["device"] = m_device
  67. try:
  68. await async_setup_entry(hass, entry, m_add_entities)
  69. assert False
  70. except ValueError:
  71. pass
  72. m_add_entities.assert_not_called()