使用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 }

 

posted @ 2015-09-19 18:18  Ryan.Miao  阅读(933)  评论(0编辑  收藏  举报