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

org.scalatest.AbstractSuite.scala Maven / Gradle / Ivy

/*
 * Copyright 2001-2012 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

/**
 * AbstractSuite has been deprecated and will be removed in a future version of ScalaTest. Please change occurances of
 * AbstractSuite where serving as a base class for stackable traits to SuiteMixin.  This
 * is just a name change for stackable traits extending AbstractSuite. If AbstractSuite was
 * being used in any other way, change AbstractSuite to Suite.
 *
 * 

* The main change will be to change stackable traits defined like this: *

* *
 * import org.scalatest._
 * import concurrent.Eventually._
 * 
 * trait RetriedTests extends AbstractSuite { Suite =>
 *   abstract override def withFixture(test: NoArgTest) {
 *     eventually { super.withFixture(test) }
 *   }
 * }
 * 
* *

* Instead of extending AbstractSuite, extend SuiteMixin instead: *

* *
 * import org.scalatest._
 * import concurrent.Eventually._
 * 
 * trait RetriedTests extends SuiteMixin { Suite =>
 *   abstract override def withFixture(test: NoArgTest) {
 *     eventually { super.withFixture(test) }
 *   }
 * }
 * 
*/ @deprecated("Please use SuiteMixin or Suite instead. For more info, see the Scaladoc for AbstractSuite.") trait AbstractSuite { this: Suite => /** * Runs the passed test function with a fixture established by this method. * *

* This method should set up the fixture needed by the tests of the * current suite, invoke the test function, and if needed, perform any clean * up needed after the test completes. Because the NoArgTest function * passed to this method takes no parameters, preparing the fixture will require * side effects, such as initializing an external database. *

* * @param test the no-arg test function to run with a fixture */ protected def withFixture(test: NoArgTest) /** * Runs this suite of tests. * * @param testName an optional name of one test to execute. If None, all relevant tests should be executed. * I.e., None acts like a wildcard that means execute all relevant tests in this Suite. * @param args the Args for this run * * @throws NullPointerException if any passed parameter is null. */ def run(testName: Option[String], args: Args): Status /** * Runs zero to many of this suite's nested suites. * * @param args the Args for this run * * @throws NullPointerException if args is null. */ protected def runNestedSuites(args: Args): Status /** * Runs zero to many of this suite's tests. * * @param testName an optional name of one test to run. If None, all relevant tests should be run. * I.e., None acts like a wildcard that means run all relevant tests in this Suite. * @param args the Args for this run * * @throws NullPointerException if either testName or args is null. */ protected def runTests(testName: Option[String], args: Args): Status /** * Runs a test. * * @param testName the name of one test to execute. * @param args the Args for this run * * @throws NullPointerException if any of testName, reporter, stopper, configMap, * or tracker is null. */ protected def runTest( testName: String, args: Args ): Status /** * A Set of test names. If this Suite contains no tests, this method returns an empty Set. * *

* Although subclass and subtrait implementations of this method may return a Set whose iterator produces String * test names in a well-defined order, the contract of this method does not required a defined order. Subclasses are free to * implement this method and return test names in either a defined or undefined order. *

*/ def testNames: Set[String] /** * An immutable IndexedSeq of this Suite object's nested Suites. If this Suite contains no nested Suites, * this method returns an empty IndexedSeq. */ def nestedSuites: collection.immutable.IndexedSeq[Suite] /** * A Map whose keys are String tag names with which tests in this Suite are marked, and * whose values are the Set of test names marked with each tag. If this Suite contains no tags, this * method returns an empty Map. * *

* Subclasses may implement this method to define and/or discover tags in a custom manner, but overriding method implementations * should never return an empty Set as a value. If a tag has no tests, its name should not appear as a key in the * returned Map. *

*/ def tags: Map[String, Set[String]] /** * The total number of tests that are expected to run when this Suite's run method is invoked. * * @param filter a Filter with which to filter tests to count based on their tags */ def expectedTestCount(filter: Filter): Int /** * The fully qualified name of the class that can be used to rerun this suite. */ def rerunner: Option[String] /** * This suite's style name. * *

* This lifecycle method provides a string that is used to determine whether this suite object's * style is one of the chosen styles for * the project. *

*/ val styleName: String /** * This overloaded form of run has been deprecated and will be removed in a future * version of ScalaTest. Please use the run method that takes two parameters instead. * *

* This final implementation of this method constructs a Args instance from the passed * reporter, stopper, filter, configMap, distributor, * and tracker, and invokes the overloaded run method that takes two parameters, * passing in the specified testName and the newly constructed Args. This method * implementation enables existing code that called into the old run method to continue to work * during the deprecation cycle. Subclasses and subtraits that overrode this method, however, will need to * be changed to use the new two-parameter form instead. *

* * @param testName an optional name of one test to execute. If None, all relevant tests should be executed. * I.e., None acts like a wildcard that means execute all relevant tests in this Suite. * @param reporter the Reporter to which results will be reported * @param stopper the Stopper that will be consulted to determine whether to stop execution early. * @param filter a Filter with which to filter tests based on their tags * @param configMap a Map of key-value pairs that can be used by the executing Suite of tests. * @param distributor an optional Distributor, into which to put nested Suites to be executed * by another entity, such as concurrently by a pool of threads. If None, nested Suites will be executed sequentially. * @param tracker a Tracker tracking Ordinals being fired by the current thread. * * @throws NullPointerException if any passed parameter is null. */ final def run( testName: Option[String], reporter: Reporter, stopper: Stopper, filter: Filter, configMap: Map[String, Any], distributor: Option[Distributor], tracker: Tracker ): Status = { // TODO: test that this grabs chosenStyles out of config map run(testName, Args(reporter, stopper, filter, configMap, distributor, tracker, Set.empty)) } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy