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

mockit.internal.expectations.invocation.ArgumentValuesAndMatchersWithoutVarargs Maven / Gradle / Ivy

Go to download

JMockit is a Java toolkit for automated developer testing. It contains APIs for the creation of the objects to be tested, for mocking dependencies, and for faking external APIs; JUnit (4 & 5) and TestNG test runners are supported. It also contains an advanced code coverage tool.

The 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.invocation;

import edu.umd.cs.findbugs.annotations.NonNull;

import java.util.Map;

import mockit.internal.expectations.argumentMatching.ArgumentMatcher;
import mockit.internal.expectations.argumentMatching.EqualityMatcher;
import mockit.internal.expectations.argumentMatching.LenientEqualityMatcher;

final class ArgumentValuesAndMatchersWithoutVarargs extends ArgumentValuesAndMatchers {
    ArgumentValuesAndMatchersWithoutVarargs(@NonNull InvocationArguments signature, @NonNull Object[] values) {
        super(signature, values);
    }

    @Override
    boolean isMatch(@NonNull Object[] replayArgs, @NonNull Map instanceMap) {
        if (matchers == null) {
            return areEqual(values, replayArgs, replayArgs.length, instanceMap);
        }

        for (int i = 0; i < replayArgs.length; i++) {
            Object actual = replayArgs[i];
            ArgumentMatcher expected = getArgumentMatcher(i);

            if (expected == null) {
                Object arg = values[i];
                if (arg == null) {
                    continue;
                }
                expected = new LenientEqualityMatcher(arg, instanceMap);
            }

            if (!expected.matches(actual)) {
                return false;
            }
        }

        return true;
    }

    @Override
    boolean hasEquivalentMatchers(@NonNull ArgumentValuesAndMatchers other) {
        @SuppressWarnings("unchecked")
        int i = indexOfFirstValueAfterEquivalentMatchers(other);

        if (i < 0) {
            return false;
        }

        while (i < values.length) {
            if (!EqualityMatcher.areEqual(values[i], other.values[i])) {
                return false;
            }

            i++;
        }

        return true;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy