Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions jsonstore.py
Original file line number Diff line number Diff line change
Expand Up @@ -151,6 +151,9 @@ def __get_obj(self, full_path):
return obj

def __setitem__(self, name, value):
if type(name) is not str:
raise TypeError("Key must be of type 'str' but '%s' was given" % name.__class__.__name__)

path, _, key = name.rpartition(".")
if self._valid_object(value):
dictionary = self.__get_obj(path)
Expand Down
3 changes: 1 addition & 2 deletions test_jsonstore.py
Original file line number Diff line number Diff line change
Expand Up @@ -116,8 +116,7 @@ def assign(value):
self.assertRaises(AttributeError, assign(None for i in range(2)))

def test_assign_bad_keys(self):
# FIXME: a ValueError would make more sense
self.assertRaises(AttributeError, self._setitem(1, 2))
self.assertRaises(TypeError, self._setitem(1, 2))

def test_retrieve_values(self):
for name, value in self.TEST_DATA:
Expand Down