Merge pull request #109 from tiqi-group/fix/task_disappears_after_changing_state

Fix/task disappears after changing state
This commit is contained in:
Mose Müller 2024-03-05 16:08:55 +01:00 committed by GitHub
commit 0c175fc706
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 38 additions and 7 deletions

View File

@ -267,18 +267,24 @@ def set_nested_value_by_path(
logger.error(e)
return
# setting the new value
serialized_value = dump(value)
serialized_value.pop("readonly", None)
value_type = serialized_value.pop("type")
if "readonly" in current_dict and current_dict["type"] != "method":
current_dict["type"] = value_type
keys_to_keep = set(serialized_value.keys())
if current_dict == {}: # adding an attribute / element to a list or dict
pass
elif current_dict["type"] == "method": # state change of task
keys_to_keep = set(current_dict.keys())
serialized_value = current_dict
serialized_value["value"] = value.name if isinstance(value, Enum) else None
else:
# attribute-specific information should not be overwritten by new value
serialized_value.pop("readonly")
serialized_value.pop("doc")
current_dict.update(serialized_value)
# removes keys that are not present in the serialized new value
keys_to_keep = set(serialized_value.keys()) | {"type", "readonly"}
for key in list(current_dict.keys()):
if key not in keys_to_keep:
current_dict.pop(key, None)

View File

@ -405,6 +405,9 @@ def setup_dict() -> dict[str, Any]:
enum_attr = MyEnum.RUNNING
attr_list = [0, 1, MySubclass()]
def my_task(self) -> None:
pass
return ServiceClass().serialize()["value"]
@ -439,6 +442,28 @@ def test_update_enum_attribute_to_float(setup_dict: dict[str, Any]) -> None:
}
def test_update_task_state(setup_dict: dict[str, Any]) -> None:
assert setup_dict["my_task"] == {
"async": False,
"doc": None,
"frontend_render": False,
"readonly": True,
"signature": {"parameters": {}, "return_annotation": {}},
"type": "method",
"value": None,
}
set_nested_value_by_path(setup_dict, "my_task", TaskStatus.RUNNING)
assert setup_dict["my_task"] == {
"async": False,
"doc": None,
"frontend_render": False,
"readonly": True,
"signature": {"parameters": {}, "return_annotation": {}},
"type": "method",
"value": "RUNNING",
}
def test_update_list_entry(setup_dict: dict[str, Any]) -> None:
set_nested_value_by_path(setup_dict, "attr_list[1]", 20)
assert setup_dict["attr_list"]["value"][1]["value"] == 20