模拟dict接口python

时间:2017-11-26 20:02:52

标签: python dictionary

出于某种原因,我不能完美地模仿我的类型的字典行为。

class IValType:
    def __init__(self, v):
        self.v = v

    def __repr__(self):
        return self.v.__repr__()

    def __str__(self):
        return self.v.__str__()

    def __eq__(self, other):
        return self.v.__eq__(other)

class Map(IValType, dict):
    def __init__(self, v: dict):
        super(Map, self).__init__(v)
        print("debug")

    def __contains__(self, item):
        return self.v.__contains__(item)

    def __getitem__(self, item):
        return self.v[item]

    def __setitem__(self, key, value):
        self.v[key] = value

    def __delitem__(self, key):
        self.v.__delitem__(key)

    def __missing__(self, key):
        return self.v.__missing__(key)

    def __get__(self, instance, owner):
        return self.__get__(instance, owner)

    def __iter__(self):
        return self.v.__iter__()

    def __len__(self):
        return len(self.v)

    @staticmethod
    def fromkeys(seq):
        return dict.fromkeys(seq)

    def values(self):
        return self.v.values()

    def keys(self):
        return self.v.keys()

    def items(self):
        return self.v.items()

    def pop(self, k):
        return self.v.pop(k)

    def popitem(self):
        return self.v.popitem()

    def setdefault(self, k, default=None):
        return self.v.setdefault(k, default)

    def get(self, k):
        return self.v.get(k)

    def update(self, __m, **kwargs):
        self.v.update(__m, **kwargs)

平等测试失败。

class MainTest(unittest.TestCase):

    def test_4(self):
        # make a full test for dicts
        d = {"k": 1,"p":2}
        dm = Map(d)
        self.assertIn("k", dm)
        self.assertEqual(dm["k"], d["k"])
        self.assertDictEqual(dm,d)

AssertionError: {'p': 2, 'k': 1} != {'p': 2, 'k': 1}
- {'p': 2, 'k': 1}
+ {'k': 1, 'p': 2}

我实施了几乎所有神奇的方法,我缺少什么?我不会以同样的方式重新实现列表而遇到这些麻烦,并且他们也会(成功地)进行平等测试。这是py 3.5

请帮忙吗?

1 个答案:

答案 0 :(得分:2)

您的问题是缺少的实现不等于,这是assertDictEqual在内部使用的内容(请参阅here):

>>> dm != d
True

IValType定义__ne__

这也可以说是unittest.TestCase中的错误,因此您可以考虑在bugs.python.org提交问题和/或切换到a better test runner