假设我在抽象类中有几个测试,这些测试旨在在特征的几个实现上运行:
trait Foo {
def method1
def method2
// etc.
}
class Foo1 extends Foo { ... }
class Foo2 extends Foo { ... }
class Foo3 extends Foo { ... }
abstract class FooTest extends FunSuite with Matchers {
val foo: Foo
test("method1") { foo.method1 should equal(...) }
test("method2") { ... }
}
class Foo1Tests extends FooTests { val foo = new Foo1 }
...
不幸的是,有一些测试不能通过Foo2
,而其他测试也不会通过Foo3
。将它们视为Foo
的规范,其中不完整的实现已经很有用。我想把一些继承的测试标记为待定(或完全隐藏它们)。
根据子类测试的工作原理将FooTests
分解为特征并不是一个解决方案:将来可能会添加新的子类,包括外部项目。
使用JUnitSuite
会有所帮助,因为测试只是方法而且可以正常覆盖,但它可能为时已晚。
答案 0 :(得分:1)
您放入抽象类主体的任何代码都将被执行,期间。如果您希望能够排除某些测试,则需要自定义解决方案。其中之一是根据名称排除测试:
abstract class FooTest extends FunSuite with Matchers {
def excluded: Seq[String] = Seq.empty
override def test(testName: String, testTags: Tag*)(testFun: => Unit) =
if (excluded.contains(testName)) ()
else super.test(testName, testTags: _*)(testFun)
test("method1") { ... }
test("method2") { ... }
然后在子类中,您可以排除一些测试,如下所示:
class Foo1Test extends FooTest {
override def excluded = Seq("method2")
}
你当然可以提出更多的语法糖,但我认为它不值得花更多的时间,如果它只是为了隐藏测试,直到它们被实现。
另请注意,使用此方法完全隐藏测试,但您可以在调用test
之前标记它们,标记它们或执行任何操作。