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

mockit.Injectable Maven / Gradle / Ivy

/*
 * Copyright (c) 2006-2012 Rogério Liesenfeld
 * This file is subject to the terms of the MIT license (see LICENSE.txt).
 */
package mockit;

import java.lang.annotation.*;

/**
 * Indicates an instance field of the test class or a parameter of the test method whose value will be an
 * isolated mocked instance, intended to be passed or injected into the code under test.
 * Such instances can be said to be proper mock objects, in contrast to the mocked instances of a
 * regular mocked type.
 * The intent is that these mock objects will be passed/injected into the tested object/unit, so that other instances
 * of the same type remain unaffected.
 * 

* The use of this annotation implies that the declared type of the mock field/parameter is a mocked type, just like it * would be if annotated with {@linkplain Mocked @Mocked}. * The {@code @Mocked} annotation can be applied at the same time, if needed. * The default mocking behavior, however, is different in several ways. *

* For the duration of each test where the mock field/parameter is in scope, only one injectable instance is * mocked; other instances of the same mocked type are not affected. * For an injectable mocked class, static methods and constructors are not mocked; * only instance methods are. *

* When used in combination with {@linkplain Tested @Tested}, the values of injectable fields and parameters will be * used for automatic injection into the tested object. * Additionally, this annotation can be applied to non-mocked fields of primitive or array type, which will also be used * for injection. * * @see #value * @see In the * Tutorial */ @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.FIELD, ElementType.PARAMETER}) public @interface Injectable { /** * Specifies a literal value when the type of the injectable mock field/parameter is {@code String}, a primitive * type, or an enum type. * For a primitive type, the value provided must be convertible to it. * For an enum type, the given textual value must equal the name of one of the possible enum values. *

* When a value is provided for an injectable whose type is {@code String} or an enum type, said type is not * mocked; otherwise, it is. */ String value() default ""; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy