Oto strona Scalatest dotycząca korzystania z runnera i rozszerzonej dyskusji na temat opcji -t
i-z
.
Ten post pokazuje, jakie polecenia działają dla pliku testowego, który używa FunSpec
.
Oto plik testowy:
package com.github.mrpowers.scalatest.example
import org.scalatest.FunSpec
class CardiBSpec extends FunSpec {
describe("realName") {
it("returns her birth name") {
assert(CardiB.realName() === "Belcalis Almanzar")
}
}
describe("iLike") {
it("works with a single argument") {
assert(CardiB.iLike("dollars") === "I like dollars")
}
it("works with multiple arguments") {
assert(CardiB.iLike("dollars", "diamonds") === "I like dollars, diamonds")
}
it("throws an error if an integer argument is supplied") {
assertThrows[java.lang.IllegalArgumentException]{
CardiB.iLike()
}
}
it("does not compile with integer arguments") {
assertDoesNotCompile("""CardiB.iLike(1, 2, 3)""")
}
}
}
To polecenie uruchamia cztery testy w iLike
bloku opisywania (z wiersza poleceń SBT):
testOnly *CardiBSpec -- -z iLike
Możesz również użyć cudzysłowów, więc to również zadziała:
testOnly *CardiBSpec -- -z "iLike"
Spowoduje to uruchomienie pojedynczego testu:
testOnly *CardiBSpec -- -z "works with multiple arguments"
Spowoduje to uruchomienie dwóch testów zaczynających się od „działa z”:
testOnly *CardiBSpec -- -z "works with"
Nie mogę -t
uruchomić żadnych testów w CardiBSpec
pliku. To polecenie nie uruchamia żadnych testów:
testOnly *CardiBSpec -- -t "works with multiple arguments"
Wygląda na to, że -t
opcja działa, gdy testy nie są zagnieżdżone w describe
blokach. Rzućmy okiem na inny plik testowy:
class CalculatorSpec extends FunSpec {
it("adds two numbers") {
assert(Calculator.addNumbers(3, 4) === 7)
}
}
-t
można użyć do uruchomienia pojedynczego testu:
testOnly *CalculatorSpec -- -t "adds two numbers"
-z
można również użyć do uruchomienia pojedynczego testu:
testOnly *CalculatorSpec -- -z "adds two numbers"
Zobacz to repozytorium, jeśli chcesz uruchomić te przykłady.