Bug整理——Spring boot 执行Junit Test时不加载Application中的参数的问题

在我们的项目中,需要在Application中设置几个系统参数才能正常打印日志,所以在Application.java中,我们是这么写的:

@EnableTransactionManagement
@SpringBootApplication
@EnableCasClient
@ComponentScan(basePackages={"com.test"})
public class Application {
	public static void main(String[] args) throws Exception {
		System.setProperty("aaa","bbbb");
		SpringApplication.run(Application.class, args);
	}
}

需要设置一个aaa = bbb,但是在执行test时,每次get时,却发现是不正确的。后来经过排查,在跑test时,是不执行这个main方法的,所以才不会设置上,所以开始我是这么修复的:

    
@Test
public void update(){
   System.setProperty("aaa","bbbb");
   //TODO 写自己的test逻辑
}

发现还是不对!!!

然后又意识到其实这里的代码只有执行后才会生效,而我的getProperty的逻辑在config中,所以仍然获取不到、

最后得出结论,需要在使用这个property参数之前设置。(好像废话一样....)

在configuration的代码中加载是最好的,最先被执行。


你可能感兴趣的:(BUG总结)