Completed
Pull Request — master (#79)
by
unknown
30s
created

src.hamcrest.core.core.Is   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 13
Duplicated Lines 0 %
Metric Value
dl 0
loc 13
rs 10
wmc 4

4 Methods

Rating   Name   Duplication   Size   Complexity  
A Is.matches() 0 2 1
A Is.describe_to() 0 2 1
A Is.describe_mismatch() 0 2 1
A Is.__init__() 0 2 1
1
from __future__ import absolute_import
2
__author__ = "Jon Reid"
3
__copyright__ = "Copyright 2011 hamcrest.org"
4
__license__ = "BSD, see License.txt"
5
6
from hamcrest.core.base_matcher import BaseMatcher
7
from hamcrest.core.helpers.wrap_matcher import wrap_matcher, is_matchable_type
8
from .isinstanceof import instance_of
9
10
11
class Is(BaseMatcher):
12
13
    def __init__(self, matcher):
14
        self.matcher = matcher
15
16
    def matches(self, item, mismatch_description=None):
17
        return self.matcher.matches(item, mismatch_description)
18
19
    def describe_mismatch(self, item, mismatch_description):
20
        return self.matcher.describe_mismatch(item, mismatch_description)
21
22
    def describe_to(self, description):
23
        description.append_description_of(self.matcher)
24
25
26
def wrap_value_or_type(x):
27
    if is_matchable_type(x):
28
        return instance_of(x)
29
    else:
30
        return wrap_matcher(x)
31
32
33
def is_(x):
34
    """Decorates another matcher, or provides shortcuts to the frequently used
35
    ``is(equal_to(x))`` and ``is(instance_of(x))``.
36
37
    :param x: The matcher to satisfy,  or a type for
38
        :py:func:`~hamcrest.core.core.isinstanceof.instance_of` matching, or an
39
        expected value for :py:func:`~hamcrest.core.core.isequal.equal_to`
40
        matching.
41
42
    This matcher compares the evaluated object to the given matcher.
43
44
    .. note::
45
46
        PyHamcrest's ``is_`` matcher is unrelated to Python's ``is`` operator.
47
        The matcher for object identity is
48
        :py:func:`~hamcrest.core.core.issame.same_instance`.
49
50
    If the ``x`` argument is a matcher, its behavior is retained, but the test
51
    may be more expressive. For example::
52
53
        assert_that(value, less_than(5))
54
        assert_that(value, is_(less_than(5)))
55
56
    If the ``x`` argument is a type, it is wrapped in an
57
    :py:func:`~hamcrest.core.core.isinstanceof.instance_of` matcher. This makes
58
    the following statements equivalent::
59
60
        assert_that(cheese, instance_of(Cheddar))
61
        assert_that(cheese, is_(instance_of(Cheddar)))
62
        assert_that(cheese, is_(Cheddar))
63
64
    Otherwise, if the ``x`` argument is not a matcher, it is wrapped in an
65
    :py:func:`~hamcrest.core.core.isequal.equal_to` matcher. This makes the
66
    following statements equivalent::
67
68
        assert_that(cheese, equal_to(smelly))
69
        assert_that(cheese, is_(equal_to(smelly)))
70
        assert_that(cheese, is_(smelly))
71
72
    Choose the style that makes your expression most readable. This will vary
73
    depending on context.
74
75
    """
76
    return Is(wrap_value_or_type(x))
77