trait
EitherValues 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
convertLeftProjectionToValuable[L, R](leftProj: LeftProjection[L, R]): LeftValuable[L, R]
-
implicit
def
convertRightProjectionToValuable[L, R](rightProj: RightProjection[L, R]): RightValuable[L, R]
-
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
Trait that provides an implicit conversion that adds
left.valueandright.valuemethods toEither, which will return the selected value of theEitherif defined, or throwTestFailedExceptionif not.This construct allows you to express in one statement that an
Eithershould be left or right and that its value should meet some expectation. Here's are some examples:Or, using assertions instead of matcher expressions:
Were you to simply invoke
right.getorleft.geton theEither, if theEitherwasn't defined as expected (e.g., it was aLeftwhen you expected aRight), it would throw aNoSuchElementException:The
NoSuchElementExceptionwould cause the test to fail, but without providing a stack depth pointing to the failing line of test code. This stack depth, provided byTestFailedException(and a few other ScalaTest exceptions), makes it quicker for users to navigate to the cause of the failure. WithoutEitherValues, to get a stack depth exception you would need to make two statements, like this:The
EitherValuestrait allows you to state that more concisely: