hass-core/tests/components/wallbox/test_init.py
hesselonline c497c0eadd
Add wallbox integration (#48082)
* 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 commit 9c1af82fff.

* Revert "Isolated the async_add_executor_job to make the solution more async"

This reverts commit 0bf034c331.

* 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>
2021-05-24 13:08:24 +02:00

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()