小编jku*_*urs的帖子

如何模拟辅助类的 init

我在检查一个对象是否是使用另一个对象实例的正确参数构造时遇到问题。在下面的示例中,我尝试B在 的实例中创建 的实例AB我想检查实例内部构造函数中使用的参数A。当我运行下面的测试时,我得到:

AssertionError: assert None
[CPython36:setup:stdout] E        +  where None = <bound method NonCallableMock.assert_called_with of <MagicMock name='B' id='139968329210736'>>(4)
[CPython36:setup:stdout] E        +    where <bound method NonCallableMock.assert_called_with of <MagicMock name='B' id='139968329210736'>> = <MagicMock name='B' id='139968329210736'>.assert_called_with
Run Code Online (Sandbox Code Playgroud)

我不太确定我在这里做错了什么,并查看了其他堆栈溢出帖子,但无法解决我的问题。

b.py:

class B(object):
    def __init__(self, x):
        self.x = x

    def square(self):
        return x * x
Run Code Online (Sandbox Code Playgroud)

a.py:

from b import B

class A(object):
    def foo(self):
        b = B(4)
        b.square()
Run Code Online (Sandbox Code Playgroud)

测试_a.py:

import unittest
from unittest.mock import patch

from a …
Run Code Online (Sandbox Code Playgroud)

python unit-testing mocking pytest python-3.x

-1
推荐指数
1
解决办法
487
查看次数

标签 统计

mocking ×1

pytest ×1

python ×1

python-3.x ×1

unit-testing ×1