Chcę zrozumieć, jak wykonać @patch
funkcję z zaimportowanego modułu.
To jest, gdzie jestem do tej pory.
app / mocking.py:
from app.my_module import get_user_name
def test_method():
return get_user_name()
if __name__ == "__main__":
print "Starting Program..."
test_method()
app / my_module / __ init__.py:
def get_user_name():
return "Unmocked User"
test / mock-test.py:
import unittest
from app.mocking import test_method
def mock_get_user():
return "Mocked This Silly"
@patch('app.my_module.get_user_name')
class MockingTestTestCase(unittest.TestCase):
def test_mock_stubs(self, mock_method):
mock_method.return_value = 'Mocked This Silly')
ret = test_method()
self.assertEqual(ret, 'Mocked This Silly')
if __name__ == '__main__':
unittest.main()
To nie działa tak, jak bym się spodziewał. „Połatany” moduł po prostu zwraca niezakodowaną wartość get_user_name
. Jak pozorować metody z innych pakietów, które importuję do testowanej przestrzeni nazw?
Mock
, która jest zawarta w python3.3 + asunittest.mock
.