使用junit测试用例

通常只会使用junit测试非main方法,在我眼里就是程序入口实现而已。今天,发现原来可以测试类。

针对mybatis练习。在需要测试的UserDaoImpl类上右键,新建一个junit case,位置可以放到新创建的source folder :test里面。

选择需要测试的方法:

然后就会生成一个测试方法,自己补足测试方法就好:

 1 package cn.mrf.mybatis.dao;
 2 
 3 import static org.junit.Assert.*;
 4 
 5 import java.io.InputStream;
 6 
 7 import org.apache.ibatis.io.Resources;
 8 import org.apache.ibatis.session.SqlSession;
 9 import org.apache.ibatis.session.SqlSessionFactory;
10 import org.apache.ibatis.session.SqlSessionFactoryBuilder;
11 import org.junit.Before;
12 import org.junit.Test;
13 
14 import cn.mrf.mybatis.po.User;
15 
16 public class UserDaoImplTest {
17     
18     private SqlSessionFactory sqlSessionFactory;
19     
20     //此方法是在执行testFindUserById之前执行
21     @Before
22     public void setUp() throws Exception{
23         //创建sqlSessionFactory
24         //mybatis配置文件
25         String resource = "SqlMapConfig.xml";
26         
27         InputStream inputStream = Resources.getResourceAsStream(resource);
28         //创建会话工厂,传入mybatis的配置文件信息
29         sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); 
30         
31     }
32 
33     @Test
34     public void testFindUserById() throws Exception {
35         //创建UserDao对象
36         UserDao userDao = new UserDaoImpl(sqlSessionFactory);
37         //调用
38         User user = userDao.findUserById(1);
39         
40         System.out.println(user);
41     }
42 
43 }

下面是被测试的类:

 1 package cn.mrf.mybatis.dao;
 2 
 3 import java.util.List;
 4 
 5 import org.apache.ibatis.session.SqlSession;
 6 import org.apache.ibatis.session.SqlSessionFactory;
 7 
 8 import cn.mrf.mybatis.po.User;
 9 /**
10  * 
11 * @ClassName: UserDaoImpl 
12 * @Description: 接口实现类
13 * @author mrf
14 * @date 2015-9-19 下午05:57:03 
15 *
16  */
17 public class UserDaoImpl implements UserDao {
18 
19     // 需要向dao实现类中注入SqlSessionFactory
20     // 这里通过构造方法注入
21     private SqlSessionFactory sqlSessionFactory;
22     
23     public UserDaoImpl(SqlSessionFactory sqlSessionFactory) {
24         this.sqlSessionFactory = sqlSessionFactory;
25     }
26 
27     
28     @Override
29     public User findUserById(int id) throws Exception {
30         //sqlSession是线程不安全的,所以单独使用
31         SqlSession sqlSession = sqlSessionFactory.openSession();
32         
33         User user = sqlSession.selectOne("test.findUserById",id);
34         
35         //释放资源
36         sqlSession.close();
37         return user;
38     }
39 
40     @Override
41     public List<User> findUserByName(String name) throws Exception {
42         SqlSession sqlSession = sqlSessionFactory.openSession();
43         
44         List<User> list = sqlSession.selectList("test.findUserByName",name);
45         
46         //释放资源
47         return list;
48     }
49 
50     @Override
51     public void insertUser(User user) throws Exception {
52         SqlSession sqlSession = sqlSessionFactory.openSession();
53         //执行插入
54         sqlSession.insert("test.insertUser",user);
55         
56         //提交事物
57         sqlSession.commit();
58         // 释放资源
59         sqlSession.close();
60 
61 
62     }
63 
64     @Override
65     public void deleteUser(int id) throws Exception {
66         SqlSession sqlSession = sqlSessionFactory.openSession();
67 
68         //执行插入操作
69         sqlSession.delete("test.deleteUser", id);
70 
71         // 提交事务
72         sqlSession.commit();
73 
74         // 释放资源
75         sqlSession.close();
76     }
77 
78 }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏函数式编程语言及工具

Akka(9): 分布式运算:Remoting-远程构建式

   上篇我们讨论了Akka-Remoting。我们说Akka-Remoting是一种点对点的通讯方式,能使两个不同JVM上Akka-ActorSystem上的...

2279
来自专栏我就是马云飞

Rxjava2最全面的解析

前言 由于公司重新规划的部门,我调到了另外一个部门,所以负责的项目也换了,仔细看了下整体的项目,rxjava+retrofit。整体的一套。众所周知,rxja...

33010
来自专栏Java成神之路

Java微信公众平台开发_07_JSSDK图片上传

(2)对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL键值对的格式 (即 key1=value1&key2=value2…)拼接成...

2831
来自专栏IT可乐

mybatis源码解读(一)——初始化环境

1512
来自专栏Linux驱动

问题

如果在ucos中使用浮点数,尽量使用__align(8) 对齐,否则串口打印浮点数会乱码,比如:

885
来自专栏生信小驿站

数据处理第2节:将列转换为正确的形状

博客原文:https://suzan.rbind.io/2018/01/dplyr-tutorial-1/ 作者:Suzan Baert

1533
来自专栏java学习

Mybatis学习笔记2

Mybatis学习笔记2 本章目录描述: 1、Dao开发方法 1.1需求 1.2SqlSession的使用范围 1.3原始Dao开发方式 ...

2777
来自专栏余林丰

MyBatis源码解读(1)——SqlSessionFactory

在前面对MyBatis稍微有点了解过后,现在来对MyBatis的源码试着解读一下,并不是解析,暂时定为解读。所有对MyBatis解读均是基于MyBatis-3....

2287
来自专栏大前端_Web

easyUI组件datagrid的二次封装

版权声明:本文为吴孔云博客原创文章,转载请注明出处并带上链接,谢谢。 https://blog.csdn.net/wkyseo/articl...

1983
来自专栏软件开发

MyBatis学习总结(四)——MyBatis缓存与代码生成

缓存可以提高系统性能,可以加快访问速度,减轻服务器压力,带来更好的用户体验。缓存用空间换时间,好的缓存是缓存命中率高的且数据量小的。缓存是一种非常重要的技术。

1883

扫码关注云+社区