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

org.scalatest.enablers.WheneverAsserting.scala Maven / Gradle / Ivy

/*
 * Copyright 2001-2013 Artima, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.scalatest.enablers

import org.scalatest.Assertion
import org.scalatest.exceptions.DiscardedEvaluationException
import scala.concurrent.Future

/**
  * Supertrait for WheneverAsserting typeclasses, which are used to implement and determine the result
  * type of [[org.scalatest.prop.Whenever Whenever]]'s whenever method.
  *
  * 

* Currently, an [[org.scalatest.prop.Whenever Whenever]] expression will have result type Assertion, if the function passed has result type Assertion, * else it will have result type Unit. *

*/ trait WheneverAsserting[T] { /** * The result type of the whenever method. */ type Result /** * Implementation method for [[org.scalatest.prop.Whenever Whenever]]'s whenever syntax. * * @param condition the boolean condition that determines whether whenever will evaluate the * fun function (condition is true) or throws DiscardedEvaluationException (condition is false) * @param fun the function to evaluate if the specified condition is true */ def whenever(condition: Boolean)(fun: => T): Result } /** * Class holding lowest priority WheneverAsserting implicit, which enables [[org.scalatest.prop.Whenever Whenever]] expressions that have result type Unit. */ abstract class UnitWheneverAsserting { /** * Provides support of [[org.scalatest.enablers.WheneverAsserting WheneverAsserting]] for Unit. Return Unit when the check succeeds, * but throw [[org.scalatest.exceptions.DiscardedEvaluationException DiscardedEvaluationException]] * when check fails. */ implicit def assertingNatureOfT[T]: WheneverAsserting[T] { type Result = Unit } = { new WheneverAsserting[T] { type Result = Unit def whenever(condition: Boolean)(fun: => T): Unit = if (!condition) throw new DiscardedEvaluationException else fun } } } /** * Abstract class that in the future will hold an intermediate priority WheneverAsserting implicit, which will enable inspector expressions * that have result type Expectation, a more composable form of assertion that returns a result instead of throwing an exception when it fails. */ abstract class ExpectationWheneverAsserting extends UnitWheneverAsserting { /*private[scalatest] implicit def assertingNatureOfExpectation: WheneverAsserting[Expectation] { type Result = Expectation } = { new WheneverAsserting[Expectation] { type Result = Expectation def whenever(condition: Boolean)(fun: => Expectation): Expectation = if (!condition) throw new DiscardedEvaluationException else fun } }*/ implicit def assertingNatureOfFutureAssertion: WheneverAsserting[Future[Assertion]] { type Result = Future[Assertion] } = { new WheneverAsserting[Future[Assertion]] { type Result = Future[Assertion] def whenever(condition: Boolean)(fun: => Future[Assertion]): Future[Assertion] = if (!condition) throw new DiscardedEvaluationException else fun } } } /** * Companion object to WheneverAsserting that provides two implicit providers, a higher priority one for passed functions that have result * type Assertion, which also yields result type Assertion, and one for any other type, which yields result type Unit. */ object WheneverAsserting extends ExpectationWheneverAsserting { implicit def assertingNatureOfAssertion: WheneverAsserting[Assertion] { type Result = Assertion } = { new WheneverAsserting[Assertion] { type Result = Assertion def whenever(condition: Boolean)(fun: => Assertion): Assertion = if (!condition) throw new DiscardedEvaluationException else fun } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy