mirror of
https://github.com/kevin1024/vcrpy.git
synced 2025-12-10 01:25:34 +00:00
Nicer error when cassette doesn't contain request
Raise UnhandledHTTPRequestError. Show name of cassette and request.
This commit is contained in:
@@ -1,7 +1,7 @@
|
|||||||
import pytest
|
import pytest
|
||||||
import yaml
|
import yaml
|
||||||
import mock
|
import mock
|
||||||
from vcr.cassette import Cassette
|
from vcr.cassette import Cassette, UnhandledHTTPRequestError
|
||||||
|
|
||||||
|
|
||||||
def test_cassette_load(tmpdir):
|
def test_cassette_load(tmpdir):
|
||||||
@@ -53,7 +53,7 @@ def test_cassette_responses_of():
|
|||||||
@mock.patch('vcr.cassette.requests_match', _mock_requests_match)
|
@mock.patch('vcr.cassette.requests_match', _mock_requests_match)
|
||||||
def test_cassette_get_missing_response():
|
def test_cassette_get_missing_response():
|
||||||
a = Cassette('test')
|
a = Cassette('test')
|
||||||
with pytest.raises(KeyError):
|
with pytest.raises(UnhandledHTTPRequestError):
|
||||||
a.responses_of('foo')
|
a.responses_of('foo')
|
||||||
|
|
||||||
@mock.patch('vcr.cassette.requests_match', _mock_requests_match)
|
@mock.patch('vcr.cassette.requests_match', _mock_requests_match)
|
||||||
@@ -61,5 +61,5 @@ def test_cassette_cant_read_same_request_twice():
|
|||||||
a = Cassette('test')
|
a = Cassette('test')
|
||||||
a.append('foo','bar')
|
a.append('foo','bar')
|
||||||
a.play_response('foo')
|
a.play_response('foo')
|
||||||
with pytest.raises(KeyError):
|
with pytest.raises(UnhandledHTTPRequestError):
|
||||||
a.play_response('foo')
|
a.play_response('foo')
|
||||||
|
|||||||
@@ -15,6 +15,10 @@ from .serializers import yamlserializer
|
|||||||
from .matchers import requests_match, url, method
|
from .matchers import requests_match, url, method
|
||||||
|
|
||||||
|
|
||||||
|
class UnhandledHTTPRequestError(Exception):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
class Cassette(ContextDecorator):
|
class Cassette(ContextDecorator):
|
||||||
'''A container for recorded requests and responses'''
|
'''A container for recorded requests and responses'''
|
||||||
|
|
||||||
@@ -73,9 +77,10 @@ class Cassette(ContextDecorator):
|
|||||||
if self.play_counts[index] == 0:
|
if self.play_counts[index] == 0:
|
||||||
self.play_counts[index] += 1
|
self.play_counts[index] += 1
|
||||||
return response
|
return response
|
||||||
# I decided that a KeyError is the best exception to raise
|
# The cassette doesn't contain the request asked for.
|
||||||
# if the cassette doesn't contain the request asked for.
|
raise UnhandledHTTPRequestError(
|
||||||
raise KeyError
|
"The cassette (%r) doesn't contain the request (%r) asked for"
|
||||||
|
% (self._path,request))
|
||||||
|
|
||||||
def responses_of(self, request):
|
def responses_of(self, request):
|
||||||
'''
|
'''
|
||||||
@@ -89,9 +94,10 @@ class Cassette(ContextDecorator):
|
|||||||
|
|
||||||
if responses:
|
if responses:
|
||||||
return responses
|
return responses
|
||||||
# I decided that a KeyError is the best exception to raise
|
# The cassette doesn't contain the request asked for.
|
||||||
# if the cassette doesn't contain the request asked for.
|
raise UnhandledHTTPRequestError(
|
||||||
raise KeyError
|
"The cassette (%r) doesn't contain the request (%r) asked for"
|
||||||
|
% (self._path,request))
|
||||||
|
|
||||||
def _as_dict(self):
|
def _as_dict(self):
|
||||||
return {"requests": self.requests, "responses": self.responses}
|
return {"requests": self.requests, "responses": self.responses}
|
||||||
|
|||||||
Reference in New Issue
Block a user