Wrapper class that adds a value method to LeftProjection, allowing
you to make statements like:
Wrapper class that adds a value method to LeftProjection, allowing
you to make statements like:
either.left.value should be > 9
Wrapper class that adds a value method to RightProjection, allowing
you to make statements like:
Wrapper class that adds a value method to RightProjection, allowing
you to make statements like:
either.right.value should be > 9
Implicit conversion that adds a value method to LeftProjection.
Implicit conversion that adds a value method to LeftProjection.
Implicit conversion that adds a value method to RightProjection.
Implicit conversion that adds a value method to RightProjection.
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:either1.right.value should be > 9 either2.left.value should be ("Muchas problemas")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:val either: Either[String, Int] = Left("Muchas problemas") either.right.get should be > 9 // either.right.get throws NoSuchElementExceptionThe
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:val either: Either[String, Int] = Left("Muchas problemas") either should be ('right) // throws TestFailedException either.right.get should be > 9The
EitherValuestrait allows you to state that more concisely:val either: Either[String, Int] = Left("Muchas problemas") either.right.value should be > 9 // either.right.value throws TestFailedException