Я хотел бы изменить аргументы, переданные методу в модуле, в отличие от замены его возвращаемого значения.
Я нашел способ обойти это, но он кажется чем-то полезным и превратился в урок в насмешек.
module.py
from third_party import ThirdPartyClass
ThirdPartyClass.do_something('foo', 'bar')
ThirdPartyClass.do_something('foo', 'baz')
tests.py
@mock.patch('module.ThirdPartyClass.do_something')
def test(do_something):
# Instead of directly overriding its return value
# I'd like to modify the arguments passed to this function.
# change return value, no matter inputs
do_something.return_value = 'foo'
# change return value, based on inputs, but have no access to the original function
do_something.side_effect = lambda x, y: y, x
# how can I wrap do_something, so that I can modify its inputs and pass it back to the original function?
# much like a decorator?
Я пробовал что-то вроде следующего, но не только он повторяющийся и уродливый, он не работает. После некоторой интроспекции PDB. Мне интересно, просто ли это из-за того, что эта сторонняя библиотека работает, так как я вижу, как оригинальные функции вызываются успешно, когда я бросаю pdb внутри side_effect
.
Либо это, либо какая-то автоматическая насмешка магии, я просто не слежу за тем, что мне очень хотелось бы узнать.
def test():
from third_party import ThirdPartyClass
original_do_something = ThirdPartyClass.do_something
with mock.patch('module.ThirdPartyClass.do_something' as mocked_do_something:
def side_effect(arg1, arg2):
return original_do_something(arg1, 'overridden')
mocked_do_something.side_effect = side_effect
# execute module.py
Приветствуется любое руководство!