Test annotation告诉JUnit公共void方法到哪个 附加可以作为测试用例运行。要运行该方法,请使用JUnit 首先构造一个新的类实例然后调用 注释方法。将报告测试引发的任何异常 由JUnit作为失败。如果没有抛出异常,那么测试就是 假设已经成功。
这可能意味着,对于每个@Test
方法,应该再次初始化上下文。这个答案也证实了这一点:https://stackoverflow.com/a/1564309/258483
同时,我在实验中看到了相反的情况:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = SpringJUnit4ClassRunnerDemo._Config.class)
public class SpringJUnit4ClassRunnerDemo {
public static class Bean1 {
{
System.out.println("Bean1 constructor called");
}
}
public static class Bean2 {
{
System.out.println("Bean2 constructor called");
}
private Bean1 bean1;
public Bean1 getBean1() {
return bean1;
}
@Autowired
public void setBean1(Bean1 bean1) {
this.bean1 = bean1;
System.out.println("Bean2.bean1 property set");
}
}
@Configuration
public static class _Config {
@Bean
public Bean1 bean1() {
return new Bean1();
}
@Bean
public Bean2 bean2() {
return new Bean2();
}
}
@Autowired
private Bean1 bean1;
@Autowired
private Bean2 bean2;
@Test
public void testBean1() {
assertNotNull(bean1);
System.out.println("testBean1() done");
}
@Test
public void testBean2() {
assertNotNull(bean2);
assertSame(bean2.getBean1(), bean1);
System.out.println("testBean2() done");
}
}
此代码输出
Bean1 constructor called
Bean2 constructor called
Bean2.bean1 property set
testBean1() done
testBean2() done
这可能意味着,在第二次测试之前第二次没有初始化上下文。
什么是实际和正确的行为以及如何控制它?
答案 0 :(得分:2)
如果您希望在测试方法之间重新加载Spring上下文,则需要使用@DirtiesContext
注释:https://docs.spring.io/spring/docs/current/javadoc-api/org/springframework/test/annotation/DirtiesContext.html