Source code for pook.matcher

[docs] class MatcherEngine(list): """ HTTP request matcher engine used by `pook.Mock` to test if an intercepted outgoing HTTP request must be mocked out or not. """
[docs] def add(self, matcher): """ Adds a new matcher function to the current engine. Arguments: matcher (function): matcher function to be added. """ self.append(matcher)
[docs] def flush(self): """ Flushes the current matcher engine, removing all the registered matcher functions. """ self.clear()
[docs] def match(self, request): """ Match the given HTTP request instance against the registered matcher functions in the current engine. Arguments: request (pook.Request): outgoing request to match. Returns: tuple(bool, list[Exception]): ``True`` if all matcher tests passes, otherwise ``False``. Also returns an optional list of error exceptions. """ errors = [] def match(matcher): try: return matcher.match(request) except Exception as err: err = "{}: {}".format(type(matcher).__name__, err) errors.append(err) return False return all([match(matcher) for matcher in self]), errors
def __repr__(self): """ Returns an human friendly readable instance data representation. Returns: str """ matchers = [repr(matcher) for matcher in self] return "MatcherEngine([\n {}\n])".format(",\n ".join(matchers))