2019-04-30 22:07:34 +00:00
|
|
|
"""
|
|
|
|
Enable ptvsd debugger to attach to HA.
|
|
|
|
|
|
|
|
Attach ptvsd debugger by default to port 5678.
|
|
|
|
"""
|
|
|
|
|
2019-10-22 05:39:36 +00:00
|
|
|
from asyncio import Event
|
2019-04-30 22:07:34 +00:00
|
|
|
import logging
|
|
|
|
from threading import Thread
|
|
|
|
|
|
|
|
import voluptuous as vol
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
from homeassistant.const import CONF_HOST, CONF_PORT
|
2019-04-30 22:07:34 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
|
|
|
from homeassistant.helpers.typing import ConfigType, HomeAssistantType
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
DOMAIN = "ptvsd"
|
2019-04-30 22:07:34 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
CONF_WAIT = "wait"
|
2019-04-30 22:07:34 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
CONFIG_SCHEMA = vol.Schema(
|
|
|
|
{
|
|
|
|
DOMAIN: vol.Schema(
|
|
|
|
{
|
|
|
|
vol.Optional(CONF_HOST, default="0.0.0.0"): cv.string,
|
|
|
|
vol.Optional(CONF_PORT, default=5678): cv.port,
|
|
|
|
vol.Optional(CONF_WAIT, default=False): cv.boolean,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
},
|
|
|
|
extra=vol.ALLOW_EXTRA,
|
|
|
|
)
|
2019-04-30 22:07:34 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def async_setup(hass: HomeAssistantType, config: ConfigType):
|
|
|
|
"""Set up ptvsd debugger."""
|
2019-10-22 23:13:34 +00:00
|
|
|
|
|
|
|
# This is a local import, since importing this at the top, will cause
|
|
|
|
# ptvsd to hook into `sys.settrace`. So does `coverage` to generate
|
|
|
|
# coverage, resulting in a battle and incomplete code test coverage.
|
|
|
|
import ptvsd # pylint: disable=import-outside-toplevel
|
|
|
|
|
2019-04-30 22:07:34 +00:00
|
|
|
conf = config[DOMAIN]
|
|
|
|
host = conf[CONF_HOST]
|
|
|
|
port = conf[CONF_PORT]
|
|
|
|
|
|
|
|
ptvsd.enable_attach((host, port))
|
|
|
|
|
|
|
|
wait = conf[CONF_WAIT]
|
|
|
|
if wait:
|
|
|
|
_LOGGER.warning("Waiting for ptvsd connection on %s:%s", host, port)
|
|
|
|
ready = Event()
|
|
|
|
|
|
|
|
def waitfor():
|
|
|
|
ptvsd.wait_for_attach()
|
|
|
|
hass.loop.call_soon_threadsafe(ready.set)
|
2019-07-31 19:25:30 +00:00
|
|
|
|
2019-04-30 22:07:34 +00:00
|
|
|
Thread(target=waitfor).start()
|
|
|
|
|
|
|
|
await ready.wait()
|
|
|
|
else:
|
|
|
|
_LOGGER.warning("Listening for ptvsd connection on %s:%s", host, port)
|
|
|
|
|
|
|
|
return True
|