From 86a23c7c1103f6fe79de9d756286189ffde4c5b2 Mon Sep 17 00:00:00 2001 From: Fabio Caccamo Date: Fri, 13 Mar 2020 13:53:49 +0100 Subject: [PATCH] Fixed `keypath_separator` support when using `from_{format}` methods. #12 --- benedict/dicts/__init__.py | 2 +- tests/dicts/test_benedict.py | 36 ++++++++++++++++++++++++++++++++++++ 2 files changed, 37 insertions(+), 1 deletion(-) diff --git a/benedict/dicts/__init__.py b/benedict/dicts/__init__.py index 13abebf..6fef229 100644 --- a/benedict/dicts/__init__.py +++ b/benedict/dicts/__init__.py @@ -28,7 +28,7 @@ from benedict.dicts.keypath import KeypathDict from benedict.dicts.parse import ParseDict -class benedict(IODict, KeypathDict, ParseDict): +class benedict(KeypathDict, IODict, ParseDict): def __init__(self, *args, **kwargs): """ diff --git a/tests/dicts/test_benedict.py b/tests/dicts/test_benedict.py index 365d8c0..d87ab9f 100644 --- a/tests/dicts/test_benedict.py +++ b/tests/dicts/test_benedict.py @@ -607,6 +607,42 @@ class benedict_test_case(unittest.TestCase): self.assertTrue(isinstance(d, benedict)) self.assertEqual(d, { 'a':1, 'b':{ 'c':3, 'd':4 },}) + def test_from_yaml_with_keypath_separator_in_keys(self): + # fix: https://github.com/fabiocaccamo/python-benedict/issues/12 + j = """ +192.168.0.1: + test: value + test2: value2 +value: + value_with_period: 12.34.45 +""" + with self.assertRaises(ValueError): + # static method + d = benedict.from_yaml(j) + self.assertTrue(isinstance(d, dict)) + self.assertEqual(d, { 'a':1, 'b':{ 'c':3, 'd':4 },}) + # constructor + d = benedict(j, format='yaml') + self.assertTrue(isinstance(d, dict)) + self.assertEqual(d, { 'a':1, 'b':{ 'c':3, 'd':4 },}) + r = { + '192.168.0.1': { + 'test':'value', + 'test2':'value2', + }, + 'value': { + 'value_with_period':'12.34.45', + }, + } + # static method + d = benedict.from_yaml(j, keypath_separator=None) + self.assertTrue(isinstance(d, dict)) + self.assertEqual(d, r) + # constructor + d = benedict(j, format='yaml', keypath_separator=None) + self.assertTrue(isinstance(d, dict)) + self.assertEqual(d, r) + def test_from_xml(self): j = """