From 61ffb8bb162d5b63390d85ca5159ea44c167b0ab Mon Sep 17 00:00:00 2001 From: "Andrew S. Rosen" Date: Sat, 30 Nov 2024 18:06:26 -0500 Subject: [PATCH 1/2] Fix recursive msonable --- monty/json.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/monty/json.py b/monty/json.py index 97a7bb90a..3b35e148a 100644 --- a/monty/json.py +++ b/monty/json.py @@ -715,7 +715,13 @@ def jsanitize( pass if recursive_msonable and isinstance(obj, MSONable): - return obj.as_dict() + return jsanitize( + obj.as_dict(), + strict=strict, + allow_bson=allow_bson, + enum_values=enum_values, + recursive_msonable=recursive_msonable, + ) if not strict: return str(obj) From 91e3b7e2b53086c13278700c3164326ab024d443 Mon Sep 17 00:00:00 2001 From: "Andrew S. Rosen" Date: Sat, 30 Nov 2024 18:07:11 -0500 Subject: [PATCH 2/2] Update test_json.py --- tests/test_json.py | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/tests/test_json.py b/tests/test_json.py index 16ba2d6c4..116b864cc 100644 --- a/tests/test_json.py +++ b/tests/test_json.py @@ -15,7 +15,7 @@ from monty.json import MontyDecoder, MontyEncoder, MSONable, _load_redirect, jsanitize -from . import __version__ as tests_version +from monty import __version__ as tests_version test_dir = os.path.join(os.path.dirname(os.path.abspath(__file__)), "test_files") @@ -576,6 +576,18 @@ def test_jsanitize(self): assert clean_recursive_msonable["hello"]["a"] == 1 assert clean_recursive_msonable["hello"]["b"] == 2 + DoubleGoodMSONClass = GoodMSONClass(1, 2, 3) + DoubleGoodMSONClass.values = [GoodMSONClass(1, 2, 3)] + clean_recursive_msonable = jsanitize( + DoubleGoodMSONClass, recursive_msonable=True + ) + assert clean_recursive_msonable["a"] == 1 + assert clean_recursive_msonable["b"] == 2 + assert clean_recursive_msonable["c"] == 3 + assert clean_recursive_msonable["values"][0]["a"] == 1 + assert clean_recursive_msonable["values"][0]["b"] == 2 + assert clean_recursive_msonable["values"][0]["c"] == 3 + d = {"dt": datetime.datetime.now()} clean = jsanitize(d) assert isinstance(clean["dt"], str)