trait
ShouldVerb extends AnyRef
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
-
implicit
def
convertToStringShouldWrapper(o: String): StringShouldWrapperForVerb
-
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
Inherited from AnyRef
Inherited from Any
Provides an implicit conversion that adds
should
methods toString
to support the syntax ofFlatSpec
,WordSpec
,org.scalatest.fixture.FlatSpec
, andorg.scalatest.fixture.WordSpec
.For example, this trait enables syntax such as the following test registration in
FlatSpec
andorg.scalatest.fixture.FlatSpec
:It also enables syntax such as the following shared test registration in
FlatSpec
andorg.scalatest.fixture.FlatSpec
:"A Stack (with one item)" should behave like nonEmptyStack(stackWithOneItem, lastValuePushed) ^
In addition, it supports the registration of subject descriptions in
WordSpec
andorg.scalatest.fixture.WordSpec
, such as:"A Stack (when empty)" should { ... ^
And finally, it also supportds the registration of subject descriptions with after words in
WordSpec
andorg.scalatest.fixture.WordSpec
. For example:The reason this implicit conversion is provided in a separate trait, instead of being provided directly in
FlatSpec
,WordSpec
,org.scalatest.fixture.FlatSpec
, andorg.scalatest.fixture.WordSpec
, is because an implicit conversion provided directly would conflict with the implicit conversion that providesshould
methods onString
in theShouldMatchers
trait. By contrast, there is no conflict with the separateShouldVerb
trait approach, because:FlatSpec
,WordSpec
,org.scalatest.fixture.FlatSpec
, andorg.scalatest.fixture.WordSpec
mix inShouldVerb
directly, andShouldMatchers
extendsShouldVerb
, overriding theconvertToStringShouldWrapper
implicit conversion function.So whether or not a
FlatSpec
,WordSpec
,org.scalatest.fixture.FlatSpec
, ororg.scalatest.fixture.WordSpec
mixes inShouldMatchers
, there will only be one implicit conversion in scope that addsshould
methods toString
s.Also, because the class of the result of the overriding
convertToStringShouldWrapper
implicit conversion method provided inShouldMatchers
extends this trait'sStringShouldWrapperForVerb
class, the four uses ofshould
provided here are still available. These fourshould
are in fact available to any class that mixes inShouldMatchers
, but each takes an implicit parameter that is provided only inFlatSpec
andorg.scalatest.fixture.FlatSpec
, orWordSpec
andorg.scalatest.fixture.WordSpec
.