All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.testng.ITestResult Maven / Gradle / Ivy

package org.testng;

import java.util.Collections;
import java.util.List;
import org.testng.internal.thread.ThreadTimeoutException;

/**
 * This class describes the result of a test.
 *
 * @author Cedric Beust, May 2, 2004
 * @version $Revision: 721 $, $Date: 2009-05-23 09:55:46 -0700 (Sat, 23 May 2009) $
 * @since May 2, 2004
 */
public interface ITestResult extends IAttributes, Comparable {

  // Test status
  int CREATED = -1;
  int SUCCESS = 1;
  int FAILURE = 2;
  int SKIP = 3;
  int SUCCESS_PERCENTAGE_FAILURE = 4;
  int STARTED = 16;

  /** @return The status of this result, using one of the constants above. */
  int getStatus();

  void setStatus(int status);

  /** @return The test method this result represents. */
  ITestNGMethod getMethod();

  /** @return The parameters this method was invoked with. */
  Object[] getParameters();

  void setParameters(Object[] parameters);

  /** @return The test class used this object is a result for. */
  IClass getTestClass();

  /**
   * @return The throwable that was thrown while running the method, or null if no exception was
   *     thrown.
   */
  Throwable getThrowable();

  void setThrowable(Throwable throwable);

  /** @return the start date for this test, in milliseconds. */
  long getStartMillis();

  /** @return the end date for this test, in milliseconds. */
  long getEndMillis();

  void setEndMillis(long millis);

  /** @return The name of this TestResult, typically identical to the name of the method. */
  String getName();

  /** @return true if if this test run is a SUCCESS */
  boolean isSuccess();

  /**
   * @return The host where this suite was run, or null if it was run locally. The returned string
   *     has the form: host:port
   */
  String getHost();

  /** The instance on which this method was run. */
  Object getInstance();

  /**
   * @return - A parameter array that was passed to a factory method (or) an empty object array
   * otherwise.
   */
  Object[] getFactoryParameters();

  /**
   * If this result's related instance implements ITest or use @Test(testName=...), returns its test
   * name, otherwise returns null.
   */
  String getTestName();

  String getInstanceName();

  /** @return the {@link ITestContext} for this test result. */
  ITestContext getTestContext();

  /** @param name - The new name to be used as a test name */
  void setTestName(String name);

  /**
   * @return - true if the test was retried again by an implementation of {@link
   *     IRetryAnalyzer}
   */
  boolean wasRetried();

  /**
   * @param wasRetried - true if the test was retried and false otherwise.
   */
  void setWasRetried(boolean wasRetried);

  /**
   * @return - The list of either upstream method(s) or configuration method(s) whose failure led to
   * the current method being skipped. An empty list is returned when the current method is not
   * a skipped method.
   */
  default List getSkipCausedBy() {
    return Collections.emptyList();
  }

  /**
   * @param result - The test result of a method
   * @return - true if the test failure was due to a timeout.
   */
  static boolean wasFailureDueToTimeout(ITestResult result) {
    Throwable cause = result.getThrowable();
    while (cause != null && !cause.getClass().equals(Throwable.class)) {
      if (cause instanceof ThreadTimeoutException) {
        return true;
      }
      cause = cause.getCause();
    }
    return false;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy