Я пытаюсь смоделировать ожидаемое поведение исключительной ситуации в обычных средах тестирования (например, JUnit или TestNG).
Вот что я мог придумать (работает):
trait ExpectAsserts
{
self : {
def fail (message : String)
def success (message : String)
} =>
def expect[T](exceptionClass : Class[T])(test : => Unit)
{
try
{
test
fail("exception not thrown")
}
catch
{
case expected : T => success("got exception " + expected)
case other : Exception => fail("expected "+ exceptionClass + " but " + other + " thrown instead.")
}
}
}
object Main extends ExpectAsserts
{
def main (args : Array[String])
{
expect(classOf[ArithmeticException])
{
throw new IllegalArgumentException // this should print an error message.
}
}
def fail (s : String)
{
System.err.println(s)
}
def success(s : String)
{
System.out.println(s)
}
}
Фрагмент имеет метод main
, который осуществляет код. Моя проблема заключается в том, что выброшенное исключение входит в первый оператор сопоставления с образцом:
case expected : T
Хотя на самом деле я говорю, что исключение должно иметь тип T
, который будет IllegalArgumentException
.
Есть идеи?