%PDF- %PDF-
Direktori : /lib/python3/dist-packages/hamcrest/core/core/ |
Current File : //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])