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

org.scalatest.concurrent.AsyncCancelAfterFailure.scala Maven / Gradle / Ivy

/*
 * Copyright 2001-2016 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.concurrent

import org.scalatest.time.Span
import org.scalatest._

import scala.concurrent.Future

/*
This should be moved up to org.scalatest to be symetric to CancelAfterFailure. Also consider
adding the final newInstance method to prevent it being mixed in with OneInstancePerTest.
AFTER MOVING, DROP THE .. in the link to AsyncTestSuite below
*/

 /* ADD THIS LATER AFTER DOING THE ENHANCEMENT:
 * 

* Note that this trait only cancels tests in the same AsyncTestSuite instance, because * it uses a private volatile instance variable as a flag to indicate whether or not a test has failed. * If you are running each test in its own instance, therefore, it would not cancel the * remaining tests, because they would not see the same flag. For this reason, this trait contains * a final implementation of a method defined in OneInstancePerTest, * to prevent it from being mixed into any class that also mixes in OneInstancePerTest, * including by mixing in ParallelTestExecution * or a path traits. *

*/ /** * Trait that when mixed into a AsyncTestSuite cancels any remaining tests in that * AsyncTestSuite instance after a test fails. * *

* The intended use case for this trait is if you have a suite of long-running tests that are * related such that if one fails, you aren't interested in running the others, you can use this * trait to simply cancel any remaining tests, so you need not wait long for them to complete. *

* */ trait AsyncCancelAfterFailure extends AsyncTestSuiteMixin { this: AsyncTestSuite => @volatile private var cancelRemaining = false /** * Stackable implementation of withFixture that cancels the current test if * any previous test run in this AsyncSuite instance has failed. */ abstract override def withFixture(test: NoArgAsyncTest): FutureOutcome = { if (cancelRemaining) FutureOutcome.canceled("Canceled by CancelOnFailure because a test failed previously") else super.withFixture(test) onFailedThen { _ => cancelRemaining = true } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy