mirror of
https://github.com/kevin1024/vcrpy.git
synced 2025-12-09 01:03:24 +00:00
feat(failure-message): reformat the message with the best requests matches (#459)
The message is less verbose and the display is improved for a better readability.
This commit is contained in:
73
tests/unit/test_errors.py
Normal file
73
tests/unit/test_errors.py
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
import pytest
|
||||||
|
|
||||||
|
from vcr.compat import mock
|
||||||
|
from vcr import errors
|
||||||
|
from vcr.cassette import Cassette
|
||||||
|
|
||||||
|
|
||||||
|
@mock.patch("vcr.cassette.Cassette.find_requests_with_most_matches")
|
||||||
|
@pytest.mark.parametrize(
|
||||||
|
"most_matches, expected_message",
|
||||||
|
[
|
||||||
|
# No request match found
|
||||||
|
(
|
||||||
|
[],
|
||||||
|
"No similar requests, that have not been played, found."
|
||||||
|
),
|
||||||
|
# One matcher failed
|
||||||
|
(
|
||||||
|
[("similar request", ["method", "path"], [("query", "failed : query")])],
|
||||||
|
"Found 1 similar requests with 1 different matcher(s) :\n"
|
||||||
|
"\n1 - ('similar request').\n"
|
||||||
|
"Matchers succeeded : ['method', 'path']\n"
|
||||||
|
"Matchers failed :\n"
|
||||||
|
"query - assertion failure :\n"
|
||||||
|
"failed : query\n"
|
||||||
|
|
||||||
|
),
|
||||||
|
# Multiple failed matchers
|
||||||
|
(
|
||||||
|
[("similar request", ["method"], [("query", "failed : query"), ("path", "failed : path")])],
|
||||||
|
"Found 1 similar requests with 2 different matcher(s) :\n"
|
||||||
|
"\n1 - ('similar request').\n"
|
||||||
|
"Matchers succeeded : ['method']\n"
|
||||||
|
"Matchers failed :\n"
|
||||||
|
"query - assertion failure :\n"
|
||||||
|
"failed : query\n"
|
||||||
|
"path - assertion failure :\n"
|
||||||
|
"failed : path\n"
|
||||||
|
|
||||||
|
),
|
||||||
|
# Multiple similar requests
|
||||||
|
(
|
||||||
|
[
|
||||||
|
("similar request", ["method"], [("query", "failed : query")]),
|
||||||
|
("similar request 2", ["method"], [("query", "failed : query 2")])
|
||||||
|
],
|
||||||
|
"Found 2 similar requests with 1 different matcher(s) :\n"
|
||||||
|
"\n1 - ('similar request').\n"
|
||||||
|
"Matchers succeeded : ['method']\n"
|
||||||
|
"Matchers failed :\n"
|
||||||
|
"query - assertion failure :\n"
|
||||||
|
"failed : query\n"
|
||||||
|
"\n2 - ('similar request 2').\n"
|
||||||
|
"Matchers succeeded : ['method']\n"
|
||||||
|
"Matchers failed :\n"
|
||||||
|
"query - assertion failure :\n"
|
||||||
|
"failed : query 2\n"
|
||||||
|
|
||||||
|
),
|
||||||
|
]
|
||||||
|
)
|
||||||
|
def test_CannotOverwriteExistingCassetteException_get_message(
|
||||||
|
mock_find_requests_with_most_matches, most_matches, expected_message):
|
||||||
|
mock_find_requests_with_most_matches.return_value = most_matches
|
||||||
|
cassette = Cassette("path")
|
||||||
|
failed_request = "request"
|
||||||
|
exception_message = errors.CannotOverwriteExistingCassetteException._get_message(
|
||||||
|
cassette, "request"
|
||||||
|
)
|
||||||
|
expected = "Can't overwrite existing cassette (%r) in your current record mode (%r).\n" \
|
||||||
|
"No match for the request (%r) was found.\n" \
|
||||||
|
"%s" % (cassette._path, cassette.record_mode, failed_request, expected_message)
|
||||||
|
assert exception_message == expected
|
||||||
@@ -204,17 +204,13 @@ def test_evaluate_matcher_does_not_match_with_assert_message():
|
|||||||
|
|
||||||
|
|
||||||
def test_get_assertion_message():
|
def test_get_assertion_message():
|
||||||
assert matchers.get_assertion_message(None) == ""
|
assert matchers.get_assertion_message(None) is None
|
||||||
assert matchers.get_assertion_message("") == ""
|
assert matchers.get_assertion_message("") == ""
|
||||||
|
|
||||||
|
|
||||||
def test_get_assertion_message_with_details():
|
def test_get_assertion_message_with_details():
|
||||||
assertion_msg = "q1=1 != q2=1"
|
assertion_msg = "q1=1 != q2=1"
|
||||||
expected = (
|
expected = assertion_msg
|
||||||
"--------------- DETAILS ---------------\n"
|
|
||||||
"{}\n"
|
|
||||||
"----------------------------------------\n".format(assertion_msg)
|
|
||||||
)
|
|
||||||
assert matchers.get_assertion_message(assertion_msg) == expected
|
assert matchers.get_assertion_message(assertion_msg) == expected
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -5,21 +5,27 @@ class CannotOverwriteExistingCassetteException(Exception):
|
|||||||
message = self._get_message(kwargs["cassette"], kwargs["failed_request"])
|
message = self._get_message(kwargs["cassette"], kwargs["failed_request"])
|
||||||
super(CannotOverwriteExistingCassetteException, self).__init__(message)
|
super(CannotOverwriteExistingCassetteException, self).__init__(message)
|
||||||
|
|
||||||
def _get_message(self, cassette, failed_request):
|
@staticmethod
|
||||||
|
def _get_message(cassette, failed_request):
|
||||||
"""Get the final message related to the exception"""
|
"""Get the final message related to the exception"""
|
||||||
# Get the similar requests in the cassette that
|
# Get the similar requests in the cassette that
|
||||||
# have match the most with the request.
|
# have match the most with the request.
|
||||||
best_matches = cassette.find_requests_with_most_matches(failed_request)
|
best_matches = cassette.find_requests_with_most_matches(failed_request)
|
||||||
# Build a comprehensible message to put in the exception.
|
if best_matches:
|
||||||
best_matches_msg = ""
|
# Build a comprehensible message to put in the exception.
|
||||||
for best_match in best_matches:
|
best_matches_msg = "Found {} similar requests with {} different matcher(s) :\n".format(
|
||||||
request, _, failed_matchers_assertion_msgs = best_match
|
len(best_matches), len(best_matches[0][2]))
|
||||||
best_matches_msg += "Similar request found : (%r).\n" % request
|
|
||||||
for failed_matcher, assertion_msg in failed_matchers_assertion_msgs:
|
for idx, best_match in enumerate(best_matches, start=1):
|
||||||
best_matches_msg += "Matcher failed : %s\n" "%s\n" % (
|
request, succeeded_matchers, failed_matchers_assertion_msgs = best_match
|
||||||
failed_matcher,
|
best_matches_msg += "\n%s - (%r).\n" \
|
||||||
assertion_msg,
|
"Matchers succeeded : %s\n" \
|
||||||
)
|
"Matchers failed :\n" % (idx, request, succeeded_matchers)
|
||||||
|
for failed_matcher, assertion_msg in failed_matchers_assertion_msgs:
|
||||||
|
best_matches_msg += "%s - assertion failure :\n" \
|
||||||
|
"%s\n" % (failed_matcher, assertion_msg)
|
||||||
|
else:
|
||||||
|
best_matches_msg = "No similar requests, that have not been played, found."
|
||||||
return (
|
return (
|
||||||
"Can't overwrite existing cassette (%r) in "
|
"Can't overwrite existing cassette (%r) in "
|
||||||
"your current record mode (%r).\n"
|
"your current record mode (%r).\n"
|
||||||
|
|||||||
@@ -135,21 +135,8 @@ def get_matchers_results(r1, r2, matchers):
|
|||||||
return matches_success, matches_fails
|
return matches_success, matches_fails
|
||||||
|
|
||||||
|
|
||||||
def get_assertion_message(assertion_details, **format_options):
|
def get_assertion_message(assertion_details):
|
||||||
"""
|
"""
|
||||||
Get a detailed message about the failing matcher.
|
Get a detailed message about the failing matcher.
|
||||||
"""
|
"""
|
||||||
msg = ""
|
return assertion_details
|
||||||
if assertion_details:
|
|
||||||
separator = format_options.get("separator", "-")
|
|
||||||
title = format_options.get("title", " DETAILS ")
|
|
||||||
nb_separator = format_options.get("nb_separator", 40)
|
|
||||||
first_title_line = (
|
|
||||||
separator * ((nb_separator - len(title)) // 2)
|
|
||||||
+ title
|
|
||||||
+ separator * ((nb_separator - len(title)) // 2)
|
|
||||||
)
|
|
||||||
msg += "{}\n{}\n{}\n".format(
|
|
||||||
first_title_line, str(assertion_details), separator * nb_separator
|
|
||||||
)
|
|
||||||
return msg
|
|
||||||
|
|||||||
Reference in New Issue
Block a user