trait
HavePropertyMatcher[-T, P] extends (T) ⇒ HavePropertyMatchResult[P]
Concrete Value Members
-
final
def
!=(arg0: AnyRef): Boolean
-
final
def
!=(arg0: Any): Boolean
-
final
def
##(): Int
-
final
def
==(arg0: AnyRef): Boolean
-
final
def
==(arg0: Any): Boolean
-
-
final
def
asInstanceOf[T0]: T0
-
def
clone(): AnyRef
-
-
final
def
eq(arg0: AnyRef): Boolean
-
def
equals(arg0: Any): Boolean
-
def
finalize(): Unit
-
final
def
getClass(): Class[_]
-
def
hashCode(): Int
-
final
def
isInstanceOf[T0]: Boolean
-
final
def
ne(arg0: AnyRef): Boolean
-
final
def
notify(): Unit
-
final
def
notifyAll(): Unit
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
-
def
toString(): String
-
final
def
wait(): Unit
-
final
def
wait(arg0: Long, arg1: Int): Unit
-
final
def
wait(arg0: Long): Unit
Value Members
-
-
def
toString(): String
Inherited from AnyRef
Value Members
-
final
def
!=(arg0: AnyRef): Boolean
-
final
def
##(): Int
-
final
def
==(arg0: AnyRef): Boolean
-
def
clone(): AnyRef
-
final
def
eq(arg0: AnyRef): Boolean
-
def
equals(arg0: Any): Boolean
-
def
finalize(): Unit
-
final
def
getClass(): Class[_]
-
def
hashCode(): Int
-
final
def
ne(arg0: AnyRef): Boolean
-
final
def
notify(): Unit
-
final
def
notifyAll(): Unit
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
-
final
def
wait(): Unit
-
final
def
wait(arg0: Long, arg1: Int): Unit
-
final
def
wait(arg0: Long): Unit
Inherited from Any
Value Members
-
final
def
!=(arg0: Any): Boolean
-
final
def
==(arg0: Any): Boolean
-
final
def
asInstanceOf[T0]: T0
-
final
def
isInstanceOf[T0]: Boolean
Ungrouped
-
-
final
def
!=(arg0: AnyRef): Boolean
-
final
def
!=(arg0: Any): Boolean
-
final
def
##(): Int
-
final
def
==(arg0: AnyRef): Boolean
-
final
def
==(arg0: Any): Boolean
-
-
final
def
asInstanceOf[T0]: T0
-
def
clone(): AnyRef
-
-
final
def
eq(arg0: AnyRef): Boolean
-
def
equals(arg0: Any): Boolean
-
def
finalize(): Unit
-
final
def
getClass(): Class[_]
-
def
hashCode(): Int
-
final
def
isInstanceOf[T0]: Boolean
-
final
def
ne(arg0: AnyRef): Boolean
-
final
def
notify(): Unit
-
final
def
notifyAll(): Unit
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
-
def
toString(): String
-
final
def
wait(): Unit
-
final
def
wait(arg0: Long, arg1: Int): Unit
-
final
def
wait(arg0: Long): Unit
Trait extended by matcher objects, which may appear after the word
have
, that can match against a property of the type specified by theHavePropertyMatcher
's second type parameterP
.HavePropertyMatcher
's first type parameter,T
, specifies the type that declares the property. The match will succeed if and only if the value of the property equals the specified value. The object containing the property is passed to theHavePropertyMatcher
'sapply
method. The result is aHavePropertyMatchResult[P]
. AHavePropertyMatcher
is, therefore, a function from the specified type,T
, to aHavePropertyMatchResult[P]
.Although
HavePropertyMatcher
andMatcher
represent similar concepts, they have no inheritance relationship becauseMatcher
is intended for use right aftershould
ormust
whereasHavePropertyMatcher
is intended for use right afterhave
.A
HavePropertyMatcher
essentially allows you to write statically typed property assertions similar to the dynamic ones that use symbols:One good way to organize custom matchers is to place them inside one or more traits that you can then mix into the suites or specs that need them. Here's an example that includes two methods that produce
HavePropertyMatcher
s:Each time the
title
method is called, it returns a newHavePropertyMatcher[Book, String]
that can be used to match against thetitle
property of theBook
passed to itsapply
method. Because the type parameter of these twoHavePropertyMatcher
s isBook
, they can only be used with instances of that type. (The compiler will enforce this.) The match will succeed if thetitle
property equals the value passed asexpectedValue
. If the match succeeds, thematches
field of the returnedHavePropertyMatchResult
will betrue
. The second field,propertyName
, is simply the string name of the property. The third and fourth fields,expectedValue
andactualValue
indicate the expected and actual values, respectively, for the property. Here's an example that uses theseHavePropertyMatchers
:These matches should succeed, but if for example the first property,
title ("Moby Dick")
, were to fail, you would get an error message like:For more information on
HavePropertyMatchResult
and the meaning of its fields, please see the documentation forHavePropertyMatchResult
. To understand whyHavePropertyMatcher
is contravariant in its type parameter, see the section entitled "Matcher's variance" in the documentation forMatcher
.