加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – TypeError:尝试模拟classmethod时的未绑定方法

发布时间:2020-12-16 23:33:39 所属栏目:Python 来源:网络整理
导读:此脚本失败: import mockclass MyClass(object): @classmethod def my_method(cls): print('my_method')def mocked_method(cls): print('I want this method to get called')with mock.patch.object(MyClass,'my_method',mocked_method): MyClass.my_method
此脚本失败:
import mock

class MyClass(object):

    @classmethod
    def my_method(cls):
        print('my_method')

def mocked_method(cls):
    print('I want this method to get called')

with mock.patch.object(MyClass,'my_method',mocked_method):
    MyClass.my_method()

例外:

Traceback (most recent call last):
  File "/home/foo/tmp/test_mocking_classmethod.py",line 14,in <module>
    MyClass.my_method()
TypeError: unbound method mocked_method() must be called with MyClass instance as first argument (got nothing instead)

解决方法

Python函数是 descriptors,Python将这些函数绑定到它们被查找的实例,或者在classmethod的情况下,绑定到类.因为你没有在替换函数上使用classmethod装饰器,所以它被错误地绑定(作为常规方法,因此没有传入cls).

只需手动将目标包装在classmethod装饰器中:

with mock.patch.object(MyClass,classmethod(mocked_method)):
    MyClass.my_method()

这里我手动应用了@classmethod装饰器,但您也可以直接在目标函数上使用它作为装饰器:

@classmethod
def mocked_method(cls):
    print('I want this method to get called')

with mock.patch.object(MyClass,mocked_method):
    MyClass.my_method()

演示:

>>> import mock
>>> class MyClass(object):
...     @classmethod
...     def my_method(cls):
...         print('my_method')
... 
>>> def mocked_method(cls):
...     print('I want this method to get called')
... 
>>> with mock.patch.object(MyClass,classmethod(mocked_method)):
...     MyClass.my_method()
... 
I want this method to get called

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读