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

org.testng.internal.reflect.DataProviderMethodMatcher Maven / Gradle / Ivy

package org.testng.internal.reflect;

/** Checks the conformance as per data-provide specifications. */
public class DataProviderMethodMatcher extends AbstractMethodMatcher {

  private final DirectMethodMatcher directMethodMatcher;
  private final ArrayEndingMethodMatcher arrayEndingMethodMatcher;
  private MethodMatcher matchingMatcher = null;

  public DataProviderMethodMatcher(final MethodMatcherContext context) {
    super(context);
    this.directMethodMatcher = new DirectMethodMatcher(context);
    this.arrayEndingMethodMatcher = new ArrayEndingMethodMatcher(context);
  }

  /** {@inheritDoc} */
  @Override
  protected boolean hasConformance() {
    boolean matching = false;
    if (directMethodMatcher.conforms()) {
      matching = true;
      matchingMatcher = directMethodMatcher;
    } else if (arrayEndingMethodMatcher.conforms()) {
      matching = true;
      matchingMatcher = arrayEndingMethodMatcher;
    }
    return matching;
  }

  /** {@inheritDoc} */
  @Override
  public Object[] getConformingArguments() {
    if (getConforms() == null) {
      conforms();
    }
    if (matchingMatcher != null) {
      return matchingMatcher.getConformingArguments();
    }
    String msg = String.format("[%s] has no parameters defined but was found to be using a "
        + "data provider (either explicitly specified or "
        + "inherited from class level annotation).\n", getContext().getMethod());
    throw new MethodMatcherException(
        msg + "Data provider mismatch", getContext().getMethod(), getContext().getArguments());
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy