场景
项目正常运行
运行junit测试方式时报以上错误。
Failuer Trace:
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'permeateController': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: private com.kylin.aep.service.PermeateService com.kylin.aep.controller.PermeateController.permeateServiceImpl; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'PermeateServiceImpl' defined in file [D:\workspace\aep\target\classes\***\serviceimpl\PermeateServiceImpl.class]: Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.kylin.aep.serviceimpl.PermeateServiceImpl]: Constructor threw exception; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.**.solr.SolrClient] is defined
分析
根据failure tarce 找到PermeateServiceImpl中有这样一段代码:
SolrClient solrClient = SpringContextUtil.getBean(SolrClient.class);
SolrClient.class对应com.**.solr.SolrClient。
可以知道,问题就出现在这一句代码上。
临时解决办法
我要测试的代码与com.**.solr.SolrClient无关,所以我注释掉这一行代码。
然后运行junit测试方法,成功。
追究原因
测试工作完成,现在回过头研究为什么会出现这个问题。
No qualifying bean of type [com.**.solr.SolrClient] is defined
那么我们来看一下配置文件。
发现SpringServlet.xml中有以下配置:
<!-- solr配置 -->
<bean id="solrClient" class="com.kylin.aep.solr.SolrClient"
scope="singleton">
<constructor-arg name="solrURL" value="${solr.url}" />
<constructor-arg name="coreName" value="${solr.core}" />
<constructor-arg name="maxClient" value="${solr.max.client}" />
</bean>
而SpringServletTest.xml中没有。
加上以上配置,再运行junit测试方法,果然不报错。