我最近问this question关于将bean从applicationContext中拉出.答案确实有用,但是现在看来我在从测试之外的类访问此bean时遇到问题.换句话说,我的测试实例化了一个使用来自应用程序上下文的Bean的类,但是该Bean一直保持为空.
我的测试像这样设置应用程序上下文:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "/applicationContext-test.xml")
public class SearcherTests {
我的测试以编程方式实例化了Repository类:
Repository searcher = new Repository();
我的存储库类具有以下成员变量:
@Resource
private MyFactory myFactory;
如果我对Spring的理解正确,那么应该在当前应用程序上下文中查找名为myFactory的bean.根据测试,当前应用程序上下文应为applicationContext-test.xml,其中包含myFactory的定义:
<bean id="myFactory"
name="myFactory"
class="com.foo.Mocks"
factory-method="createMockFactory" />
将来,此工厂方法将返回一个模拟.但是目前,它只是返回一个常规的Factory对象:
public class Mocks {
public static MyFactory createMockFactory() {
return new MyFactory();
}
}
当我从浏览器运行该应用程序时,已从applicationContext.xml中的bean定义正确实例化了myFactory变量.在我的测试中,为确保我的applicationContext-test.xml正常工作,就像在Repository类中一样,将相同的bean作为成员变量列出.运行测试时,包含测试的文件中的myFactory变量看起来与我期望的完全一样.但是,当我进入Repository类时,该类中的myFactory变量为null.似乎此类未基于applicationContext-test.xml中的Bean实例化myFactory变量.有人可以告诉我为什么吗?
更新资料
我更改了搜索程序变量,使其成为Spring Bean,而不是手动实例化Repository类,现在myFactory变量已填充到Repository类中.有人可以解释为什么要使用它才能工作吗?
最佳答案
如果您自己实例化Repository,则不会涉及Spring,也不会注入依赖项.这不是神奇的事情,Spring必须以某种方式处于循环中-实例必须通过Spring处理层传递,而直接实例化可以防止这种情况的发生.