org.mockito.scalaz.IdiomaticMockitoScalaz.scala Maven / Gradle / Ivy
The newest version!
package org.mockito.scalaz
import scalaz.{ Applicative, Equal, MonadError }
import org.mockito._
import org.scalactic.Equality
import scala.reflect.ClassTag
trait IdiomaticMockitoScalaz extends ScalacticSerialisableHack {
import org.mockito.scalaz.IdiomaticMockitoScalaz._
implicit class StubbingOpsScalaz[F[_], T](stubbing: F[T]) {
def shouldReturnF: ReturnActions[F, T] = macro WhenMacro.shouldReturn[T]
def mustReturnF: ReturnActions[F, T] = macro WhenMacro.shouldReturn[T]
def returnsF: ReturnActions[F, T] = macro WhenMacro.shouldReturn[T]
def shouldFailWith: ThrowActions[F, T] = macro WhenMacro.shouldThrow[T]
def mustFailWith: ThrowActions[F, T] = macro WhenMacro.shouldThrow[T]
def failsWith: ThrowActions[F, T] = macro WhenMacro.shouldThrow[T]
def raises: ThrowActions[F, T] = macro WhenMacro.shouldThrow[T]
def shouldAnswerF: AnswerActions[F, T] = macro WhenMacro.shouldAnswer[T]
def mustAnswerF: AnswerActions[F, T] = macro WhenMacro.shouldAnswer[T]
def answersF: AnswerActions[F, T] = macro WhenMacro.shouldAnswer[T]
}
implicit class StubbingOps2Scalaz[F[_], G[_], T](stubbing: F[G[T]]) {
def shouldReturnFG: ReturnActions2[F, G, T] = macro WhenMacro.shouldReturn[T]
def mustReturnFG: ReturnActions2[F, G, T] = macro WhenMacro.shouldReturn[T]
def returnsFG: ReturnActions2[F, G, T] = macro WhenMacro.shouldReturn[T]
def shouldFailWithG: ThrowActions2[F, G, T] = macro WhenMacro.shouldThrow[T]
def mustFailWithG: ThrowActions2[F, G, T] = macro WhenMacro.shouldThrow[T]
def failsWithG: ThrowActions2[F, G, T] = macro WhenMacro.shouldThrow[T]
def raisesG: ThrowActions2[F, G, T] = macro WhenMacro.shouldThrow[T]
def shouldAnswerFG: AnswerActions2[F, G, T] = macro WhenMacro.shouldAnswer[T]
def mustAnswerFG: AnswerActions2[F, G, T] = macro WhenMacro.shouldAnswer[T]
def answersFG: AnswerActions2[F, G, T] = macro WhenMacro.shouldAnswer[T]
}
val returnedF: ReturnedF.type = ReturnedF
val answeredF: AnsweredF.type = AnsweredF
val returnedFG: ReturnedFG.type = ReturnedFG
val answeredFG: AnsweredFG.type = AnsweredFG
val raised: Raised.type = Raised
val raisedG: RaisedG.type = RaisedG
implicit class DoSomethingOpsScalaz[R](v: R) {
def willBe(r: ReturnedF.type): ReturnedByF[R] = ReturnedByF[R]()
def willBe(r: ReturnedFG.type): ReturnedByFG[R] = ReturnedByFG[R]()
def willBe(r: Raised.type): Raised[R] = Raised[R]()
def willBe(r: RaisedG.type): RaisedG[R] = RaisedG[R]()
def willBe(r: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(r: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps0Scalaz[R](v: () => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps1Scalaz[P0, R](v: P0 => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps2Scalaz[P0, P1, R](v: (P0, P1) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps3Scalaz[P0, P1, P2, R](v: (P0, P1, P2) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps4Scalaz[P0, P1, P2, P3, R](v: (P0, P1, P2, P3) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps5Scalaz[P0, P1, P2, P3, P4, R](v: (P0, P1, P2, P3, P4) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps6Scalaz[P0, P1, P2, P3, P4, P5, R](v: (P0, P1, P2, P3, P4, P5) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps7Scalaz[P0, P1, P2, P3, P4, P5, P6, R](v: (P0, P1, P2, P3, P4, P5, P6) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps8Scalaz[P0, P1, P2, P3, P4, P5, P6, P7, R](v: (P0, P1, P2, P3, P4, P5, P6, P7) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps9Scalaz[P0, P1, P2, P3, P4, P5, P6, P7, P8, R](v: (P0, P1, P2, P3, P4, P5, P6, P7, P8) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit class DoSomethingOps10Scalaz[P0, P1, P2, P3, P4, P5, P6, P7, P8, P9, R](v: (P0, P1, P2, P3, P4, P5, P6, P7, P8, P9) => R) {
def willBe(a: AnsweredF.type): AnsweredByF[R] = AnsweredByF[R]()
def willBe(a: AnsweredFG.type): AnsweredByFG[R] = AnsweredByFG[R]()
}
implicit def scalazEquality[T: Equal]: Equality[T] = new EqToEquality[T]
}
object IdiomaticMockitoScalaz extends IdiomaticMockitoScalaz {
object ReturnedF
case class ReturnedByF[T]() {
def by[F[_], S](stubbing: F[S])(implicit F: Applicative[F], $ev: T <:< S): F[S] = macro DoSomethingMacro.returnedF[T, S]
}
object AnsweredF
case class AnsweredByF[T]() {
def by[F[_], S](stubbing: F[S])(implicit F: Applicative[F], $ev: T <:< S): F[S] = macro DoSomethingMacro.answeredF[T, S]
}
object ReturnedFG
case class ReturnedByFG[T]() {
def by[F[_], G[_], S](stubbing: F[G[S]])(implicit F: Applicative[F], G: Applicative[G], $ev: T <:< S): F[G[S]] =
macro DoSomethingMacro.returnedFG[T, S]
}
object AnsweredFG
case class AnsweredByFG[T]() {
def by[F[_], G[_], S](stubbing: F[G[S]])(implicit F: Applicative[F], G: Applicative[G], $ev: T <:< S): F[G[S]] =
macro DoSomethingMacro.answeredFG[T, S]
}
object Raised
case class Raised[T]() {
def by[F[_], E](stubbing: F[E])(implicit F: MonadError[F, _ >: T]): F[E] = macro DoSomethingMacro.raised[E]
}
object RaisedG
case class RaisedG[T]() {
def by[F[_], G[_], E](stubbing: F[G[E]])(implicit F: Applicative[F], G: MonadError[G, _ >: T]): F[G[E]] =
macro DoSomethingMacro.raisedG[E]
}
class ReturnActions[F[_], T](os: ScalazStubbing[F, T]) {
def apply(value: T)(implicit a: Applicative[F]): ScalazStubbing[F, T] = os thenReturn value
}
class ReturnActions2[F[_], G[_], T](os: ScalazStubbing2[F, G, T]) {
def apply(value: T)(implicit a: Applicative[F], ag: Applicative[G]): ScalazStubbing2[F, G, T] = os thenReturn value
}
class ThrowActions[F[_], T](os: ScalazStubbing[F, T]) {
def apply[E](error: E)(implicit ae: MonadError[F, _ >: E]): ScalazStubbing[F, T] = os thenFailWith error
}
class ThrowActions2[F[_], G[_], T](os: ScalazStubbing2[F, G, T]) {
def apply[E](error: E)(implicit ae: Applicative[F], ag: MonadError[G, _ >: E]): ScalazStubbing2[F, G, T] = os thenFailWith error
}
class AnswerActions[F[_], T](os: ScalazStubbing[F, T]) {
def apply(f: => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] = os thenAnswer f
def apply[P0](f: P0 => T)(implicit classTag: ClassTag[P0] = defaultClassTag[P0], F: Applicative[F]): ScalazStubbing[F, T] =
os thenAnswer f
def apply[P0, P1](f: (P0, P1) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] = os thenAnswer f
def apply[P0, P1, P2](f: (P0, P1, P2) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] = os thenAnswer f
def apply[P0, P1, P2, P3](f: (P0, P1, P2, P3) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] = os thenAnswer f
def apply[P0, P1, P2, P3, P4](f: (P0, P1, P2, P3, P4) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] = os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5](f: (P0, P1, P2, P3, P4, P5) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] = os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6](f: (P0, P1, P2, P3, P4, P5, P6) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7](f: (P0, P1, P2, P3, P4, P5, P6, P7) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7, P8](f: (P0, P1, P2, P3, P4, P5, P6, P7, P8) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] = os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7, P8, P9](f: (P0, P1, P2, P3, P4, P5, P6, P7, P8, P9) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7, P8, P9, P10](f: (P0, P1, P2, P3, P4, P5, P6, P7, P8, P9, P10) => T)(implicit F: Applicative[F]): ScalazStubbing[F, T] =
os thenAnswer f
}
class AnswerActions2[F[_], G[_], T](os: ScalazStubbing2[F, G, T]) {
def apply(f: => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] = os thenAnswer f
def apply[P0](f: P0 => T)(implicit classTag: ClassTag[P0] = defaultClassTag[P0], F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
def apply[P0, P1](f: (P0, P1) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] = os thenAnswer f
def apply[P0, P1, P2](f: (P0, P1, P2) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] = os thenAnswer f
def apply[P0, P1, P2, P3](f: (P0, P1, P2, P3) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4](f: (P0, P1, P2, P3, P4) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5](f: (P0, P1, P2, P3, P4, P5) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] = os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6](f: (P0, P1, P2, P3, P4, P5, P6) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7](f: (P0, P1, P2, P3, P4, P5, P6, P7) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7, P8](f: (P0, P1, P2, P3, P4, P5, P6, P7, P8) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7, P8, P9](f: (P0, P1, P2, P3, P4, P5, P6, P7, P8, P9) => T)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
def apply[P0, P1, P2, P3, P4, P5, P6, P7, P8, P9, P10](
f: (P0, P1, P2, P3, P4, P5, P6, P7, P8, P9, P10) => T
)(implicit F: Applicative[F], G: Applicative[G]): ScalazStubbing2[F, G, T] =
os thenAnswer f
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy