test_button.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. """Tests for the button entity."""
  2. from pytest_homeassistant_custom_component.common import MockConfigEntry
  3. import pytest
  4. from unittest.mock import AsyncMock, Mock
  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.button import (
  12. async_setup_entry,
  13. TuyaLocalButton,
  14. )
  15. @pytest.mark.asyncio
  16. async def test_init_entry_as_secondary(hass):
  17. """Test the initialisation."""
  18. entry = MockConfigEntry(
  19. domain=DOMAIN,
  20. data={
  21. CONF_TYPE: "catit_pet_feeder",
  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"]["button_factory_reset"]) == TuyaLocalButton
  36. m_add_entities.assert_called_once()
  37. @pytest.mark.asyncio
  38. async def test_init_entry_fails_if_device_has_no_button(hass):
  39. """Test initialisation when device has no matching entity"""
  40. entry = MockConfigEntry(
  41. domain=DOMAIN,
  42. data={
  43. CONF_TYPE: "kogan_heater",
  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()