From f128c808874d10da628701590163abe500bb33fb Mon Sep 17 00:00:00 2001 From: Baptiste Fontaine Date: Mon, 24 Jun 2024 10:06:03 +0000 Subject: [PATCH] Disallow []= on ImmutableDict Fixes #88. --- edn_format/immutable_dict.py | 5 ----- tests.py | 19 +++++++++++++++---- 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/edn_format/immutable_dict.py b/edn_format/immutable_dict.py index bbbe3d3..706fc94 100644 --- a/edn_format/immutable_dict.py +++ b/edn_format/immutable_dict.py @@ -15,11 +15,6 @@ def __init__(self, somedict): def __getitem__(self, key): return self.dict[key] - def __setitem__(self, key, value): - modifiable = dict(self.dict) - modifiable[key] = value - return ImmutableDict(modifiable) - def __repr__(self): return self.dict.__repr__() diff --git a/tests.py b/tests.py index 14d457c..ab4a336 100644 --- a/tests.py +++ b/tests.py @@ -2,12 +2,12 @@ # TODO: Tests pass on Python 3.6, Disabled to not break tests on 2.7 :-( # from __future__ import absolute_import, division, print_function, unicode_literals -from collections import OrderedDict -from uuid import uuid4, UUID -import random import datetime import fractions +import random import unittest +from collections import OrderedDict +from uuid import uuid4, UUID import pytz @@ -15,7 +15,6 @@ loads, dumps, Keyword, Symbol, ImmutableDict, ImmutableList, Char, \ TaggedElement, add_tag, remove_tag, tag, \ EDNDecodeError - from edn_format.compat import _PY3, unicode @@ -632,6 +631,18 @@ def test_equality(self): self.assertTrue(Symbol("db/id") == Symbol("db/id")) +class ImmutableDictTest(unittest.TestCase): + def test_mutation(self): + x = ImmutableDict({}) + + def mutate(): + nonlocal x + # noinspection PyUnresolvedReferences + x["foo"] = "bar" + + self.assertRaises(TypeError, mutate) + + class ImmutableListTest(unittest.TestCase): def test_list(self): x = ImmutableList([1, 2, 3])