ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Spring入门笔记--Spring集成Junit

2022-05-30 01:35:48  阅读:158  来源: 互联网

标签:xml Autowired -- Spring bean dataSource DruidDataSource Junit


Spring集成Junit

  1. SpringJunit负责创建Spring容器--RunWith
  2. 指定配置文件 --ContextConfiguration
  3. 需要测试的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

标签:xml,Autowired,--,Spring,bean,dataSource,DruidDataSource,Junit
来源: https://www.cnblogs.com/xiahounidunye/p/16325455.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有