2016-12-04 18:57:48 +00:00
|
|
|
"""The tests for the emulated Hue component."""
|
|
|
|
import json
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
from unittest.mock import patch
|
|
|
|
import requests
|
2017-11-04 19:04:05 +00:00
|
|
|
from aiohttp.hdrs import CONTENT_TYPE
|
2016-12-04 18:57:48 +00:00
|
|
|
|
2018-11-28 12:16:43 +00:00
|
|
|
from homeassistant import setup, const
|
2016-12-04 18:57:48 +00:00
|
|
|
from homeassistant.components import emulated_hue, http
|
|
|
|
|
|
|
|
from tests.common import get_test_instance_port, get_test_home_assistant
|
|
|
|
|
|
|
|
HTTP_SERVER_PORT = get_test_instance_port()
|
|
|
|
BRIDGE_SERVER_PORT = get_test_instance_port()
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
BRIDGE_URL_BASE = "http://127.0.0.1:{}".format(BRIDGE_SERVER_PORT) + "{}"
|
2017-11-04 19:04:05 +00:00
|
|
|
JSON_HEADERS = {CONTENT_TYPE: const.CONTENT_TYPE_JSON}
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TestEmulatedHue(unittest.TestCase):
|
|
|
|
"""Test the emulated Hue component."""
|
|
|
|
|
|
|
|
hass = None
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2018-08-19 20:29:08 +00:00
|
|
|
"""Set up the class."""
|
2016-12-04 18:57:48 +00:00
|
|
|
cls.hass = hass = get_test_home_assistant()
|
|
|
|
|
2017-03-05 09:41:54 +00:00
|
|
|
setup.setup_component(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass, http.DOMAIN, {http.DOMAIN: {http.CONF_SERVER_PORT: HTTP_SERVER_PORT}}
|
|
|
|
)
|
|
|
|
|
|
|
|
with patch("homeassistant.components" ".emulated_hue.UPNPResponderThread"):
|
|
|
|
setup.setup_component(
|
|
|
|
hass,
|
|
|
|
emulated_hue.DOMAIN,
|
|
|
|
{
|
|
|
|
emulated_hue.DOMAIN: {
|
|
|
|
emulated_hue.CONF_LISTEN_PORT: BRIDGE_SERVER_PORT
|
|
|
|
}
|
|
|
|
},
|
|
|
|
)
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
cls.hass.start()
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def tearDownClass(cls):
|
|
|
|
"""Stop the class."""
|
|
|
|
cls.hass.stop()
|
|
|
|
|
|
|
|
def test_description_xml(self):
|
|
|
|
"""Test the description."""
|
2019-11-18 08:10:15 +00:00
|
|
|
import defusedxml.ElementTree as ET
|
2016-12-04 18:57:48 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
result = requests.get(BRIDGE_URL_BASE.format("/description.xml"), timeout=5)
|
2016-12-04 18:57:48 +00:00
|
|
|
|
2018-10-24 10:10:05 +00:00
|
|
|
assert result.status_code == 200
|
2019-07-31 19:25:30 +00:00
|
|
|
assert "text/xml" in result.headers["content-type"]
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
# Make sure the XML is parsable
|
|
|
|
try:
|
|
|
|
ET.fromstring(result.text)
|
2018-07-17 17:34:29 +00:00
|
|
|
except: # noqa: E722 pylint: disable=bare-except
|
2019-07-31 19:25:30 +00:00
|
|
|
self.fail("description.xml is not valid XML!")
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
def test_create_username(self):
|
|
|
|
"""Test the creation of an username."""
|
2019-07-31 19:25:30 +00:00
|
|
|
request_json = {"devicetype": "my_device"}
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
result = requests.post(
|
2019-07-31 19:25:30 +00:00
|
|
|
BRIDGE_URL_BASE.format("/api"), data=json.dumps(request_json), timeout=5
|
|
|
|
)
|
2016-12-04 18:57:48 +00:00
|
|
|
|
2018-10-24 10:10:05 +00:00
|
|
|
assert result.status_code == 200
|
2019-07-31 19:25:30 +00:00
|
|
|
assert "application/json" in result.headers["content-type"]
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
resp_json = result.json()
|
|
|
|
success_json = resp_json[0]
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
assert "success" in success_json
|
|
|
|
assert "username" in success_json["success"]
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
def test_valid_username_request(self):
|
|
|
|
"""Test request with a valid username."""
|
2019-07-31 19:25:30 +00:00
|
|
|
request_json = {"invalid_key": "my_device"}
|
2016-12-04 18:57:48 +00:00
|
|
|
|
|
|
|
result = requests.post(
|
2019-07-31 19:25:30 +00:00
|
|
|
BRIDGE_URL_BASE.format("/api"), data=json.dumps(request_json), timeout=5
|
|
|
|
)
|
2016-12-04 18:57:48 +00:00
|
|
|
|
2018-10-24 10:10:05 +00:00
|
|
|
assert result.status_code == 400
|