用junitperf做并发测试带来的问题

原创 2005年04月26日 12:20:00

关于junitperf的一点介绍

junitperf 是个很小巧的java性能测试框架,可以在http://sourceforge.net/project/showfiles.php?group_id=15278 上下载到。可以很容易的把它结合junit一起测试,比如在测试套件里面加这么几行:

import com.clarkware.junitperf.TimedTest;
import com.clarkware.junitperf.LoadTest;
.......

    int testTimes = 10;
    int users = 5;

    suite.addTest(new TestUserDAO("test1AddUser")); //基本功能测试,同时初始化环境
  
    suite.addTest(new TimedTest(new TestUserDAO("test1AddUser"), 1000)); //基本性能测试:方法应在1秒内完成

    suite.addTest(new LoadTest(new TestUserDAO("test1AddUser"), users)); // 并发测试

  suite.addTest(new LoadTest(new TestUserDAO("test1AddUser"),users,testTimes)); //并发负载测试

  suite.addTest(new TimedTest(new LoadTest(new TestUserDAO("test1AddUser"),
                                           users,testTimes), 35000)); //并发性能测试

如果只需要反复做一个测试而不需要并发测试,可以

suite.addTest(new LoadTest(new TestUserDAO("test1AddUser"),1,testTimes));

当然也可以不用junitperf,junit.extensions.RepeatedTest就是设计来干这个的:

suite.addTest(new RepeatedTest(new TestUserDAO("test1AddUser"), testTimes)); //重复测试

用junitperf做并发测试带来的问题

做并发测试的时候junitperf有一个问题。注意看这一行:

new LoadTest(new TestUserDAO("test1AddUser"), users)

我们只传递了一个TestUserDAO实例给LoadTest,却要求它开启users个线程来测试,这样这users个线程就会只针对同一个TestUserDAO实例进行测试。这个时候,我们在TestUserDAO里面就不能存放任何状态数据了。比如以前我很喜欢这么做:

public class TestUserDAO extends TestCase{
 private int lastId;
 protected void setUp() throws Exception{
  super.setUp();
  //构造一个测试用的数据
  User user = new User("张三");
  //向数据库插入一条记录
  userDAO.addUser(user);
  lastId = user.getId();//刚刚插入的记录在数据库中产生的ID;
 }

 public void testUpdateUser() throws DaoException{
  //针对setup中插入的数据进行update操作
  user = userDAO.getUserById(lastId);
  user.setName("李四");
  userDAO.updateUser(user);
 }
 protected void tearDown() throws Exception{
  //删除测试数据
  userDAO.deleteUserById(lastId);
  super.tearDown();
 }
这样我是通过一个int变量lastId在各个方法之间传递被测试的数据的。如果用junitperf来测试,lastId变量就会被后来的线程覆盖,导致测试失败。

解决方法

在com.clarkware.junitperf.TestFactory的文档中对这个问题做了说明:

This factory class should be used in cases when a stateful test is intended to be decorated by a <code>LoadTest</code>.  A stateful test is defined as any test that defines test-specific state in its <code>setUp()</code> method.

TestFactory的使用方法是这样:

import com.clarkware.junitperf.TestFactory;

......

     suite.addTest(new LoadTest(new TestFactory(TestUserDAO.class), users,testTimes)); //并发负载测试

但是这样只能观察整个测试类的表现。如果我们要单个的测试测试类中的一个测试,那么可以考虑另一种方法。我们在TestFactory的文档中看到:

 This class is dependent on Java 2.  For earlier platforms a  local cache implementation should be changed to use, for example,  a HashMap to track thread-local information.

这个方法同事也适用于我们需要处理的情况:

public class TestUserDAO extends TestCase{
 private static final ThreadLocal threadLocal = new ThreadLocal();
 protected void setUp() throws Exception{
  super.setUp();
  //构造一个测试用的数据
  User user = new User("张三");
  //向数据库插入一条记录
  userDAO.addUser(user);
  //lastId = user.getId();//刚刚插入的记录在数据库中产生的ID;
  threadLocal.set(new Integer(user.getId()));
 }

 public void testUpdateUser() throws DaoException{
  //针对setup中插入的数据进行update操作
  //user = userDAO.getUserById(lastId);
  user = userDAO.getUserById(((Integer)threadLocal.get()).intValue());
  user.setName("李四");
  userDAO.updateUser(user);
 }
 protected void tearDown() throws Exception{
  //删除测试数据
  userDAO.deleteUserById(((Integer)threadLocal.get()).intValue());
  super.tearDown();
 }

author: emu(黄希彤)

Java并发测试扩展插件JunitPerf的使用

首先,不得不承认一个悲剧的事实,Junit4.0根本不支持并发测试。于是,我从网上挖掘到两个可以用于并发测试的eclipse插件。一个是GroboUtils-5,另一个是JunitPerf。由于某些原...
  • gx262091291
  • gx262091291
  • 2014年10月27日 10:06
  • 1092

junitPerf

在java开发中经常使用junit的朋友一定也会喜欢junitPerf,若你不是很了解或不是很熟悉,建议你静下心来,慢慢的把下面的文字看完,这里绝没有晦涩的语言,作者可谓循循善诱、由浅入深。 去年的时...
  • sdlcn
  • sdlcn
  • 2008年08月01日 21:59
  • 2848

追求代码质量: 用 JUnitPerf 进行性能测试

在应用程序的开发周期中,性能测试常被放到最后考虑,这并不是因为它不重要,而是因为存在这么多未知变量,很难有效地测试。在本月的 追求代码质量 系列中,Andrew Glover 使性能测试成为开发周期的...
  • ibmjournal
  • ibmjournal
  • 2006年12月25日 15:14
  • 750

JunitPerf使用简明手册

    代码效率对于许多开发者而言是一个非常关心的指标。而且,代码执行效率的高低对于应用的使用者来说是感觉最直观的。它往往也是一个应用是否成功的关键性指标之一。那么是否存在那些能够反映代码执行效率的工...
  • foxgemm
  • foxgemm
  • 2004年06月03日 16:57
  • 1137

junitperf-1.9.1.zip

  • 2009年09月21日 16:18
  • 68KB
  • 下载

junit4.10+dbunit2.4.7+httpunit+junitperf的jar包

  • 2012年05月29日 09:53
  • 5MB
  • 下载

Spring带来的问题

          Spring对接口与实现进行了解耦,它是工程的粘合剂,同时也变成了最大的耦合剂。过多bean的配置和更加多的bean属性的配置,产生的结果是你的工程牢牢的依赖于spring。一旦失...
  • lostsky
  • lostsky
  • 2005年10月10日 14:50
  • 1489

数据库并发操作会带来哪些问题及原因

(1)丢失更新         当两个或多个事物读入同一数据并修改,会发生丢失更新问题,即后一个事物更新的结果被前一事务所做更新覆盖 即当事务A和B同事进行时,事务A对数据已经改变但并未提交时B又对...
  • echo_sy
  • echo_sy
  • 2017年03月20日 20:52
  • 2845

junitperf-1.8.jar

  • 2017年06月11日 17:15
  • 28KB
  • 下载

用junitperf做并发测试带来的问题

关于junitperf的一点介绍junitperf 是个很小巧的java性能测试框架,可以在http://sourceforge.net/project/showfiles.php?group_id=...
  • emu
  • emu
  • 2005年04月26日 12:20
  • 3711
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用junitperf做并发测试带来的问题
举报原因:
原因补充:

(最多只允许输入30个字)