模拟多用户进行压力测试

本文介绍了一种使用Java反射和线程池技术进行压力测试的方法,模拟了1000个用户调用unit test。通过创建线程池并根据用户数决定线程数量,每个线程通过反射获取并执行测试类的所有方法,最后汇总并打印所有测试结果。

      这周二接到mentor分配的任务,写压力测试,主要模拟大约1000个用户,调用unit test对系统进行压力测试。刚开始mentor的意思是给每一个unit test写一个test,以多线程方式调用它进行压力测试。一时头大,那得写很多个测试,还得一个方法一个方法的调用。后来懒了一下,稍作改变写了以下一个test,可以对所有的unit test 压力测试。思路如下:

    

       主要采用了java反射和线程池两种技术。运行这个test,要求输入两个参数,一个是目标unit test的完整类名,一个是要模拟的用户数目。在该test中,建立线程池,根据输入的用户数目决定要运行的线程数(最终要求是运行1000个)。在每个线程中需要做的事是:利用完整类名,通过反射获取该类,以及其他属性,并获取、调用所有测试方法,并将测试结果保存在一个全局对象中。当所有线程运行完后,在主进程中打印所有测试结果。

      

      期间碰到种种问题,有种种由于线程并发带来的问题,最终得到下面一串代码。 

 

package com.ssc.sats.usertestall;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.lang.reflect.Method;
import java.lang.reflect.Field;
import java.util.concurrent.Executors;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.TimeUnit;
import junit.framework.TestCase;
import org.apache.log4j.Logger;
import com.ssc.faw.util.GenCache;
import com.ssc.faw.util.GenCacheObject;
import com.ssc.sats.cab.workflow.idf.IDF_7831011;

/**
 *
 * @author a522381
 *
 * This class is used to test the project as if there are many users
 *
 */
public class IDF_pressure_test extends TestCase
{
    private transient static Logger log = Logger.getLogger(IDF_pressure_test.class);
    private int waitTime = 30;
    private int poolSize = 20;

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值