背景
相对较新的Python及其unittest模块。在测试中模拟静态类变量时遇到问题。
(仅当原始类方法通过其第一个参数引用其自己的类变量时:cls)
例:
正在测试的类和类方法的简化版本:a.py
class A:
# class variable
my_list = []
@classmethod
def my_method(cls, item):
print cls # [] unable to mock this, why?
print A # [1,2,3] mocked as intended
cls.my_list.append(item)
测试:import unittest
from mock import patch
from a import A
class Test(unittest.testCase):
def test_my_method(self):
with patch("a.A") as mock_A:
# mocking the class variable
mock_A.my_list = [1,2,3]
# test call class method
A.my_method(4)
# assert the appended list to expected output
self.assertEqual(mock_A.my_list, [1,2,3,4])
# should evaluate to true, but fails the test
if __name__ == "__main__":
unittest.main()
问题:为什么mock只修补A引用而不是cls引用?
解决方案应该在什么方向,为了成功修补cls参数,所以类方法可以通过上面显示的测试。