1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-19 11:56:13 +01:00

Fix BaseModel to convert dictionaries to objects on retrieving a model list

This commit is contained in:
Daniel Mach 2024-02-14 14:00:06 +01:00
parent acc54919fc
commit 7768684461
2 changed files with 23 additions and 0 deletions

View File

@ -249,8 +249,18 @@ class Field(property):
def get(self, obj): def get(self, obj):
try: try:
result = obj._values[self.name] result = obj._values[self.name]
# convert dictionaries into objects
# we can't do it earlier because list is a standalone object that is not under our control
if result is not None and self.is_model_list:
for num, i in enumerate(result):
if isinstance(i, dict):
klass = self.inner_type
result[num] = klass(**i)
if self.get_callback is not None: if self.get_callback is not None:
result = self.get_callback(obj, result) result = self.get_callback(obj, result)
return result return result
except KeyError: except KeyError:
pass pass

View File

@ -339,6 +339,19 @@ class Test(unittest.TestCase):
m.field = [{"text": "one"}, {"text": "two"}] m.field = [{"text": "one"}, {"text": "two"}]
self.assertFalse(m.has_changed()) self.assertFalse(m.has_changed())
def test_append_dict(self):
class TestSubmodel(BaseModel):
text: str = Field(default="default")
class TestModel(BaseModel):
field: Optional[List[TestSubmodel]] = Field(default=[])
m = TestModel()
m.field.append({"text": "value"})
# dict is converted to object next time the field is retrieved
self.assertIsInstance(m.field[0], BaseModel)
self.assertEqual(m.field[0].text, "value")
if __name__ == "__main__": if __name__ == "__main__":
unittest.main() unittest.main()