test_lock.py 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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. },
  20. )
  21. # although async, the async_add_entities function passed to
  22. # async_setup_entry is called truly asynchronously. If we use
  23. # AsyncMock, it expects us to await the result.
  24. m_add_entities = Mock()
  25. m_device = AsyncMock()
  26. hass.data[DOMAIN] = {}
  27. hass.data[DOMAIN]["dummy"] = {}
  28. hass.data[DOMAIN]["dummy"]["device"] = m_device
  29. await async_setup_entry(hass, entry, m_add_entities)
  30. assert type(hass.data[DOMAIN]["dummy"]["lock_child_lock"]) == TuyaLocalLock
  31. m_add_entities.assert_called_once()
  32. async def test_init_entry_fails_if_device_has_no_lock(hass):
  33. """Test initialisation when device has no matching entity"""
  34. entry = MockConfigEntry(
  35. domain=DOMAIN,
  36. data={CONF_TYPE: "kogan_switch", CONF_DEVICE_ID: "dummy"},
  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. try:
  47. await async_setup_entry(hass, entry, m_add_entities)
  48. assert False
  49. except ValueError:
  50. pass
  51. m_add_entities.assert_not_called()
  52. async def test_init_entry_fails_if_config_is_missing(hass):
  53. """Test initialisation when device has no matching entity"""
  54. entry = MockConfigEntry(
  55. domain=DOMAIN,
  56. data={CONF_TYPE: "non_existing", CONF_DEVICE_ID: "dummy"},
  57. )
  58. # although async, the async_add_entities function passed to
  59. # async_setup_entry is called truly asynchronously. If we use
  60. # AsyncMock, it expects us to await the result.
  61. m_add_entities = Mock()
  62. m_device = AsyncMock()
  63. hass.data[DOMAIN] = {}
  64. hass.data[DOMAIN]["dummy"] = {}
  65. hass.data[DOMAIN]["dummy"]["device"] = m_device
  66. try:
  67. await async_setup_entry(hass, entry, m_add_entities)
  68. assert False
  69. except ValueError:
  70. pass
  71. m_add_entities.assert_not_called()