File: //proc/self/root/lib/python3/dist-packages/hamcrest/core/core/allof.py
from hamcrest.core.base_matcher import BaseMatcher
from hamcrest.core.helpers.wrap_matcher import wrap_matcher
__author__ = "Jon Reid"
__copyright__ = "Copyright 2011 hamcrest.org"
__license__ = "BSD, see License.txt"
class AllOf(BaseMatcher):
def __init__(self, *matchers):
self.matchers = matchers
def matches(self, item, mismatch_description=None):
for matcher in self.matchers:
if not matcher.matches(item):
if mismatch_description:
mismatch_description.append_description_of(matcher) \
.append_text(' ')
matcher.describe_mismatch(item, mismatch_description)
return False
return True
def describe_mismatch(self, item, mismatch_description):
self.matches(item, mismatch_description)
def describe_to(self, description):
description.append_list('(', ' and ', ')', self.matchers)
def all_of(*items):
"""Matches if all of the given matchers evaluate to ``True``.
:param matcher1,...: A comma-separated list of matchers.
The matchers are evaluated from left to right using short-circuit
evaluation, so evaluation stops as soon as a matcher returns ``False``.
Any argument that is not a matcher is implicitly wrapped in an
:py:func:`~hamcrest.core.core.isequal.equal_to` matcher to check for
equality.
"""
return AllOf(*[wrap_matcher(item) for item in items])