Quiero entender cómo @patch
funciona una función desde un módulo importado.
Aquí es donde estoy hasta ahora.
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()
Esto no funciona como esperaba. El módulo "parcheado" simplemente devuelve el valor no manipulado de get_user_name
. ¿Cómo puedo simular métodos de otros paquetes que estoy importando en un espacio de nombres bajo prueba?
Mock
, que se incluye en python3.3 + asunittest.mock
.