我最近问了this question关于从 applicationContext 中拉出 bean。答案确实很有帮助,但现在看来我在从测试之外的类访问这个 bean 时遇到了问题。换句话说,我的测试实例化了一个使用来自应用程序上下文的 bean 的类,但这个 bean 一直为 null。
我的测试像这样设置应用程序上下文:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "/applicationContext-test.xml")
public class SearcherTests {
我的测试以编程方式实例化 Repository 类:
Repository searcher = new Repository();
我的 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();
}
}
当我从浏览器运行应用程序时,myFactory
变量已根据 applicationContext.xml
中的 bean 定义正确实例化。在我的测试中,为了确保我的 applicationContext-test.xml
正常工作,我将这个相同的 bean 列为成员变量,就像我在 Repository
类中所做的那样。运行测试时,包含测试的文件中的 myFactory
变量看起来与我预期的完全一样。但是,当我到达 Repository
类时,该类中的 myFactory
变量为空。好像这个类没有根据 applicationContext-test.xml
中的 bean 定义实例化 myFactory
变量。谁能告诉我为什么?
更新
我更改了 searcher
变量,使其成为一个 Spring bean,而不是手动实例化 Repository
类,现在是 myFactory
变量已填充到 Repository
类中。有人可以解释为什么这需要是一个 bean 才能工作吗?
最佳答案
如果您自己实例化Repository
,则Spring 不会参与,也不会注入(inject)依赖项。它不会神奇地发生,Spring 必须以某种方式处于循环中 - 实例必须通过 Spring 处理层传递,而直接实例化可以防止这种情况发生。
关于java - 那么现在为什么我的 bean 是空的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4306908/