mirror of
https://github.com/python-kasa/python-kasa.git
synced 2025-01-08 22:07:06 +00:00
Fix incorrect state updates in FakeTestProtocols (#861)
This commit is contained in:
parent
6e5cae1f47
commit
e410e4f3f3
@ -182,6 +182,7 @@ class IotBulb(IotDevice, Bulb):
|
|||||||
50
|
50
|
||||||
>>> preset.brightness = 100
|
>>> preset.brightness = 100
|
||||||
>>> asyncio.run(bulb.save_preset(preset))
|
>>> asyncio.run(bulb.save_preset(preset))
|
||||||
|
>>> asyncio.run(bulb.update())
|
||||||
>>> bulb.presets[0].brightness
|
>>> bulb.presets[0].brightness
|
||||||
100
|
100
|
||||||
|
|
||||||
|
@ -66,6 +66,7 @@ class IotStrip(IotDevice):
|
|||||||
>>> strip.is_on
|
>>> strip.is_on
|
||||||
True
|
True
|
||||||
>>> asyncio.run(strip.turn_off())
|
>>> asyncio.run(strip.turn_off())
|
||||||
|
>>> asyncio.run(strip.update())
|
||||||
|
|
||||||
Accessing individual plugs can be done using the `children` property:
|
Accessing individual plugs can be done using the `children` property:
|
||||||
|
|
||||||
|
@ -413,4 +413,4 @@ class FakeIotProtocol(IotProtocol):
|
|||||||
for target in request:
|
for target in request:
|
||||||
response.update(get_response_for_module(target))
|
response.update(get_response_for_module(target))
|
||||||
|
|
||||||
return response
|
return copy.deepcopy(response)
|
||||||
|
@ -157,13 +157,15 @@ class FakeSmartTransport(BaseTransport):
|
|||||||
return self._handle_control_child(params)
|
return self._handle_control_child(params)
|
||||||
elif method == "component_nego" or method[:4] == "get_":
|
elif method == "component_nego" or method[:4] == "get_":
|
||||||
if method in info:
|
if method in info:
|
||||||
return {"result": info[method], "error_code": 0}
|
result = copy.deepcopy(info[method])
|
||||||
|
return {"result": result, "error_code": 0}
|
||||||
if (
|
if (
|
||||||
# FIXTURE_MISSING is for service calls not in place when
|
# FIXTURE_MISSING is for service calls not in place when
|
||||||
# SMART fixtures started to be generated
|
# SMART fixtures started to be generated
|
||||||
missing_result := self.FIXTURE_MISSING_MAP.get(method)
|
missing_result := self.FIXTURE_MISSING_MAP.get(method)
|
||||||
) and missing_result[0] in self.components:
|
) and missing_result[0] in self.components:
|
||||||
retval = {"result": missing_result[1], "error_code": 0}
|
result = copy.deepcopy(missing_result[1])
|
||||||
|
retval = {"result": result, "error_code": 0}
|
||||||
else:
|
else:
|
||||||
# PARAMS error returned for KS240 when get_device_usage called
|
# PARAMS error returned for KS240 when get_device_usage called
|
||||||
# on parent device. Could be any error code though.
|
# on parent device. Could be any error code though.
|
||||||
|
@ -20,6 +20,7 @@ async def test_brightness_component(dev: SmartDevice):
|
|||||||
|
|
||||||
# Test setting the value
|
# Test setting the value
|
||||||
await feature.set_value(10)
|
await feature.set_value(10)
|
||||||
|
await dev.update()
|
||||||
assert feature.value == 10
|
assert feature.value == 10
|
||||||
|
|
||||||
with pytest.raises(ValueError):
|
with pytest.raises(ValueError):
|
||||||
@ -42,6 +43,7 @@ async def test_brightness_dimmable(dev: SmartDevice):
|
|||||||
|
|
||||||
# Test setting the value
|
# Test setting the value
|
||||||
await feature.set_value(10)
|
await feature.set_value(10)
|
||||||
|
await dev.update()
|
||||||
assert feature.value == 10
|
assert feature.value == 10
|
||||||
|
|
||||||
with pytest.raises(ValueError):
|
with pytest.raises(ValueError):
|
||||||
|
@ -20,6 +20,7 @@ async def test_colortemp_component(dev: SmartDevice):
|
|||||||
# We need to take the min here, as L9xx reports a range [9000, 9000].
|
# We need to take the min here, as L9xx reports a range [9000, 9000].
|
||||||
new_value = min(feature.minimum_value + 1, feature.maximum_value)
|
new_value = min(feature.minimum_value + 1, feature.maximum_value)
|
||||||
await feature.set_value(new_value)
|
await feature.set_value(new_value)
|
||||||
|
await dev.update()
|
||||||
assert feature.value == new_value
|
assert feature.value == new_value
|
||||||
|
|
||||||
with pytest.raises(ValueError):
|
with pytest.raises(ValueError):
|
||||||
|
@ -295,6 +295,7 @@ async def test_modify_preset(dev: IotBulb, mocker):
|
|||||||
assert preset.color_temp == 0
|
assert preset.color_temp == 0
|
||||||
|
|
||||||
await dev.save_preset(preset)
|
await dev.save_preset(preset)
|
||||||
|
await dev.update()
|
||||||
assert dev.presets[0].brightness == 10
|
assert dev.presets[0].brightness == 10
|
||||||
|
|
||||||
with pytest.raises(KasaException):
|
with pytest.raises(KasaException):
|
||||||
|
@ -88,8 +88,8 @@ async def test_sysinfo(dev, runner):
|
|||||||
@turn_on
|
@turn_on
|
||||||
async def test_state(dev, turn_on, runner):
|
async def test_state(dev, turn_on, runner):
|
||||||
await handle_turn_on(dev, turn_on)
|
await handle_turn_on(dev, turn_on)
|
||||||
res = await runner.invoke(state, obj=dev)
|
|
||||||
await dev.update()
|
await dev.update()
|
||||||
|
res = await runner.invoke(state, obj=dev)
|
||||||
|
|
||||||
if dev.is_on:
|
if dev.is_on:
|
||||||
assert "Device state: True" in res.output
|
assert "Device state: True" in res.output
|
||||||
@ -100,12 +100,12 @@ async def test_state(dev, turn_on, runner):
|
|||||||
@turn_on
|
@turn_on
|
||||||
async def test_toggle(dev, turn_on, runner):
|
async def test_toggle(dev, turn_on, runner):
|
||||||
await handle_turn_on(dev, turn_on)
|
await handle_turn_on(dev, turn_on)
|
||||||
await runner.invoke(toggle, obj=dev)
|
await dev.update()
|
||||||
|
assert dev.is_on == turn_on
|
||||||
|
|
||||||
if turn_on:
|
await runner.invoke(toggle, obj=dev)
|
||||||
assert not dev.is_on
|
await dev.update()
|
||||||
else:
|
assert dev.is_on != turn_on
|
||||||
assert dev.is_on
|
|
||||||
|
|
||||||
|
|
||||||
@device_iot
|
@device_iot
|
||||||
@ -118,6 +118,7 @@ async def test_alias(dev, runner):
|
|||||||
new_alias = "new alias"
|
new_alias = "new alias"
|
||||||
res = await runner.invoke(alias, [new_alias], obj=dev)
|
res = await runner.invoke(alias, [new_alias], obj=dev)
|
||||||
assert f"Setting alias to {new_alias}" in res.output
|
assert f"Setting alias to {new_alias}" in res.output
|
||||||
|
await dev.update()
|
||||||
|
|
||||||
res = await runner.invoke(alias, obj=dev)
|
res = await runner.invoke(alias, obj=dev)
|
||||||
assert f"Alias: {new_alias}" in res.output
|
assert f"Alias: {new_alias}" in res.output
|
||||||
@ -319,6 +320,7 @@ async def test_brightness(dev, runner):
|
|||||||
|
|
||||||
res = await runner.invoke(brightness, ["12"], obj=dev)
|
res = await runner.invoke(brightness, ["12"], obj=dev)
|
||||||
assert "Setting brightness" in res.output
|
assert "Setting brightness" in res.output
|
||||||
|
await dev.update()
|
||||||
|
|
||||||
res = await runner.invoke(brightness, obj=dev)
|
res = await runner.invoke(brightness, obj=dev)
|
||||||
assert "Brightness: 12" in res.output
|
assert "Brightness: 12" in res.output
|
||||||
|
@ -12,10 +12,12 @@ async def test_set_brightness(dev, turn_on):
|
|||||||
await handle_turn_on(dev, turn_on)
|
await handle_turn_on(dev, turn_on)
|
||||||
|
|
||||||
await dev.set_brightness(99)
|
await dev.set_brightness(99)
|
||||||
|
await dev.update()
|
||||||
assert dev.brightness == 99
|
assert dev.brightness == 99
|
||||||
assert dev.is_on == turn_on
|
assert dev.is_on == turn_on
|
||||||
|
|
||||||
await dev.set_brightness(0)
|
await dev.set_brightness(0)
|
||||||
|
await dev.update()
|
||||||
assert dev.brightness == 1
|
assert dev.brightness == 1
|
||||||
assert dev.is_on == turn_on
|
assert dev.is_on == turn_on
|
||||||
|
|
||||||
@ -27,17 +29,18 @@ async def test_set_brightness_transition(dev, turn_on, mocker):
|
|||||||
query_helper = mocker.spy(IotDimmer, "_query_helper")
|
query_helper = mocker.spy(IotDimmer, "_query_helper")
|
||||||
|
|
||||||
await dev.set_brightness(99, transition=1000)
|
await dev.set_brightness(99, transition=1000)
|
||||||
|
|
||||||
assert dev.brightness == 99
|
|
||||||
assert dev.is_on
|
|
||||||
query_helper.assert_called_with(
|
query_helper.assert_called_with(
|
||||||
mocker.ANY,
|
mocker.ANY,
|
||||||
"smartlife.iot.dimmer",
|
"smartlife.iot.dimmer",
|
||||||
"set_dimmer_transition",
|
"set_dimmer_transition",
|
||||||
{"brightness": 99, "duration": 1000},
|
{"brightness": 99, "duration": 1000},
|
||||||
)
|
)
|
||||||
|
await dev.update()
|
||||||
|
assert dev.brightness == 99
|
||||||
|
assert dev.is_on
|
||||||
|
|
||||||
await dev.set_brightness(0, transition=1000)
|
await dev.set_brightness(0, transition=1000)
|
||||||
|
await dev.update()
|
||||||
assert dev.brightness == 1
|
assert dev.brightness == 1
|
||||||
|
|
||||||
|
|
||||||
@ -58,15 +61,15 @@ async def test_turn_on_transition(dev, mocker):
|
|||||||
original_brightness = dev.brightness
|
original_brightness = dev.brightness
|
||||||
|
|
||||||
await dev.turn_on(transition=1000)
|
await dev.turn_on(transition=1000)
|
||||||
|
|
||||||
assert dev.is_on
|
|
||||||
assert dev.brightness == original_brightness
|
|
||||||
query_helper.assert_called_with(
|
query_helper.assert_called_with(
|
||||||
mocker.ANY,
|
mocker.ANY,
|
||||||
"smartlife.iot.dimmer",
|
"smartlife.iot.dimmer",
|
||||||
"set_dimmer_transition",
|
"set_dimmer_transition",
|
||||||
{"brightness": original_brightness, "duration": 1000},
|
{"brightness": original_brightness, "duration": 1000},
|
||||||
)
|
)
|
||||||
|
await dev.update()
|
||||||
|
assert dev.is_on
|
||||||
|
assert dev.brightness == original_brightness
|
||||||
|
|
||||||
|
|
||||||
@dimmer
|
@dimmer
|
||||||
@ -94,15 +97,15 @@ async def test_set_dimmer_transition(dev, turn_on, mocker):
|
|||||||
query_helper = mocker.spy(IotDimmer, "_query_helper")
|
query_helper = mocker.spy(IotDimmer, "_query_helper")
|
||||||
|
|
||||||
await dev.set_dimmer_transition(99, 1000)
|
await dev.set_dimmer_transition(99, 1000)
|
||||||
|
|
||||||
assert dev.is_on
|
|
||||||
assert dev.brightness == 99
|
|
||||||
query_helper.assert_called_with(
|
query_helper.assert_called_with(
|
||||||
mocker.ANY,
|
mocker.ANY,
|
||||||
"smartlife.iot.dimmer",
|
"smartlife.iot.dimmer",
|
||||||
"set_dimmer_transition",
|
"set_dimmer_transition",
|
||||||
{"brightness": 99, "duration": 1000},
|
{"brightness": 99, "duration": 1000},
|
||||||
)
|
)
|
||||||
|
await dev.update()
|
||||||
|
assert dev.is_on
|
||||||
|
assert dev.brightness == 99
|
||||||
|
|
||||||
|
|
||||||
@dimmer
|
@dimmer
|
||||||
|
@ -27,6 +27,7 @@ async def test_effects_lightstrip_set_effect(dev: IotLightStrip):
|
|||||||
await dev.set_effect("Not real")
|
await dev.set_effect("Not real")
|
||||||
|
|
||||||
await dev.set_effect("Candy Cane")
|
await dev.set_effect("Candy Cane")
|
||||||
|
await dev.update()
|
||||||
assert dev.effect["name"] == "Candy Cane"
|
assert dev.effect["name"] == "Candy Cane"
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user