summaryrefslogtreecommitdiff
path: root/Lib/unittest/mock.py
diff options
context:
space:
mode:
authorXtreak <tir.karthi@gmail.com>2019-04-22 08:00:23 +0530
committerBerker Peksag <berker.peksag@gmail.com>2019-04-22 05:30:23 +0300
commit9b21856b0fcda949de239edc7aa6cf3f2f4f77a3 (patch)
tree67b8f216a06b29748f5e573d5ab855b3462752e7 /Lib/unittest/mock.py
parent9541bd321a94f13dc41163a5d7a1a847816fac84 (diff)
downloadcpython-git-9b21856b0fcda949de239edc7aa6cf3f2f4f77a3.tar.gz
bpo-23078: Add support for {class,static}method to mock.create_autospec() (GH-11613)
Co-authored-by: Felipe <felipe.nospam.ochoa@gmail.com>
Diffstat (limited to 'Lib/unittest/mock.py')
-rw-r--r--Lib/unittest/mock.py4
1 files changed, 3 insertions, 1 deletions
diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py
index 0e77f0e489..1636073ff0 100644
--- a/Lib/unittest/mock.py
+++ b/Lib/unittest/mock.py
@@ -29,7 +29,7 @@ import inspect
import pprint
import sys
import builtins
-from types import ModuleType
+from types import ModuleType, MethodType
from unittest.util import safe_repr
from functools import wraps, partial
@@ -122,6 +122,8 @@ def _copy_func_details(func, funcopy):
def _callable(obj):
if isinstance(obj, type):
return True
+ if isinstance(obj, (staticmethod, classmethod, MethodType)):
+ return _callable(obj.__func__)
if getattr(obj, '__call__', None) is not None:
return True
return False