summaryrefslogtreecommitdiff
path: root/tests/utils_tests/test_hashable.py
diff options
context:
space:
mode:
authoraspalding <aspalding@procuredhealth.com>2018-10-16 10:02:36 -0500
committerTim Graham <timograham@gmail.com>2018-10-17 11:17:50 -0400
commit217f82d7139fd32f07adbfa92c5fb383d0ade577 (patch)
tree753bd98d3cf496b43f1f719bb800bc129a2f5bc5 /tests/utils_tests/test_hashable.py
parent834c4ec8e4cfc43acf0525e0a4d8c914534f6afd (diff)
downloaddjango-217f82d7139fd32f07adbfa92c5fb383d0ade577.tar.gz
Refs #29838 -- Fixed make_hashable() for values that have lists or dicts nested in tuples.
And for non-hashable values that are iterable, e.g. sets.
Diffstat (limited to 'tests/utils_tests/test_hashable.py')
-rw-r--r--tests/utils_tests/test_hashable.py12
1 files changed, 11 insertions, 1 deletions
diff --git a/tests/utils_tests/test_hashable.py b/tests/utils_tests/test_hashable.py
index 2310c4c605..b4db3ef7d7 100644
--- a/tests/utils_tests/test_hashable.py
+++ b/tests/utils_tests/test_hashable.py
@@ -8,9 +8,11 @@ class TestHashable(SimpleTestCase):
([], ()),
(['a', 1], ('a', 1)),
({}, ()),
- ({'a'}, {'a'}),
+ ({'a'}, ('a',)),
(frozenset({'a'}), {'a'}),
({'a': 1}, (('a', 1),)),
+ (('a', ['b', 1]), ('a', ('b', 1))),
+ (('a', {'b': 1}), ('a', (('b', 1),))),
)
for value, expected in tests:
with self.subTest(value=value):
@@ -19,7 +21,15 @@ class TestHashable(SimpleTestCase):
def test_count_equal(self):
tests = (
({'a': 1, 'b': ['a', 1]}, (('a', 1), ('b', ('a', 1)))),
+ ({'a': 1, 'b': ('a', [1, 2])}, (('a', 1), ('b', ('a', (1, 2))))),
)
for value, expected in tests:
with self.subTest(value=value):
self.assertCountEqual(make_hashable(value), expected)
+
+ def test_unhashable(self):
+ class Unhashable:
+ __hash__ = None
+
+ with self.assertRaisesMessage(TypeError, "unhashable type: 'Unhashable'"):
+ make_hashable(Unhashable())