* Wallbox component added * resolved mergeconflicts from upstream * fixed an incorrect removal in CODEOWNERS file * fixes for pullrequest automatic test * clean up code after PR tests * fixed strings.json * fix config_flow error > wallbox * fixed some formatting issues * fix pylint warnings * fixed error in number.py > set value * pylint warnings fixed * some more pylint fixes * isort fixes * fix unused_import pylint * remove tests * remove test requirements * config flow test * test errors resolved * test file formatting * isort on test file * sensor test * isort on test * isort test const * remove not working sensor test * remove test const * add switch, number and lock test * docstrings for test classes * sort test_number, create test_sensor * additional tests * fix test error * reduced PR to 1 component * newline in const * ignore test coverage -> dependency on external device (wallbox) * do not ignore config_flow * add test for validate_input * remove obsolete import * additional test config flow * change test sensor * docstring * add additional test for exceptions * fix test_config * more tests * fix test_config_flow * fixed http error test * catch connectionerror and introduce testing for this error * remove .coveragefile * change comment * Update homeassistant/components/wallbox/__init__.py review suggestion by janiversen Co-authored-by: jan iversen <jancasacondor@gmail.com> * Update homeassistant/components/wallbox/__init__.py review suggestion by janiversen (format only) Co-authored-by: jan iversen <jancasacondor@gmail.com> * Processed review comments, include more testing for sensor component * Isolated the async_add_executor_job to make the solution more async * add a config flow test * Revert "add a config flow test" This reverts commit9c1af82fff
. * Revert "Isolated the async_add_executor_job to make the solution more async" This reverts commit0bf034c331
. * Make component more async and add config flow tests * Changes based on review comments * made _ methods in WallboxHub for the 'non-async' call to the API and try-catch. Stored the wallbox in the class. * moved the coordinator to __init__ and pass it as part of the WallboxHub class * removed obsolete function in __init__ * removed CONNECTION_CLASS = config_entries.CONN_CLASS_CLOUD_POLL * fixed spelling and imports on test files * did isort on component files Co-authored-by: jan iversen <jancasacondor@gmail.com>
165 lines
5.3 KiB
Python
165 lines
5.3 KiB
Python
"""Test Wallbox Init Component."""
|
|
import json
|
|
|
|
import pytest
|
|
import requests_mock
|
|
from voluptuous.schema_builder import raises
|
|
|
|
from homeassistant.components import wallbox
|
|
from homeassistant.components.wallbox.const import CONF_STATION, DOMAIN
|
|
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
|
|
from homeassistant.helpers.typing import HomeAssistantType
|
|
|
|
from tests.common import MockConfigEntry
|
|
|
|
entry = MockConfigEntry(
|
|
domain=DOMAIN,
|
|
data={
|
|
CONF_USERNAME: "test_username",
|
|
CONF_PASSWORD: "test_password",
|
|
CONF_STATION: "12345",
|
|
},
|
|
entry_id="testEntry",
|
|
)
|
|
|
|
test_response = json.loads(
|
|
'{"charging_power": 0,"max_available_power": 25,"charging_speed": 0,"added_range": 372,"added_energy": 44.697}'
|
|
)
|
|
|
|
test_response_rounding_error = json.loads(
|
|
'{"charging_power": "XX","max_available_power": "xx","charging_speed": 0,"added_range": "xx","added_energy": "XX"}'
|
|
)
|
|
|
|
|
|
async def test_wallbox_setup_entry(hass: HomeAssistantType):
|
|
"""Test Wallbox Setup."""
|
|
with requests_mock.Mocker() as m:
|
|
m.get(
|
|
"https://api.wall-box.com/auth/token/user",
|
|
text='{"jwt":"fakekeyhere","user_id":12345,"ttl":145656758,"error":false,"status":200}',
|
|
status_code=200,
|
|
)
|
|
m.get(
|
|
"https://api.wall-box.com/chargers/status/12345",
|
|
text='{"Temperature": 100, "Location": "Toronto", "Datetime": "2020-07-23", "Units": "Celsius"}',
|
|
status_code=200,
|
|
)
|
|
assert await wallbox.async_setup_entry(hass, entry)
|
|
|
|
with requests_mock.Mocker() as m, raises(ConnectionError):
|
|
m.get(
|
|
"https://api.wall-box.com/auth/token/user",
|
|
text='{"jwt":"fakekeyhere","user_id":12345,"ttl":145656758,"error":false,"status":404}',
|
|
status_code=404,
|
|
)
|
|
assert await wallbox.async_setup_entry(hass, entry) is False
|
|
|
|
|
|
async def test_wallbox_unload_entry(hass: HomeAssistantType):
|
|
"""Test Wallbox Unload."""
|
|
hass.data[DOMAIN] = {"connections": {entry.entry_id: entry}}
|
|
|
|
assert await wallbox.async_unload_entry(hass, entry)
|
|
|
|
hass.data[DOMAIN] = {"fail_entry": entry}
|
|
|
|
with pytest.raises(KeyError):
|
|
await wallbox.async_unload_entry(hass, entry)
|
|
|
|
|
|
async def test_get_data(hass: HomeAssistantType):
|
|
"""Test hub class, get_data."""
|
|
|
|
station = ("12345",)
|
|
username = ("test-username",)
|
|
password = "test-password"
|
|
|
|
hub = wallbox.WallboxHub(station, username, password, hass)
|
|
|
|
with requests_mock.Mocker() as m:
|
|
m.get(
|
|
"https://api.wall-box.com/auth/token/user",
|
|
text='{"jwt":"fakekeyhere","user_id":12345,"ttl":145656758,"error":false,"status":200}',
|
|
status_code=200,
|
|
)
|
|
m.get(
|
|
"https://api.wall-box.com/chargers/status/('12345',)",
|
|
json=test_response,
|
|
status_code=200,
|
|
)
|
|
assert await hub.async_get_data()
|
|
|
|
|
|
async def test_get_data_rounding_error(hass: HomeAssistantType):
|
|
"""Test hub class, get_data with rounding error."""
|
|
|
|
station = ("12345",)
|
|
username = ("test-username",)
|
|
password = "test-password"
|
|
|
|
hub = wallbox.WallboxHub(station, username, password, hass)
|
|
|
|
with requests_mock.Mocker() as m:
|
|
m.get(
|
|
"https://api.wall-box.com/auth/token/user",
|
|
text='{"jwt":"fakekeyhere","user_id":12345,"ttl":145656758,"error":false,"status":200}',
|
|
status_code=200,
|
|
)
|
|
m.get(
|
|
"https://api.wall-box.com/chargers/status/('12345',)",
|
|
json=test_response_rounding_error,
|
|
status_code=200,
|
|
)
|
|
assert await hub.async_get_data()
|
|
|
|
|
|
async def test_authentication_exception(hass: HomeAssistantType):
|
|
"""Test hub class, authentication raises exception."""
|
|
|
|
station = ("12345",)
|
|
username = ("test-username",)
|
|
password = "test-password"
|
|
|
|
hub = wallbox.WallboxHub(station, username, password, hass)
|
|
|
|
with requests_mock.Mocker() as m, raises(wallbox.InvalidAuth):
|
|
m.get("https://api.wall-box.com/auth/token/user", text="data", status_code=403)
|
|
|
|
assert await hub.async_authenticate()
|
|
|
|
with requests_mock.Mocker() as m, raises(ConnectionError):
|
|
m.get("https://api.wall-box.com/auth/token/user", text="data", status_code=404)
|
|
|
|
assert await hub.async_authenticate()
|
|
|
|
with requests_mock.Mocker() as m, raises(wallbox.InvalidAuth):
|
|
m.get("https://api.wall-box.com/auth/token/user", text="data", status_code=403)
|
|
m.get(
|
|
"https://api.wall-box.com/chargers/status/test",
|
|
json=test_response,
|
|
status_code=403,
|
|
)
|
|
assert await hub.async_get_data()
|
|
|
|
|
|
async def test_get_data_exception(hass: HomeAssistantType):
|
|
"""Test hub class, authentication raises exception."""
|
|
|
|
station = ("12345",)
|
|
username = ("test-username",)
|
|
password = "test-password"
|
|
|
|
hub = wallbox.WallboxHub(station, username, password, hass)
|
|
|
|
with requests_mock.Mocker() as m, raises(ConnectionError):
|
|
m.get(
|
|
"https://api.wall-box.com/auth/token/user",
|
|
text='{"jwt":"fakekeyhere","user_id":12345,"ttl":145656758,"error":false,"status":200}',
|
|
status_code=200,
|
|
)
|
|
m.get(
|
|
"https://api.wall-box.com/chargers/status/('12345',)",
|
|
text="data",
|
|
status_code=404,
|
|
)
|
|
assert await hub.async_get_data()
|