1
0
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:
Marc Abramowitz
2013-12-19 15:41:04 -08:00
parent 624212ef15
commit a6806f2f99
2 changed files with 15 additions and 9 deletions

View File

@@ -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')

View File

@@ -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}