我正在尝试测试使用2项服务的ClassA
。一个服务需要自动装配,一个服务需要被视为模拟对象。不幸的是,模拟对象是
未注射
到我测试的课程。所有字段都表现得像我只使用spring autowiring feauture来设置它。经过测试的ClassA也继承自其他抽象类。如果没有使用自动装配,则成功传递模拟对象。不幸的是,我无法嘲笑ServiceDao,这就是为什么我要尝试合并@InjectMocks
和@Autowiring
注释。
A类。
public ClassA extends AbstractClassA<ClassOne, ClassTwo>{
@Autowired
protected ServiceOne serviceOne; //this services needs to be mocked
@Override
protected List<ClassTwo> testedMethod(){
return serviceOne.getList(); //here method is not returning mocked objects
} //as it supposed to do.
........
}
抽象类
public class AbstractClassA<T1 extends InterfaceOne, T2 extends InterfaceTwo){
@Autowired
protected ServiceDAO serviceDAO; //this services needs to be autowired
protected abstract List<T2> testedMethod();
}
识别TestClass。
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath*:testApplicationContext.xml"})
public class Test {
@Mock
private ServiceOne serviceOne; //this mock object and it's return
//objects are set properly
@Autowired
@InjectMocks
private ClassA classA; //all fields are autowired, including the services that should be mocked
@Before
public void setData(){
Mockito.Annotations.initMocks(this);
List<ClassTwo> result = Arrays.asList(new ClassA());
when(serviceOne.testedMethod().thenReturn(result); //here when i invoke mocked object it is returning correct list.
}
}
答案 0 :(得分:5)
在这种情况下,最好通过Spring测试上下文配置来模拟注入的bean。如果您无法轻松完成此操作,则可以使用Springs ReflectionTestUtils类来模拟服务中的单个对象。
在测试配置XML文件中,您可以定义一个模拟bean:
List<Animal> animal = (List<Animal>) getSession().createCriteria(Class clazz).list();
在Java方面:
<bean id="serviceOne" class="org.mockito.Mockito" factory-method="mock"/>
<constructor-arg value="com.package.ServiceOne"/>
</bean>
在您的测试用例中,您可以@Bean
public ServiceOne serviceOne() {
return mock(ServiceOne.class);
}
并将其用作模拟对象:
@Autowire ServiceOne serviceOne