2013-04-17 4 views
9

Tak, właśnie zacząłem używać makiety z projektem Django. Próbuję wyśmiewać część widoku, która wysyła żądanie do zdalnego interfejsu API, aby potwierdzić, że żądanie subskrypcji było autentyczne (forma weryfikacji zgodnie ze specyfikacją, do której pracuję).Python mock, django i wnioski

Co mam podobny:

class SubscriptionView(View): 
    def post(self, request, **kwargs): 
     remote_url = request.POST.get('remote_url') 
     if remote_url: 
      response = requests.get(remote_url, params={'verify': 'hello'}) 

     if response.status_code != 200: 
      return HttpResponse('Verification of request failed') 

Co ja teraz chce zrobić jest użycie makiety wyśmiewać się z połączenia requests.get zmienić odpowiedź, ale nie mogę dowiedzieć się, jak to zrobić dla dekorator łat. Pomyślałem, że zrobiłeś coś takiego:

@patch(requests.get) 
def test_response_verify(self): 
    # make a call to the view using self.app.post (WebTest), 
    # requests.get makes a suitable fake response from the mock object 

Jak to osiągnąć?

+0

Deadset przy użyciu mocks? Istnieje również django.test.client.RequestFactory - https://docs.djangoproject.com/en/1.5/topics/testing/advanced/#module-django.test.client – David

+3

Tylko dla przyszłych widzów, osoba przesłuchująca chciała drwić out zewnętrznego wywołania API. Nie wezwanie do samego widoku. Mocks wydają się bardzo rozsądne w tej sytuacji. – aychedee

+0

Zgodnie z @yychedee to jest rzeczywiście to, do czego dążyłem przy tym pytaniu. – jvc26

Odpowiedz

11

jesteś prawie tam. Po prostu nazywasz to trochę niepoprawnie.

from mock import call, patch 


@patch('my_app.views.requests') 
def test_response_verify(self, mock_requests): 
    # We setup the mock, this may look like magic but it works, return_value is 
    # a special attribute on a mock, it is what is returned when it is called 
    # So this is saying we want the return value of requests.get to have an 
    # status code attribute of 200 
    mock_requests.get.return_value.status_code = 200 

    # Here we make the call to the view 
    response = SubscriptionView().post(request, {'remote_url': 'some_url'}) 

    self.assertEqual(
     mock_requests.get.call_args_list, 
     [call('some_url', params={'verify': 'hello'})] 
    ) 

Można również sprawdzić, czy odpowiedź jest poprawna i ma właściwą treść.

3

To wszystko w the documentation:

łata (target, new = DEFAULT, Spec = None, tworzyć = False, spec_set = None, Autospec = None, new_callable = None, ** kwargs)

target powinien być łańcuchem znaków w postaci "package.module.ClassName".

from mock import patch 

# or @patch('requests.get') 
@patch.object(requests, 'get') 
def test_response_verify(self): 
    # make a call to the view using self.app.post (WebTest), 
    # requests.get makes a suitable fake response from the mock object