在我们的项目中,需要在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的代码中加载是最好的,最先被执行。