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

mockit.internal.expectations.argumentMatching.AlwaysTrueMatcher Maven / Gradle / Ivy

Go to download

JMockit is a Java toolkit for automated developer testing. It contains mocking/faking APIs and a code coverage tool, supporting both JUnit and TestNG. The mocking APIs allow all kinds of Java code, without testability restrictions, to be tested in isolation from selected dependencies.

There is a newer version: 1.49
Show newest version
/*
 * Copyright (c) 2006 JMockit developers
 * This file is subject to the terms of the MIT license (see LICENSE.txt).
 */
package mockit.internal.expectations.argumentMatching;

import javax.annotation.*;

public final class AlwaysTrueMatcher implements ArgumentMatcher
{
   public static final ArgumentMatcher ANY_STRING  = new AlwaysTrueMatcher(String.class, "String");
   public static final ArgumentMatcher ANY_BOOLEAN = new AlwaysTrueMatcher(Boolean.class, "boolean");
   public static final ArgumentMatcher ANY_CHAR    = new AlwaysTrueMatcher(Character.class, "char");
   public static final ArgumentMatcher ANY_BYTE    = new AlwaysTrueMatcher(Byte.class, "byte");
   public static final ArgumentMatcher ANY_SHORT   = new AlwaysTrueMatcher(Short.class, "short");
   public static final ArgumentMatcher ANY_INT     = new AlwaysTrueMatcher(Integer.class, "int");
   public static final ArgumentMatcher ANY_FLOAT   = new AlwaysTrueMatcher(Float.class, "float");
   public static final ArgumentMatcher ANY_LONG    = new AlwaysTrueMatcher(Long.class, "long");
   public static final ArgumentMatcher ANY_DOUBLE  = new AlwaysTrueMatcher(Double.class, "double");
   public static final ArgumentMatcher ANY_VALUE   = new AlwaysTrueMatcher(Object.class, null);

   @Nonnull private final Class expectedType;
   @Nullable private final String typeName;

   private AlwaysTrueMatcher(@Nonnull Class expectedType, @Nullable String typeName) {
      this.expectedType = expectedType;
      this.typeName = typeName;
   }

   @Override
   public boolean same(@Nonnull AlwaysTrueMatcher other) { return expectedType == other.expectedType; }

   @Override
   public boolean matches(@Nullable Object argValue) {
      return argValue == null || expectedType.isInstance(argValue);
   }

   @Override
   public void writeMismatchPhrase(@Nonnull ArgumentMismatch argumentMismatch) {
      String parameterTypeName = typeName != null ? typeName : argumentMismatch.getParameterType();
      argumentMismatch.append("any ").append(parameterTypeName);
   }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy