有人能告诉我为什么这个不起作用吗?
>>> import mock
>>> @mock.patch('datetime.date.today')
... def today(cls):
... return date(2010, 1, 1)
...
>>> from datetime import date
>>> date.today()
datetime.date(2010, 12, 19)
也许有人能提出一个更好的方法?
发布于 2014-09-04 04:01:30
无论如何,模拟文档专门讨论了datetime.date.today,并且可以在不创建虚拟类的情况下实现这一点:
https://docs.python.org/3/library/unittest.mock-examples.html#partial-mocking
>>> from datetime import date
>>> with patch('mymodule.date') as mock_date:
... mock_date.today.return_value = date(2010, 10, 8)
... mock_date.side_effect = lambda *args, **kw: date(*args, **kw)
...
... assert mymodule.date.today() == date(2010, 10, 8)
... assert mymodule.date(2009, 6, 8) == date(2009, 6, 8)
...
发布于 2013-11-18 02:29:23
我想我来得有点晚了,但我认为这里的主要问题是您直接为datetime.date.today打补丁,根据文档,这是错误的。
例如,您应该修补在被测试函数所在的文件中导入的引用。
假设您有一个functions.py文件,其中包含以下内容:
import datetime
def get_today():
return datetime.date.today()
然后,在您的测试中,您应该有如下内容
import datetime
import unittest
from functions import get_today
from mock import patch, Mock
class GetTodayTest(unittest.TestCase):
@patch('functions.datetime')
def test_get_today(self, datetime_mock):
datetime_mock.date.today = Mock(return_value=datetime.strptime('Jun 1 2005', '%b %d %Y'))
value = get_today()
# then assert your thing...
希望这会有一点帮助。
发布于 2011-03-26 03:28:12
添加到Daniel G's solution的步骤
from datetime import date
class FakeDate(date):
"A manipulable date replacement"
def __new__(cls, *args, **kwargs):
return date.__new__(date, *args, **kwargs)
这将创建一个类,该类在实例化时将返回一个普通的datetime.date对象,但该对象也可以更改。
@mock.patch('datetime.date', FakeDate)
def test():
from datetime import date
FakeDate.today = classmethod(lambda cls: date(2010, 1, 1))
return date.today()
test() # datetime.date(2010, 1, 1)
https://stackoverflow.com/questions/4481954
复制相似问题