我写了一些Spring MVC控制器JUnit测试。 JUnit测试的初始化是我所有的控制器测试常见的,所以我想创造一个抽象类,这是否初始化。
因此,我创建了以下代码:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = { "classpath*:spring/applicationContext-test.xml", "classpath*:spring/spring-mvc-test.xml" })
@Transactional
public abstract class AbstractSpringMVCControllerTest<T> {
@Autowired
protected ApplicationContext applicationContext;
protected MockHttpServletRequest request;
protected MockHttpServletResponse response;
protected HandlerAdapter handlerAdapter;
protected T controller;
@SuppressWarnings("unchecked")
@Before
public void initContext() throws SecurityException, NoSuchFieldException {
request = new MockHttpServletRequest();
response = new MockHttpServletResponse();
handlerAdapter = applicationContext.getBean(AnnotationMethodHandlerAdapter.class);
// Does not work, the problem is here...
controller = applicationContext.getBean(T);
}
}
我们的想法是创建,每个控制器我想测试我的扩展JUnit测试类AbstractSpringMVCControllerTest
。 在给定的类型extends
声明是类的控制器 。
例如,如果我想测试我AccountController
,我将创建AccountControllerTest
类这样的:
public class AccountControllerTest extends AbstractSpringMVCControllerTest<AccountController> {
@Test
public void list_accounts() throws Exception {
request.setRequestURI("/account/list.html");
ModelAndView mav = handlerAdapter.handle(request, response, controller);
...
}
}
我的问题是坐落在的最后一行initContext()
抽象类的方法。 这个抽象类声明的controller
对象作为一个T
的对象,但对Spring应用上下文返回类型的豆怎么能说T
?
我已经试过类似的东西:
Class<?> controllerClass = this.getClass().getSuperclass().getDeclaredField("controller").getType();
controller = (T) applicationContext.getBean(controllerClass);
但controllerClass
返回java.lang.Object.class
类,而不是AccountController.class
。
当然,我可以创建一个public abstract Class<?> getControllerClass();
方法,该方法将各控制器的JUnit测试类被重写,但我更喜欢以避免该溶液中。
因此,任何想法?