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

com.github.firststraw.guice.ProviderKeyBindingVerifier Maven / Gradle / Ivy

Go to download

Library containing convenience classes to simplify unit testing of Guice injectors and modules.

There is a newer version: 0.2.0
Show newest version
package com.github.firststraw.guice;

import com.google.inject.Key;
import com.google.inject.TypeLiteral;
import com.google.inject.spi.ProviderKeyBinding;
import java.util.Objects;
import javax.annotation.concurrent.Immutable;
import javax.inject.Provider;
import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;

/**
 * Provides methods for verifying that a {@link ProviderKeyBinding} is configured correctly.
 *
 * @param  the bound type
 */
@Immutable
public class ProviderKeyBindingVerifier implements BindingVerifier {

    private static final String NULL_EXPECTED_TYPE_ERROR = "Expected type must not be null.";
    private static final String NULL_EXPECTED_KEY_ERROR = "Expected key must not be null.";

    private final ProviderKeyBinding binding;

    /**
     * @param binding the {@link ProviderKeyBinding} to verify
     * @throws NullPointerException if the {@link ProviderKeyBinding} is {@code null}
     */
    ProviderKeyBindingVerifier(final ProviderKeyBinding binding) {
        this.binding = Objects.requireNonNull(binding, "Binding must not be null.");
    }

    /**
     * Verifies that the {@link ProviderKeyBinding} is bound to the correct type.
     *
     * @param expectedType the expected type
     * @return "this" {@link ProviderKeyBindingVerifier}
     * @throws IncorrectBindingTargetException if the {@link ProviderKeyBinding} is not bound to the
     * correct type
     */
    public ProviderKeyBindingVerifier withClass(
            final Class> expectedType) {
        Objects.requireNonNull(expectedType, NULL_EXPECTED_TYPE_ERROR);

        return withKey(Key.get(expectedType));
    }

    /**
     * Verifies that the {@link ProviderKeyBinding} is bound to the correct type.
     *
     * @param expectedType the expected type
     * @return "this" {@link ProviderKeyBindingVerifier}
     * @throws IncorrectBindingTargetException if the {@link ProviderKeyBinding} is not bound to the
     * correct type
     */
    public ProviderKeyBindingVerifier withTypeLiteral(
            final TypeLiteral> expectedType) {
        Objects.requireNonNull(expectedType, NULL_EXPECTED_TYPE_ERROR);

        return withKey(Key.get(expectedType));
    }

    /**
     * Verifies that the {@link ProviderKeyBinding} is bound to the correct {@link Key}.
     *
     * @param expectedKey the expected {@link Key}
     * @return "this" {@link ProviderKeyBindingVerifier}
     * @throws IncorrectBindingTargetException if the {@link ProviderKeyBinding} is not bound to the
     * correct {@link Key}
     */
    public ProviderKeyBindingVerifier withKey(
            final Key> expectedKey) {
        Objects.requireNonNull(expectedKey, NULL_EXPECTED_KEY_ERROR);

        final Key> key = binding.getProviderKey();
        if (key.equals(expectedKey)) {
            return this;
        } else {
            throw new IncorrectBindingTargetException(expectedKey, key);
        }
    }

    /**
     * Returns the {@link ProviderKeyBinding} to verify.
     *
     * @return the {@link ProviderKeyBinding} to verify
     */
    @Override
    public ProviderKeyBinding getBinding() {
        return binding;
    }

    /**
     * Indicates whether the {@link Object} can potentially be equal to "this".
     *
     * @param obj the {@link Object}
     * @return {@code true} if the {@link Object} can potentially be equal to "this"
     */
    protected boolean canEqual(final Object obj) {
        return obj instanceof ProviderKeyBindingVerifier;
    }

    /**
     * Indicates whether some other object is "equal to" this one.
     *
     * @param obj the reference object with which to compare
     * @return {@code true} if this object is the same as the {@code obj} argument; {@code false}
     * otherwise
     */
    @Override
    public boolean equals(final Object obj) {
        if (this == obj) {
            return true;
        } else if (obj instanceof ProviderKeyBindingVerifier) {
            final ProviderKeyBindingVerifier rhs = (ProviderKeyBindingVerifier) obj;
            return rhs.canEqual(this) && new EqualsBuilder()
                    .append(getBinding(), rhs.getBinding())
                    .isEquals();
        } else {
            return false;
        }
    }

    /**
     * Returns a hash code value for the object.
     *
     * @return a hash code value for this object
     */
    @Override
    public int hashCode() {
        return new HashCodeBuilder().append(getBinding()).toHashCode();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy