Junit测试

备忘:
Action:需要依赖
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-junit-plugin</artifactId>
<version>2.3.16</version>
<scope>test</scope>
</dependency>

package action;

import com.opensymphony.xwork2.ActionProxy;
import com.renyuandao.actionImp.SocialContactActionImp;
import com.renyuandao.model.UserFriends;
import org.apache.struts2.StrutsSpringTestCase;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.transaction.TransactionConfiguration;


/**
* 此类测试action,测试功能
* Author: Dream.YnagLong
* Date: 13-12-19
* Time: 下午12:47
* E-mail:410357434@163.com
*/
@ContextConfiguration(locations={"classpath*:applicationContext*.xml",
})
@TransactionConfiguration(transactionManager="transactionManager",defaultRollback=false)
public class TempleActionTest extends StrutsSpringTestCase{
private SocialContactActionImp socialAction;
private ActionProxy proxy;
public void testSocial() throws Exception{
proxy = this.getActionProxy("/socialAction!socialContent.do");
socialAction = (SocialContactActionImp)proxy.getAction();
UserFriends userFriends = new UserFriends();
userFriends.setUserid(17);
userFriends.setFriendid(18);
userFriends.setFstatus(1);
socialAction.setUserFriends(userFriends);
String doaction = socialAction.socialContent();
this.assertEquals("social", doaction);

}
}

Service:


package service;

import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.AbstractTransactionalJUnit4SpringContextTests;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.transaction.TransactionConfiguration;

/**
* @author DR.YangLong
* spring3集成测试模板类,不允许提交SVN版本库
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath*:applicationContext*.xml",
})
@TransactionConfiguration(transactionManager="transactionManager",defaultRollback=false)
public abstract class SupperServiceTest extends AbstractTransactionalJUnit4SpringContextTests{
}


package service;

import com.renyuandao.manager.service.SuperuserService;
import com.renyuandao.model.UserDept;
import com.renyuandao.model.UserFriends;
import com.renyuandao.model.UserInfo;
import com.renyuandao.service.SocialContactService;
import com.renyuandao.service.UserInfoService;
import com.renyuandao.util.PagerHelper;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.annotation.Rollback;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.util.List;

/**
* Author: Dream.YnagLong
* Date: 13-12-19
* Time: 下午12:08
* E-mail:410357434@163.com
*/
@RunWith(SpringJUnit4ClassRunner.class)
public class TempleServiceTest extends SupperServiceTest {
//自动注入 @Autowired,推荐使用@Resource
@Resource(name = "service_userinfo")
private UserInfoService userInfoServiceervice;
@Autowired
private SuperuserService superuserService;
@Autowired
private SocialContactService socialContactService;
//涉及事务的方法都要加注解,Rollback属性默认为true,事务不会提交数据库,保护现场请设true
@Transactional
@Rollback(false)
@Test
public void testRegister(){
UserInfo user=new UserInfo();
UserDept dept=new UserDept();
dept.setDept("集成测试");
dept.setDeptadress("都市枫林");
user.setUsername("集成测试");
user.setEmail("444444@163.com");
userInfoServiceervice.addUser(user,dept);
user.getId();
}
@Transactional
@Rollback(false)
@Test
public void testGetList(){
PagerHelper pg=new PagerHelper();
UserInfo user=new UserInfo();
user.setVerifystatus(0);
int total=superuserService.getUserInfoCount(user);
pg.init(total,5);
List<UserInfo> users=superuserService.getUserInfoList(user,pg);
for(UserInfo usera:users){
System.out.println(usera.getVerifystatus());
}
user.getId();
}

@Test
@Transactional
@Rollback(false)
public void testAddFriend(){
UserFriends userFriends=new UserFriends();
userFriends.setFriendid(17);
userFriends.setUserid(18);
userFriends.setFstatus(1);
//更新状态
socialContactService.removeOrBlackFriend(userFriends);
}
}


DAO:

package dao;

import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.transaction.TransactionConfiguration;

/** 用spring测试DAO,不用加载配置文件获取sqlSession
* Author: Dream.YnagLong
* Date: 13-12-20
* Time: 下午4:17
* E-mail:410357434@163.com
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath*:applicationContext*.xml",
})
@TransactionConfiguration(transactionManager="transactionManager",defaultRollback=false)
public abstract class DaoTestBySpring {

}


package dao;

import java.io.IOException;
import java.io.Reader;

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.Test;

import com.renyuandao.dao.UserInfoMapper;
import com.renyuandao.model.UserInfo;
/**
* dao测试类,没有采用spring注入,所有DAO测试可以继承该类进行测试
* @author DR.YangLong
*
*/
public abstract class DaoTest {
// sqlSessionFactory
private static SqlSessionFactory sqlSessionFactory;
// mybatis file
private static final String MYBATIS_CONFIG_FILENAME = "mybatis-config.xml";
static {
Reader reader = null;
try {
reader = Resources.getResourceAsReader(MYBATIS_CONFIG_FILENAME);
} catch (IOException e) {
System.out.println(e.getMessage());
}
// build SqlSessionFactory by SqlSessionFactoryBuilder,the builder used once
sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
}

// the method get SqlSessionFactory
public static SqlSessionFactory getSqlSessionFactory() {
return sqlSessionFactory;
}

// the test method,this is templates method
@Test
public void addUser() {
// SqlSession
SqlSession sqlSession = getSqlSessionFactory().openSession();
try {
//create dao by SqlSession
UserInfoMapper mapper = sqlSession.getMapper(UserInfoMapper.class);
UserInfo userinfo = new UserInfo();
userinfo.setUsername("Maven");
userinfo.setPasw("thisistest");
userinfo.setBirthday("1999-10-11");
int id=mapper.insertSelective(userinfo);
sqlSession.commit();
System.out.println(id);
} finally {
sqlSession.close();
}
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值