如何在python单元测试中模拟类变量值?

时间:2011-12-17 19:28:20

标签: python unit-testing mocking

说我有课:

class A():
  def f(self):
    self._v = 1

尝试:

m=Mocker()
A.f._v = m.mock()
...

但没有奏效。不知道怎么......

3 个答案:

答案 0 :(得分:4)

您的意思是Mock library吗?

from mock import Mock
real = ProductionClass()
real.method = Mock(return_value=3)
real.method(3, 4, 5, key='value')

修改

你试图在嘲笑之前访问A.f._v这是不可能的。 不知道你想做什么,但这将有效

>>>A.f = Mock()
>>>a = A()
>>>a.f._v
<Mock name='mock._v' id='42076240'>

答案 1 :(得分:4)

类定义显示了一个实例变量,用于从该类外部设置它,执行以下操作:

class A:
  def f(self):
    self._v = 1

a = A()
a._v = Mock()

如果你真的想要一个真正的类变量,试试这个:

class A():
  _v = None
  def f(self):
    self.__class__._v = 1

A._v = Mock()

答案 2 :(得分:1)

我尝试了上面的解决方案,它仍然没有解决我的目的,这正是最初的问题。上面的方法会更新我的类的mocked属性,使其值为。

我的要求是从我在单元测试类中提供的模拟值设置属性值。

我最终可以借助以下方法解决这个问题。如果不是正确的方式,请告诉我:

实际班级:

class ActualClass(object):
    name=''

    def some_method(self):
        name=get_name_from_external_source()  #Say, returned name='ActualValue' 
        print name 

单元测试类:

from mock import PropertyMock
import unittest
class TestActualClass(unittest.TestCase):
    def test_some_method(self):
        actual_class=ActualClass()
        p=PropertyMock(return_value='Mocked_Name')
        type(actual_class).name=p
        actual_class.some_method()

当您通过正常执行在ActualClass中运行some_method时,输出:

ActualValue

运行TestActualClass时,输出:

Mocked_Name

这意味着使用PropertyType使用模拟值模拟类属性,您可以使用模拟值测试方法,而无需担心外部源方法调用。