mirror of
https://github.com/kevin1024/vcrpy.git
synced 2025-12-09 09:13:23 +00:00
This helps to figure out which matcher has decided your two cassettes differ, and figure out when your cassettes have hit the network. Closes #34
37 lines
712 B
Python
37 lines
712 B
Python
import logging
|
|
log = logging.getLogger(__name__)
|
|
|
|
def method(r1, r2):
|
|
return r1.method == r2.method
|
|
|
|
|
|
def url(r1, r2):
|
|
return r1.url == r2.url
|
|
|
|
|
|
def host(r1, r2):
|
|
return r1.host == r2.host
|
|
|
|
|
|
def path(r1, r2):
|
|
return r1.path == r2.path
|
|
|
|
|
|
def body(r1, r2):
|
|
return r1.body == r2.body
|
|
|
|
|
|
def headers(r1, r2):
|
|
return r1.headers == r2.headers
|
|
|
|
|
|
def _log_matches(matches):
|
|
differences = [m for m in matches if not m[0]]
|
|
if differences:
|
|
log.debug('Requests differ according to the following matchers: {0}'.format(differences))
|
|
|
|
def requests_match(r1, r2, matchers):
|
|
matches = [(m(r1, r2), m) for m in matchers]
|
|
_log_matches(matches)
|
|
return all([m[0] for m in matches])
|