ExpectedException.java

package top.infra.core;

/**
 * ExpectedException is thrown by user, not by libraries or frameworks.
 */
public class ExpectedException extends RuntimeException {

  /** Constructs a new expected exception with {@code null} as its
   * detail message.  The cause is not initialized, and may subsequently be
   * initialized by a call to {@link #initCause}.
   */
  public ExpectedException() {
    super();
  }

  /** Constructs a new expected exception with the specified detail message.
   * The cause is not initialized, and may subsequently be initialized by a
   * call to {@link #initCause}.
   *
   * @param   message   the detail message. The detail message is saved for
   *          later retrieval by the {@link #getMessage()} method.
   */
  public ExpectedException(final String message) {
    super(message);
  }

  /**
   * Constructs a new expected exception with the specified detail message and
   * cause.  <p>Note that the detail message associated with
   * {@code cause} is <i>not</i> automatically incorporated in
   * this expected exception's detail message.
   *
   * @param  message the detail message (which is saved for later retrieval
   *         by the {@link #getMessage()} method).
   * @param  cause the cause (which is saved for later retrieval by the
   *         {@link #getCause()} method).  (A <tt>null</tt> value is
   *         permitted, and indicates that the cause is nonexistent or
   *         unknown.)
   */
  public ExpectedException(final String message, final Throwable cause) {
    super(message, cause);
  }

  /** Constructs a new expected exception with the specified cause and a
   * detail message of <tt>(cause==null ? null : cause.toString())</tt>
   * (which typically contains the class and detail message of
   * <tt>cause</tt>).  This constructor is useful for expected exceptions
   * that are little more than wrappers for other throwables.
   *
   * @param  cause the cause (which is saved for later retrieval by the
   *         {@link #getCause()} method).  (A <tt>null</tt> value is
   *         permitted, and indicates that the cause is nonexistent or
   *         unknown.)
   */
  public ExpectedException(final Throwable cause) {
    super(cause);
  }

  /**
   * Constructs a new expected exception with the specified detail
   * message, cause, suppression enabled or disabled, and writable
   * stack trace enabled or disabled.
   *
   * @param  message the detail message.
   * @param cause the cause.  (A {@code null} value is permitted,
   * and indicates that the cause is nonexistent or unknown.)
   * @param enableSuppression whether or not suppression is enabled
   *                          or disabled
   * @param writableStackTrace whether or not the stack trace should
   *                           be writable
   */
  protected ExpectedException( //
      final String message, //
      final Throwable cause, //
      boolean enableSuppression, //
      boolean writableStackTrace //
  ) {
    super(message, cause, enableSuppression, writableStackTrace);
  }
}