通常只会使用junit测试非main方法,在我眼里就是程序入口实现而已。今天,发现原来可以测试类。
针对mybatis练习。在需要测试的UserDaoImpl类上右键,新建一个junit case,位置可以放到新创建的source folder :test里面。
选择需要测试的方法:
然后就会生成一个测试方法,自己补足测试方法就好:
package cn.mrf.mybatis.dao; import static org.junit.Assert.*; import java.io.InputStream; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test; import cn.mrf.mybatis.po.User; public class UserDaoImplTest { private SqlSessionFactory sqlSessionFactory; //此方法是在执行testFindUserById之前执行
@Before
public void setUp() throws Exception{
//创建sqlSessionFactory
//mybatis配置文件
String resource = "SqlMapConfig.xml"; InputStream inputStream = Resources.getResourceAsStream(resource);
//创建会话工厂,传入mybatis的配置文件信息
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); } @Test
public void testFindUserById() throws Exception {
//创建UserDao对象
UserDao userDao = new UserDaoImpl(sqlSessionFactory);
//调用
User user = userDao.findUserById(1); System.out.println(user);
} }
下面是被测试的类:
package cn.mrf.mybatis.dao; import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory; import cn.mrf.mybatis.po.User;
/**
*
* @ClassName: UserDaoImpl
* @Description: 接口实现类
* @author mrf
* @date 2015-9-19 下午05:57:03
*
*/
public class UserDaoImpl implements UserDao { // 需要向dao实现类中注入SqlSessionFactory
// 这里通过构造方法注入
private SqlSessionFactory sqlSessionFactory; public UserDaoImpl(SqlSessionFactory sqlSessionFactory) {
this.sqlSessionFactory = sqlSessionFactory;
} @Override
public User findUserById(int id) throws Exception {
//sqlSession是线程不安全的,所以单独使用
SqlSession sqlSession = sqlSessionFactory.openSession(); User user = sqlSession.selectOne("test.findUserById",id); //释放资源
sqlSession.close();
return user;
} @Override
public List<User> findUserByName(String name) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession(); List<User> list = sqlSession.selectList("test.findUserByName",name); //释放资源
return list;
} @Override
public void insertUser(User user) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
//执行插入
sqlSession.insert("test.insertUser",user); //提交事物
sqlSession.commit();
// 释放资源
sqlSession.close(); } @Override
public void deleteUser(int id) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession(); //执行插入操作
sqlSession.delete("test.deleteUser", id); // 提交事务
sqlSession.commit(); // 释放资源
sqlSession.close();
} }