org.scalatest.junit

JUnitTestFailedError

class JUnitTestFailedError extends AssertionFailedError with StackDepth with ModifiableMessage[JUnitTestFailedError]

Exception that indicates a test failed.

The purpose of this exception is to encapsulate the same stack depth information provided byTestFailedException, which is used when running with ScalaTest, but be reported as a failure not an error when running with JUnit. The stack depth information indicates which line of test code failed, so that when running with ScalaTest information can be presented to the user that makes it quick to find the failing line of test code. (In other words, when running with ScalaTest the user need not scan through the stack trace to find the correct filename and line number of the failing test.)

JUnit distinguishes between failures and errors. If a test fails because of a failed assertion, that is considered a failure in JUnit. If a test fails for any other reason, either the test code or the application being tested threw an unexpected exception, that is considered an error in JUnit. This class differs fromTestFailedException in that it extendsjunit.framework.AssertionFailedError. Instances of this class are thrown by the assertions provided by AssertionsForJUnit, and matcher expressions provided by ShouldMatchersForJUnit, andMustMatchersForJUnit.

The way JUnit 3 (JUnit 3.8 and earlier releases) decided whether an exception represented a failure or error is that only thrown junit.framework.AssertionFailedErrors were considered failures. Any other exception type was considered an error. The exception type thrown by the JUnit 3 assertion methods declared in junit.framework.Assert (such as assertEquals, assertTrue, and fail) was, therefore, AssertionFailedError. In JUnit 4, AssertionFailedErrorwas made to extend java.lang.AssertionError, and the distinction between failures and errors was essentially dropped. However, some tools that integrate with JUnit carry on this distinction, so even if you are using JUnit 4 you may want to use the "ForJUnit" of ScalaTest assertions and matchers.

    authors:
  1. Bill Venners

Inherited
  1. Hide All
  2. Show all
  1. ModifiableMessage
  2. StackDepth
  3. AssertionFailedError
  4. AssertionError
  5. Error
  6. Throwable
  7. Serializable
  8. AnyRef
  9. Any
Visibility
  1. Public
  2. All

Instance constructors

  1. new JUnitTestFailedError(message: String, cause: Throwable, failedCodeStackDepth: Int)

    Create a JUnitTestFailedError with the specified stack depth, detail message, and cause.

    Create a JUnitTestFailedError with the specified stack depth, detail message, and cause.

    Note that the detail message associated with cause isnot automatically incorporated in this throwable's detail message.

    message

    A detail message for this JUnitTestFailedError.

    cause

    the cause, the Throwable that caused this JUnitTestFailedError to be thrown.

    failedCodeStackDepth

    the depth in the stack trace of this exception at which the line of test code that failed resides.

  2. new JUnitTestFailedError(cause: Throwable, failedCodeStackDepth: Int)

    Create a JUnitTestFailedError with the specified stack depth and cause.

    Create a JUnitTestFailedError with the specified stack depth and cause. Themessage field of this exception object will be initialized toif (cause.getMessage == null) "" else cause.getMessage.

    cause

    the cause, the Throwable that caused this JUnitTestFailedError to be thrown.

    failedCodeStackDepth

    the depth in the stack trace of this exception at which the line of test code that failed resides.

  3. new JUnitTestFailedError(message: String, failedCodeStackDepth: Int)

    Create a JUnitTestFailedError with a specified stack depth and detail message.

    Create a JUnitTestFailedError with a specified stack depth and detail message.

    message

    A detail message for this JUnitTestFailedError.

    failedCodeStackDepth

    the depth in the stack trace of this exception at which the line of test code that failed resides.

  4. new JUnitTestFailedError(failedCodeStackDepth: Int)

    Create a JUnitTestFailedError with specified stack depth and no detail message or cause.

    Create a JUnitTestFailedError with specified stack depth and no detail message or cause.

    failedCodeStackDepth

    the depth in the stack trace of this exception at which the line of test code that failed resides.

  5. new JUnitTestFailedError(message: Option[String], cause: Option[Throwable], failedCodeStackDepth: Int)

Value Members

  1. def !=(arg0: AnyRef): Boolean

    attributes: final
    definition classes: AnyRef
  2. def !=(arg0: Any): Boolean

    o != arg0 is the same as !(o == (arg0)).

    o != arg0 is the same as !(o == (arg0)).

    arg0

    the object to compare against this object for dis-equality.

    returns

    false if the receiver object is equivalent to the argument; true otherwise.

    attributes: final
    definition classes: Any
  3. def ##(): Int

    attributes: final
    definition classes: AnyRef → Any
  4. def $asInstanceOf[T0](): T0

    attributes: final
    definition classes: AnyRef
  5. def $isInstanceOf[T0](): Boolean

    attributes: final
    definition classes: AnyRef
  6. def ==(arg0: AnyRef): Boolean

    o == arg0 is the same as if (o eq null) arg0 eq null else o.equals(arg0).

    o == arg0 is the same as if (o eq null) arg0 eq null else o.equals(arg0).

    arg0

    the object to compare against this object for equality.

    returns

    true if the receiver object is equivalent to the argument; false otherwise.

    attributes: final
    definition classes: AnyRef
  7. def ==(arg0: Any): Boolean

    o == arg0 is the same as o.equals(arg0).

    o == arg0 is the same as o.equals(arg0).

    arg0

    the object to compare against this object for equality.

    returns

    true if the receiver object is equivalent to the argument; false otherwise.

    attributes: final
    definition classes: Any
  8. def asInstanceOf[T0]: T0

    This method is used to cast the receiver object to be of type T0.

    This method is used to cast the receiver object to be of type T0.

    Note that the success of a cast at runtime is modulo Scala's erasure semantics. Therefore the expression1.asInstanceOf[String] will throw a ClassCastException at runtime, while the expressionList(1).asInstanceOf[List[String]] will not. In the latter example, because the type argument is erased as part of compilation it is not possible to check whether the contents of the list are of the requested typed.

    returns

    the receiver object.

    attributes: final
    definition classes: Any
  9. def canEqual(other: Any): Boolean

    Indicates whether this object can be equal to the passed object.

    Indicates whether this object can be equal to the passed object.

  10. val cause: Option[Throwable]

    An optional cause, the Throwable that caused this StackDepth exception to be thrown.

    An optional cause, the Throwable that caused this StackDepth exception to be thrown.

    definition classes: JUnitTestFailedErrorStackDepth
  11. def clone(): AnyRef

    This method creates and returns a copy of the receiver object.

    This method creates and returns a copy of the receiver object.

    The default implementation of the clone method is platform dependent.

    returns

    a copy of the receiver object.

    attributes: protected
    definition classes: AnyRef
  12. def eq(arg0: AnyRef): Boolean

    This method is used to test whether the argument (arg0) is a reference to the receiver object (this).

    This method is used to test whether the argument (arg0) is a reference to the receiver object (this).

    The eq method implements an [http://en.wikipedia.org/wiki/Equivalence_relation equivalence relation] on non-null instances of AnyRef: * It is reflexive: for any non-null instance x of type AnyRef, x.eq(x) returns true. * It is symmetric: for any non-null instances x and y of type AnyRef, x.eq(y) returns true if and only if y.eq(x) returns true. * It is transitive: for any non-null instances x, y, and z of type AnyRef if x.eq(y) returns true and y.eq(z) returns true, then x.eq(z) returns true.

    Additionally, the eq method has three other properties. * It is consistent: for any non-null instances x and y of type AnyRef, multiple invocations of x.eq(y) consistently returns true or consistently returns false. * For any non-null instance x of type AnyRef, x.eq(null) and null.eq(x) returns false. * null.eq(null) returns true.

    When overriding the equals or hashCode methods, it is important to ensure that their behavior is consistent with reference equality. Therefore, if two objects are references to each other (o1 eq o2), they should be equal to each other (o1 == o2) and they should hash to the same value (o1.hashCode == o2.hashCode).

    arg0

    the object to compare against this object for reference equality.

    returns

    true if the argument is a reference to the receiver object; false otherwise.

    attributes: final
    definition classes: AnyRef
  13. def equals(other: Any): Boolean

    Indicates whether this object is equal to the passed object.

    Indicates whether this object is equal to the passed object. If the passed object is a JUnitTestFailedError, equality requires equal message,cause, and failedCodeStackDepth fields, as well as equal return values of getStackTrace.@return true if the receiver object is equivalent to the argument; false otherwise. */

    definition classes: JUnitTestFailedError → AnyRef → Any
  14. def failedCodeFileNameAndLineNumberString: Option[String]

    A string that provides the filename and line number of the line of code that failed, suitable for presenting to a user, which is taken from this exception's StackTraceElement at the depth specified by failedCodeStackDepth.

    A string that provides the filename and line number of the line of code that failed, suitable for presenting to a user, which is taken from this exception's StackTraceElement at the depth specified by failedCodeStackDepth.

    This is a def instead of a val because exceptions are mutable: their stack trace can be changed after the exception is created. This is done, for example, by the SeveredStackTraces trait.

    returns

    a user-presentable string containing the filename and line number that caused the failed test

    definition classes: StackDepth
  15. val failedCodeStackDepth: Int

    The depth in the stack trace of this exception at which the line of test code that failed resides.

    The depth in the stack trace of this exception at which the line of test code that failed resides.

    definition classes: JUnitTestFailedErrorStackDepth
  16. def fillInStackTrace(): Throwable

    definition classes: Throwable
  17. def finalize(): Unit

    This method is called by the garbage collector on the receiver object when garbage collection determines that there are no more references to the object.

    This method is called by the garbage collector on the receiver object when garbage collection determines that there are no more references to the object.

    The details of when and if the finalize method are invoked, as well as the interaction between finalizeand non-local returns and exceptions, are all platform dependent.

    attributes: protected
    definition classes: AnyRef
  18. def getCause(): Throwable

    definition classes: Throwable
  19. def getClass(): java.lang.Class[_]

    Returns a representation that corresponds to the dynamic class of the receiver object.

    Returns a representation that corresponds to the dynamic class of the receiver object.

    The nature of the representation is platform dependent.

    returns

    a representation that corresponds to the dynamic class of the receiver object.

    attributes: final
    definition classes: AnyRef
  20. def getLocalizedMessage(): String

    definition classes: Throwable
  21. def getMessage(): String

    definition classes: Throwable
  22. def getStackTrace(): Array[StackTraceElement]

    definition classes: Throwable
  23. def hashCode(): Int

    Returns a hash code value for this object.

    Returns a hash code value for this object.@return the hash code value for the object. */

    definition classes: JUnitTestFailedError → AnyRef → Any
  24. def initCause(throwable: Throwable): Throwable

    attributes: final
    definition classes: JUnitTestFailedError → Throwable
  25. def isInstanceOf[T0]: Boolean

    This method is used to test whether the dynamic type of the receiver object is T0.

    This method is used to test whether the dynamic type of the receiver object is T0.

    Note that the test result of the test is modulo Scala's erasure semantics. Therefore the expression1.isInstanceOf[String] will return false, while the expression List(1).isInstanceOf[List[String]] will return true. In the latter example, because the type argument is erased as part of compilation it is not possible to check whether the contents of the list are of the requested typed.

    returns

    true if the receiver object is an instance of erasure of type T0; false otherwise.

    attributes: final
    definition classes: Any
  26. val message: Option[String]

    An optional detail message for this StackDepth exception.

    An optional detail message for this StackDepth exception.

    definition classes: JUnitTestFailedErrorStackDepth
  27. def modifyMessage(fun: (Option[String]) ⇒ Option[String]): JUnitTestFailedError

    Returns an instance of this exception's class, identical to this exception, except with the detail message option string replaced with the result of passing the current detail message to the passed function, fun.

    Returns an instance of this exception's class, identical to this exception, except with the detail message option string replaced with the result of passing the current detail message to the passed function, fun.

    fun

    A function that, given the current optional detail message, will produce the modified optional detail message for the result instance of TestFailedException.

    definition classes: JUnitTestFailedErrorModifiableMessage
  28. def ne(arg0: AnyRef): Boolean

    o.ne(arg0) is the same as !(o.eq(arg0)).

    o.ne(arg0) is the same as !(o.eq(arg0)).

    arg0

    the object to compare against this object for reference dis-equality.

    returns

    false if the argument is not a reference to the receiver object; true otherwise.

    attributes: final
    definition classes: AnyRef
  29. def notify(): Unit

    Wakes up a single thread that is waiting on the receiver object's monitor.

    Wakes up a single thread that is waiting on the receiver object's monitor.

    attributes: final
    definition classes: AnyRef
  30. def notifyAll(): Unit

    Wakes up all threads that are waiting on the receiver object's monitor.

    Wakes up all threads that are waiting on the receiver object's monitor.

    attributes: final
    definition classes: AnyRef
  31. def printStackTrace(arg0: PrintWriter): Unit

    definition classes: Throwable
  32. def printStackTrace(arg0: PrintStream): Unit

    definition classes: Throwable
  33. def printStackTrace(): Unit

    definition classes: Throwable
  34. def setStackTrace(arg0: Array[StackTraceElement]): Unit

    definition classes: Throwable
  35. def severedAtStackDepth: JUnitTestFailedError

    Returns an exception of class JUnitTestFailedError with failedExceptionStackDepth set to 0 and all frames above this stack depth severed off.

    Returns an exception of class JUnitTestFailedError with failedExceptionStackDepth set to 0 and all frames above this stack depth severed off. This can be useful when working with tools (such as IDEs) that do not directly support ScalaTest. (Tools that directly support ScalaTest can use the stack depth information delivered in the StackDepth exceptions.)

    definition classes: JUnitTestFailedErrorStackDepth
  36. def synchronized[T0](arg0: T0): T0

    attributes: final
    definition classes: AnyRef
  37. def toString(): String

    Returns a string representation of the object.

    Returns a string representation of the object.

    The default representation is platform dependent.

    returns

    a string representation of the object.

    definition classes: Throwable → AnyRef → Any
  38. def wait(): Unit

    attributes: final
    definition classes: AnyRef
  39. def wait(arg0: Long, arg1: Int): Unit

    attributes: final
    definition classes: AnyRef
  40. def wait(arg0: Long): Unit

    attributes: final
    definition classes: AnyRef