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

org.scalatest.GivenWhenThen.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

import org.scalactic.source

/**
 * Trait that contains methods named given, when, then, and and,
 * which take a string message and implicit Informer, and forward the message to the informer.
 *
 * 

* Here's an example: *

* *
 * package org.scalatest.examples.flatspec.info
 * 
 * import collection.mutable
 * import org.scalatest._
 * 
 * class SetSpec extends FlatSpec with GivenWhenThen {
 *   
 *   "A mutable Set" should "allow an element to be added" in {
 *     Given("an empty mutable Set")
 *     val set = mutable.Set.empty[String]
 * 
 *     When("an element is added")
 *     set += "clarity"
 * 
 *     Then("the Set should have size 1")
 *     assert(set.size === 1)
 * 
 *     And("the Set should contain the added element")
 *     assert(set.contains("clarity"))
 * 
 *     info("That's all folks!")
 *   }
 * }
 * 
* *

* If you run this SetSpec from the interpreter, you will see the following output: *

* *
 * scala> org.scalatest.run(new SetSpec)
 * A mutable Set
 * - should allow an element to be added
 *   + Given an empty mutable Set 
 *   + When an element is added 
 *   + Then the Set should have size 1 
 *   + And the Set should contain the added element 
 *   + That's all folks! 
 * 
* * @author Bill Venners */ trait GivenWhenThen { this: Informing => /** * Forwards a message to an implicit Informer, preceded by "Given." * * @param message the message to forward to the passed informer */ def Given(message: String)(implicit pos: source.Position): Unit = { info(Resources.givenMessage(message))(pos) } /** * Forwards a message to an implicit Informer, preceded by "When ". * * @param message the message to forward to the passed informer */ def When(message: String)(implicit pos: source.Position): Unit = { info(Resources.whenMessage(message))(pos) } /** * Forwards a message to an implicit Informer, preceded by "Then ". * * @param message the message to forward to the passed informer */ def Then(message: String)(implicit pos: source.Position): Unit = { info(Resources.thenMessage(message))(pos) } /** * Forwards a message to an implicit Informer, preceded by "And ". * * @param message the message to forward to the passed informer */ def And(message: String)(implicit pos: source.Position): Unit = { info(Resources.andMessage(message))(pos) } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy