有一个任务,需要频繁发送订单请求,并分析订单请求中有没有存在重复订单号,思路是用jmeter 发送http请求,使用正则表达式获取到订单号,并把订单号和线程号作为参数提供给java请求,在java请求中把订单号写到包括有线程号的命名文件中。完成出来的样子是这样的
步骤如下:
1、Jmeter 发送http请求
1) 新建HTTP信息头管理器
2) 新建HTTP请求
2,在下单过后返回部分信息如下:"msg":"下单成功","result":"1","sendCode":"96828628","weektm":"星期二,12:00"
新建 正则表达式提取器 ,获取sendCode 后面的值96828628 正则表达式填写:"sendCode":"(\d{8}),这样订单号就保存在变量sendCode中
3、到此,订单号sendCode已经获取到,需要把这个订单号保存到文件中,可以采用“保存响应到文件” 把响应保存到以线程命名的文件中,但是不好的是一个文件只能保存一个结果,不能往结果中追加结果,对于后期汇总不方便
这里使用了java请求来处理,按线程文件名命名,把同一个线程所有的响应结果保存到同一个文件中,n个线程就保存n个文件,这样就使用了java请求,java请求需要做的有
1)新建一个java类AppendFile 功能是往文件中追加内容
package editFile; import java.io.IOException; import java.io.RandomAccessFile; public class AppendFile { public static void main(String[] args) { AppendFile.appendFile("E:\\dd.txt", "1111"); AppendFile.appendFile("E:\\dd.txt", "11111"); } public static void appendFile(String fileName, String content) { try { // 打开一个随机访问文件流,按读写方式 RandomAccessFile randomFile = new RandomAccessFile(fileName, "rw"); // 文件长度,字节数 long fileLength = randomFile.length(); // 将写文件指针移到文件尾。 randomFile.seek(fileLength); randomFile.writeBytes(content + "\r\n"); randomFile.close(); } catch (IOException e) { e.printStackTrace(); } } }
2)新建一个java请求类WriteResult ,作用是从jmeter获取订单号和线程号,并使用订单号和线程号 写人文件,同时jmeter 性能测试的java请求也是这样来实现的,按照格式在runTest 中做各种请求。
package editFile; import org.apache.jmeter.config.Arguments; import org.apache.jmeter.protocol.java.sampler.JavaSamplerClient; import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext; import org.apache.jmeter.samplers.SampleResult; public class WriteResult implements JavaSamplerClient { private SampleResult results; private String senCode; private String threadNumber; // 设置从jmeter传入参数 public Arguments getDefaultParameters() { Arguments params = new Arguments(); params.addArgument("senCode", "0");// 设置senCode参数 params.addArgument("threadNumber", "0");// 设置threadNumber return params; } // 初始化方法,性能测试时只执行一次 public void setupTest(JavaSamplerContext arg0) { } // 重复执行测试的地方 public SampleResult runTest(JavaSamplerContext arg0) { senCode = arg0.getParameter("senCode"); // 获取jmeter传入的参数值, threadNumber = arg0.getParameter("threadNumber"); // 获取jmeter传入的参数值, results = new SampleResult(); results.sampleStart();// jmeter 开始统计响应时间标记 AppendFile.appendFile("E:\\jmeter\\"+threadNumber+".txt", senCode); if(senCode.length() ==8){ results.setSuccessful(true); results.setResponseData("threadNumber:"+threadNumber+"|senCode:"+senCode, null); }else{ results.setSuccessful(false); results.setResponseData("threadNumber:"+threadNumber+"|没有获取到验证码 ", null); } results.sampleEnd();// jmeter 结束统计响应时间标记 return results; } // 结束方法,实际运行时每个线程仅执行一次,在测试方法运行结束后执行 public void teardownTest(JavaSamplerContext arg0) { } public static void main(String[] args) { // TODO Auto-generated method stub } }
把java项目文件导出jar包,放在jmeter 的lib/ext 文件夹中
打开jmeter添加一个jmeter 的java请求,选中测试类,会自动显示2个参数 sendCode 和threadNumber(这2个参数是在java请求类的的方法中设置:public Arguments getDefaultParameters()
sendCode = ${sendcode}
threadNumber = ${__threadNum}
使用3个线程执行多次,结果如下:
另外使用bean shel 也能保存文件,需要在bean shell中写代码
import editFile.*; import org.apache.jmeter.threads.JMeterContextService; int threadNumber = JMeterContextService.getNumberOfThreads(); String sendCode = vars.get("sendcode"); //把获取的sendcode 变成bean shell变量值 AppendFile.appendFile("E:\\jmeter\\result"+threadNumber+".txt", sendCode); System.out.println("finished");
但是 获取的线程号代码都是1,因此所有的订单号都保存在同一个文件中,不知道这样会不会都在写同一个文件导致文件不全,要测试下才知道