4
0

test_remote.py 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. """Tests for the remote 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.remote import TuyaLocalRemote, async_setup_entry
  12. @pytest.mark.asyncio
  13. async def test_init_entry(hass):
  14. """Test the initialisation."""
  15. entry = MockConfigEntry(
  16. domain=DOMAIN,
  17. data={
  18. CONF_TYPE: "ir_remote_sensors",
  19. CONF_DEVICE_ID: "dummy",
  20. CONF_PROTOCOL_VERSION: "auto",
  21. },
  22. )
  23. # although async, the async_add_entities function passed to
  24. # async_setup_entry is called truly asynchronously. If we use
  25. # AsyncMock, it expects us to await the result.
  26. m_add_entities = Mock()
  27. m_device = AsyncMock()
  28. hass.data[DOMAIN] = {}
  29. hass.data[DOMAIN]["dummy"] = {}
  30. hass.data[DOMAIN]["dummy"]["device"] = m_device
  31. await async_setup_entry(hass, entry, m_add_entities)
  32. assert type(hass.data[DOMAIN]["dummy"]["remote"]) is TuyaLocalRemote
  33. m_add_entities.assert_called_once()
  34. @pytest.mark.asyncio
  35. async def test_init_entry_fails_if_device_has_no_remote(hass):
  36. """Test initialisation when device has no matching entity"""
  37. entry = MockConfigEntry(
  38. domain=DOMAIN,
  39. data={
  40. CONF_TYPE: "smartplugv1",
  41. CONF_DEVICE_ID: "dummy",
  42. CONF_PROTOCOL_VERSION: "auto",
  43. },
  44. )
  45. # although async, the async_add_entities function passed to
  46. # async_setup_entry is called truly asynchronously. If we use
  47. # AsyncMock, it expects us to await the result.
  48. m_add_entities = Mock()
  49. m_device = AsyncMock()
  50. hass.data[DOMAIN] = {}
  51. hass.data[DOMAIN]["dummy"] = {}
  52. hass.data[DOMAIN]["dummy"]["device"] = m_device
  53. try:
  54. await async_setup_entry(hass, entry, m_add_entities)
  55. assert False
  56. except ValueError:
  57. pass
  58. m_add_entities.assert_not_called()
  59. @pytest.mark.asyncio
  60. async def test_init_entry_fails_if_config_is_missing(hass):
  61. """Test initialisation when device has no matching entity"""
  62. entry = MockConfigEntry(
  63. domain=DOMAIN,
  64. data={
  65. CONF_TYPE: "non_existing",
  66. CONF_DEVICE_ID: "dummy",
  67. CONF_PROTOCOL_VERSION: "auto",
  68. },
  69. )
  70. # although async, the async_add_entities function passed to
  71. # async_setup_entry is called truly asynchronously. If we use
  72. # AsyncMock, it expects us to await the result.
  73. m_add_entities = Mock()
  74. m_device = AsyncMock()
  75. hass.data[DOMAIN] = {}
  76. hass.data[DOMAIN]["dummy"] = {}
  77. hass.data[DOMAIN]["dummy"]["device"] = m_device
  78. try:
  79. await async_setup_entry(hass, entry, m_add_entities)
  80. assert False
  81. except ValueError:
  82. pass
  83. m_add_entities.assert_not_called()