From 11d291ab7ae973354007dbb58c5a23bb27f65ddf Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Fri, 16 Mar 2018 18:52:56 +0100 Subject: [PATCH 1/7] Test coverage of the Air Purifier improved --- miio/tests/test_airpurifier.py | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/miio/tests/test_airpurifier.py b/miio/tests/test_airpurifier.py index 13fb879ba..c3d04e7d2 100644 --- a/miio/tests/test_airpurifier.py +++ b/miio/tests/test_airpurifier.py @@ -246,6 +246,9 @@ def extra_features(): self.device.set_extra_features(2) assert extra_features() == 2 + with pytest.raises(AirPurifierException): + self.device.set_extra_features(-1) + def test_reset_filter(self): def filter_hours_used(): return self.device.status().filter_hours_used @@ -328,3 +331,19 @@ def test_status_filter_rfid_product_ids(self): assert self.state().filter_type is FilterType.Regular self.device.state["rfid_product_id"] = '0:0:41:30' assert self.state().filter_type is FilterType.AntiBacterial + + def test_status_without_sleep_mode(self): + self.device._reset_state() + self.device.state["sleep_mode"] = None + assert self.state().sleep_mode is None + + def test_status_without_app_extra(self): + self.device._reset_state() + self.device.state["app_extra"] = None + assert self.state().extra_features is None + assert self.state().turbo_mode_supported is None + + def test_status_without_auto_detect(self): + self.device._reset_state() + self.device.state["act_det"] = None + assert self.state().auto_detect is None From 8ecb3e6332fa872d49bac2857de55e0bbda18afc Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Fri, 16 Mar 2018 19:01:27 +0100 Subject: [PATCH 2/7] Test coverage of the Philips Ceiling Lamp improved. --- miio/tests/test_ceil.py | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/miio/tests/test_ceil.py b/miio/tests/test_ceil.py index e8b66dea4..76f087b45 100644 --- a/miio/tests/test_ceil.py +++ b/miio/tests/test_ceil.py @@ -85,6 +85,12 @@ def brightness(): self.device.set_brightness(20) assert brightness() == 20 + with pytest.raises(CeilException): + self.device.set_brightness(-1) + + with pytest.raises(CeilException): + self.device.set_brightness(101) + def test_set_color_temperature(self): def color_temperature(): return self.device.status().color_temperature @@ -94,6 +100,13 @@ def color_temperature(): self.device.set_color_temperature(20) assert color_temperature() == 20 + + with pytest.raises(CeilException): + self.device.set_color_temperature(-1) + + with pytest.raises(CeilException): + self.device.set_color_temperature(101) + def test_set_brightness_and_color_temperature(self): def color_temperature(): return self.device.status().color_temperature @@ -138,14 +151,26 @@ def delay_off_countdown(): self.device.delay_off(200) assert delay_off_countdown() == 200 + with pytest.raises(CeilException): + self.device.delay_off(0) + + with pytest.raises(CeilException): + self.device.delay_off(-1) + def test_set_scene(self): def scene(): return self.device.status().scene self.device.set_scene(1) assert scene() == 1 - self.device.set_scene(2) - assert scene() == 2 + self.device.set_scene(4) + assert scene() == 4 + + with pytest.raises(CeilException): + self.device.set_scene(0) + + with pytest.raises(CeilException): + self.device.set_scene(5) def test_smart_night_light_on(self): def smart_night_light(): From 2eb59525034f662b756a1fe10efc522b8ceead0a Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Fri, 16 Mar 2018 19:10:20 +0100 Subject: [PATCH 3/7] Test coverage of the Chuangmi IR Controller improved. --- miio/tests/test_chuangmi_ir.json | 7 +++++++ miio/tests/test_chuangmi_ir.py | 8 ++++++++ 2 files changed, 15 insertions(+) diff --git a/miio/tests/test_chuangmi_ir.json b/miio/tests/test_chuangmi_ir.json index cd4995533..6ddf5d0e2 100644 --- a/miio/tests/test_chuangmi_ir.json +++ b/miio/tests/test_chuangmi_ir.json @@ -103,6 +103,13 @@ "0000006C00220002015B00AD001600160016001600160016001600160016001600160016001600160016001600160041001600410016004100160041001600410016004100160041001600160016001600160041001600160016004100160016001600160016001600160016001600410016001600160041001600160016004100160041001600410016004100160622015B005700160E6C", -1 ] + }, + { + "desc": "Invalid pronto command", + "in": [ + "Invalid pronto command", + -1 + ] } ] } \ No newline at end of file diff --git a/miio/tests/test_chuangmi_ir.py b/miio/tests/test_chuangmi_ir.py index e3e0498eb..6b6105685 100644 --- a/miio/tests/test_chuangmi_ir.py +++ b/miio/tests/test_chuangmi_ir.py @@ -125,3 +125,11 @@ def test_play_with_type(self): self.device.state['last_ir_played'], args['out'] ) + with pytest.raises(ChuangmiIrException): + self.device.play('invalid:command') + + with pytest.raises(ChuangmiIrException): + self.device.play('pronto:command:invalid:argument:count') + + with pytest.raises(ChuangmiIrException): + self.device.play('pronto:command:invalidargument') From d2a39846db81ca687bd5cea57a2db51356bf5510 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Fri, 16 Mar 2018 19:10:56 +0100 Subject: [PATCH 4/7] Blank line removed. --- miio/tests/test_ceil.py | 1 - 1 file changed, 1 deletion(-) diff --git a/miio/tests/test_ceil.py b/miio/tests/test_ceil.py index 76f087b45..d8f6de894 100644 --- a/miio/tests/test_ceil.py +++ b/miio/tests/test_ceil.py @@ -100,7 +100,6 @@ def color_temperature(): self.device.set_color_temperature(20) assert color_temperature() == 20 - with pytest.raises(CeilException): self.device.set_color_temperature(-1) From ecb47f052c72a7613762eb882bbe7d4a12b0f8d1 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Fri, 16 Mar 2018 19:35:35 +0100 Subject: [PATCH 5/7] Invalid pronto command updated. --- miio/tests/test_chuangmi_ir.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/miio/tests/test_chuangmi_ir.json b/miio/tests/test_chuangmi_ir.json index 6ddf5d0e2..3b85acf57 100644 --- a/miio/tests/test_chuangmi_ir.json +++ b/miio/tests/test_chuangmi_ir.json @@ -107,8 +107,8 @@ { "desc": "Invalid pronto command", "in": [ - "Invalid pronto command", - -1 + "FFFFFFFFFFFF", + 0 ] } ] From e1ef42fb710d7db7de1dd3214a68c3f6471d21ad Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Fri, 16 Mar 2018 19:47:11 +0100 Subject: [PATCH 6/7] Tests for the Water Purifier added. --- miio/tests/test_waterpurifier.py | 53 ++++++++++++++++++++++++++++++++ miio/waterpurifier.py | 2 +- 2 files changed, 54 insertions(+), 1 deletion(-) create mode 100644 miio/tests/test_waterpurifier.py diff --git a/miio/tests/test_waterpurifier.py b/miio/tests/test_waterpurifier.py new file mode 100644 index 000000000..db45cdda1 --- /dev/null +++ b/miio/tests/test_waterpurifier.py @@ -0,0 +1,53 @@ +from unittest import TestCase +from miio import WaterPurifier +from miio.waterpurifier import WaterPurifierStatus +from .dummies import DummyDevice +import pytest + + +class DummyWaterPurifier(DummyDevice, WaterPurifier): + def __init__(self, *args, **kwargs): + self.state = { + 'power': 'on', + } + self.return_values = { + 'get_prop': self._get_state, + 'set_power': lambda x: self._set_state("power", x), + } + super().__init__(args, kwargs) + + +@pytest.fixture(scope="class") +def waterpurifier(request): + request.cls.device = DummyWaterPurifier() + # TODO add ability to test on a real device + + +@pytest.mark.usefixtures("waterpurifier") +class TestWaterPurifier(TestCase): + def is_on(self): + return self.device.status().is_on + + def state(self): + return self.device.status() + + def test_on(self): + self.device.off() # ensure off + assert self.is_on() is False + + self.device.on() + assert self.is_on() is True + + def test_off(self): + self.device.on() # ensure on + assert self.is_on() is True + + self.device.off() + assert self.is_on() is False + + def test_status(self): + self.device._reset_state() + + assert repr(self.state()) == repr(WaterPurifierStatus(self.device.start_state)) + + assert self.is_on() is True diff --git a/miio/waterpurifier.py b/miio/waterpurifier.py index 5777526de..28c60920f 100644 --- a/miio/waterpurifier.py +++ b/miio/waterpurifier.py @@ -20,7 +20,7 @@ def power(self) -> str: def is_on(self) -> bool: return self.power == "on" - def __str__(self) -> str: + def __repr__(self) -> str: return "" % self.power From 6aa09ac0c0c7f35657ae750c0edb8d5d1f693aa7 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Mon, 26 Mar 2018 22:47:18 +0200 Subject: [PATCH 7/7] Response example dummy added --- miio/tests/test_waterpurifier.py | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/miio/tests/test_waterpurifier.py b/miio/tests/test_waterpurifier.py index db45cdda1..3467859a5 100644 --- a/miio/tests/test_waterpurifier.py +++ b/miio/tests/test_waterpurifier.py @@ -9,6 +9,23 @@ class DummyWaterPurifier(DummyDevice, WaterPurifier): def __init__(self, *args, **kwargs): self.state = { 'power': 'on', + 'mode': 'unknown', + 'tds': 'unknown', + 'filter1_life': -1, + 'filter1_state': -1, + 'filter_life': -1, + 'filter_state': -1, + 'life': -1, + 'state': -1, + 'level': 'unknown', + 'volume': 'unknown', + 'filter': 'unknown', + 'usage': 'unknown', + 'temperature': 'unknown', + 'uv_life': -1, + 'uv_state': -1, + 'elecval_state': 'unknown' + } self.return_values = { 'get_prop': self._get_state,