All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.specs2.specification.Contexts.scala Maven / Gradle / Ivy

package org.specs2
package specification

import execute.Result

/**
 * This trait is only used when we wish to write after actions in unit specifications like this
 *
 * "an example" ! {
 *   1 must_== 1
 * }.after(clean)
 */
trait Contexts {
  /**
   * add a before action to any kind of result
   */
  implicit def doBefore[T <% Result](t: =>T) = new BeforeResult(t)
  class BeforeResult[T <% Result](t: =>T) {
    def before(action: => Unit) = new Before {
      def before = action
    }.apply(t)
  }

  /**
   * add an Around function to any kind of result
   */
  implicit def doAround[T <% Result](t: =>T) = new AroundResult(t)
  class AroundResult[T <% Result](t: =>T) {
    def around(f: Result => Result) = new Around {
      def around[R](r: =>R)(implicit conv: R => Result): Result = f(conv(r))
    }.apply(t)
  }

  /**
   * add an after action to any kind of result
   */
  implicit def doAfter[T <% Result](t: =>T) = new AfterResult(t)
  class AfterResult[T <% Result](t: =>T) {
    def after(action: => Unit) = new After {
      def after = action
    }.apply(t)
  }

  protected[specs2] val defaultContext = new Context { def apply[T <% Result](a: =>T): Result = a }

}

/**
 * Use this trait to deactivate the Contexts implicits
 */
trait NoContexts extends Contexts {
  override def doBefore[T <% Result](t: =>T) = super.doBefore(t)
  override def doAround[T <% Result](t: =>T) = super.doAround(t)
  override def doAfter[T <% Result](t: =>T) = super.doAfter(t)
}

object Contexts extends Contexts




© 2015 - 2025 Weber Informatics LLC | Privacy Policy