Spring入门笔记--Spring集成Junit
Spring集成Junit
- SpringJunit负责创建Spring容器--RunWith
- 指定配置文件 --ContextConfiguration
- 需要测试的Bean在测试类注入--Autowired
准备工作
pom.xml引入SpringJunit
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.1.5.RELEASE</version>
</dependency>
SpringJunitTest.java
@RunWith(SpringJUnit4ClassRunner.class)
//@ContextConfiguration("classpath:applicationContext.xml")
@ContextConfiguration(classes = {SpringConfiguration.class}) //不使用xml则通过类配置
public class SpringJunitTest {
@Autowired
private UserService userService;
@Autowired
private DruidDataSource dataSource;
@Test
public void test1() throws SQLException {
userService.save();
System.out.println(dataSource.getConnection());
}
}
注意,此处能返回数据库的dataSource,是因为@Autowired注解默认通过数据类型去扫描spring容器中的数据。
如果有两个方法都返回DruidDataSource类型的数据,会抛出异常No qualifying bean of type 'com.alibaba.druid.pool.DruidDataSource' available: expected single matching bean but found 2: dataSource1,testDataSource,比如:
类进行配置
@Bean("dataSource1") //如果只有一个方法返回DruidDataSource数据,则注解名称无所谓。
public DataSource getDataSource(){
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driver);
dataSource.setUrl(url);
dataSource.setUsername(username);
dataSource.setPassword(password);
return dataSource;
}
@Bean("testDataSource") //spring会将当前方法返回值以指定名称存储到spring容器中,即xml中的bean id。
public DataSource getDataSource1(){
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driver);
dataSource.setUrl(url);
dataSource.setUsername(username);
dataSource.setPassword(password);
return dataSource;
}
或者
applicationContext.xml
<bean id="databaseTest1" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driver}"/>
...
</bean>
<bean id="databaseTest2" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driver}"/>
...
</bean>
解决方法:@Autowired后增加@Qualifier("dataSource1"),指定bean id
浙公网安备 33010602011771号