MockBean

Annotation that can be used to add mocks to a Spring ApplicationContext. Can be used as a class level annotation or on fields in either @Configuration classes, or test classes that are @RunWith the SpringRunner.

Mocks can be registered by type or by bean name. When registered by type, any existing single bean of a matching type (including subclasses) in the context will be replaced by the mock. When registered by name, an existing bean can be specifically targeted for replacement by a mock. In either case, if no existing bean is defined a new one will be added. Dependencies that are known to the application context but are not beans (such as those registered directly) will not be found and a mocked bean will be added to the context alongside the existing dependency.

When @MockBean is used on a field, as well as being registered in the application context, the mock will also be injected into the field. Typical usage might be:

@RunWith(SpringRunner.class)
public class ExampleTests {

    @MockBean
    private ExampleService service;

    @Autowired
    private UserOfService userOfService;

    @Test
    public void testUserOfService() {
        given(this.service.greet()).willReturn("Hello");
        String actual = this.userOfService.makeUse();
        assertEquals("Was: Hello", actual);
    }

    @Configuration
    @Import(UserOfService.class) // A @Component injected with ExampleService
    static class Config {
    }


}
If there is more than one bean of the requested type, qualifier metadata must be specified at field level:
@RunWith(SpringRunner.class)
public class ExampleTests {

    @MockBean
    @Qualifier("example")
    private ExampleService service;

    ...
}

This annotation is @Repeatable and may be specified multiple times when working with Java 8 or contained within an @MockBeans annotation.

Author

Phillip Webb

Since

1.4.0

See also

Functions

Link copied to clipboard
abstract fun annotationType(): Class<out Annotation>
Link copied to clipboard
abstract fun answer(): Answers
The Answers type to use on the mock.
Link copied to clipboard
@AliasFor(value = "value")
abstract fun classes(): Array<Class<out Any>>
The classes to mock.
Link copied to clipboard
abstract fun equals(p: Any): Boolean
Link copied to clipboard
abstract fun extraInterfaces(): Array<Class<out Any>>
Any extra interfaces that should also be declared on the mock.
Link copied to clipboard
abstract fun hashCode(): Int
Link copied to clipboard
abstract fun name(): String
The name of the bean to register or replace.
Link copied to clipboard
abstract fun reset(): MockReset
The reset mode to apply to the mock bean.
Link copied to clipboard
abstract fun serializable(): Boolean
If the generated mock is serializable.
Link copied to clipboard
abstract fun toString(): String
Link copied to clipboard
@AliasFor(value = "classes")
abstract fun value(): Array<Class<out Any>>
The classes to mock.