jmeter之自定义java请求性能测试

写在前面

最近个人情绪不稳定、心情很不美丽,特别懒,没有博客和技术文章更新,这个文章也是迟到了一周多的时间,啰嗦完了,开始正题吧。

我们在实际做性能测试的时候,一般会采用jmeter、Lr进行测试,但是很少有同学用jmeter的测试Java请求,也可以这么说,一般是开发自己搞的多一些。

准备工作

  • 自己编写一个接口(我用springboot随便写了一个,需要的可以加我好友) 
  • 新建一个maven工程
  • pom文件引用ApacheJMeter_core.jar     ApacheJMeter_java.jar

写代码前该知道的

1、创建类的时候需要去继承AbstractJavaSamplerClient抽象类或者是实现JavaSamplerClient接口

我在这里只继承AbstractJavaSamplerClient抽象类,需要复写的方法有:

  • public SampleResult runTest(JavaSamplerContext context) {}
  • public void setupTest(JavaSamplerContext context) {}
  • public void teardownTest(JavaSamplerContext context) {}
  • public Arguments getDefaultParameters() {}


2、针对复写方法说明:

  • public Arguments getDefaultParameters() {}

这个方法由Jmeter在进行添加javaRequest时第一个运行,它决定了你要在GUI中默认显示出哪些属性。

  • public void setupTest(JavaSamplerContext context) {}

这个方法相当于loadrunner中的init,我们可以用它来进行一些初始化的动作。

  • public SampleResult runTest(JavaSamplerContext context) {}

这个方法相当于loadrunner中的action,我们的核心测试代码就在这里了。

  • public void teardownTest(JavaSamplerContext context) {}

这个方法相当于loadrunner中的end,收尾的工作可以由它来做。

示例代码

package com.jmeter.demo;

import org.apache.http.HttpEntity;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import org.apache.jmeter.config.Arguments;
import org.apache.jmeter.protocol.java.sampler.AbstractJavaSamplerClient;
import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext;
import org.apache.jmeter.samplers.SampleResult;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @author rongrong
 * jmeter之自定义java请求性能测试
 */
public class JmeterForJavaTest extends AbstractJavaSamplerClient {
    private static final Logger log = LoggerFactory.getLogger(AbstractJavaSamplerClient.class);
    //测试结果
    private SampleResult sr;
    private static String lable = "放大招了奥!";

    /**
     * 初始化性能测试时,每个测试线程
     *
     * @param context
     */
    @Override
    public void setupTest(JavaSamplerContext context) {
        log.debug(getClass().getName() + ": setupTest");
    }

    /**
     * 主要设置传入的参数
     *
     * @return
     */
    @Override
    public Arguments getDefaultParameters() {
        Arguments arguments = new Arguments();
        arguments.addArgument("url", "http://localhost:8888/login?");
        arguments.addArgument("userName", "rongrong");
        arguments.addArgument("passWord", "123456");
        return arguments;
    }


    /**
     * 为性能测试的运行体
     *
     * @param context
     * @return
     */
    @Override
    public SampleResult runTest(JavaSamplerContext context) {
        String url = context.getParameter("url");
        String userName = context.getParameter("userName");
        String passWord = context.getParameter("passWord");
        String sbResultData = null;
        sr = new SampleResult();
        sr.setSampleLabel(lable);
        //记录测试时间及结果
        sr.sampleStart();
        //执行请求
        sbResultData = executRequest(url, userName, passWord, sbResultData);
        sr.setSuccessful(true);
        sr.setResponseCode("200");
        sr.setResponseCodeOK();
        sr.setRequestHeaders("这是个header呀,但是我就没写呀");
        sr.setResponseMessage("这块是自己瞎写的呀,测试是不是该严谨些呢");
        sr.setContentType("application/json 没想到这块我也要皮一下呢");
        //将数据打印到查看结果树当中
        sr.setResponseData(sbResultData, null);
        sr.setDataType(SampleResult.TEXT);
        return sr;
    }

    /**
     * 模拟接口请求
     *
     * @param url
     * @param userName
     * @param passWord
     * @param sbResultData
     * @return
     */
    private String executRequest(String url, String userName, String passWord, String sbResultData) {
        CloseableHttpClient httpClient = null;
        HttpPost httpPost = null;
        try {
            httpClient = HttpClients.createDefault();
            RequestConfig requestConfig = RequestConfig.custom().setSocketTimeout(20000).setConnectTimeout(20000).build();
            httpPost = new HttpPost(url);
            httpPost.setConfig(requestConfig);
            List<NameValuePair> ps = new ArrayList<NameValuePair>();
            Map<String, String> params = new HashMap<String, String>();
            params.put("userName", userName);
            params.put("passWord", passWord);
            for (String pKey : params.keySet()) {
                ps.add(new BasicNameValuePair(pKey, params.get(pKey)));
            }
            httpPost.setEntity(new UrlEncodedFormEntity(ps));
            CloseableHttpResponse response = httpClient.execute(httpPost);
            HttpEntity httpEntity = response.getEntity();
            sbResultData = EntityUtils.toString(httpEntity, "utf-8");
        } catch (ClientProtocolException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                if (httpPost != null) {
                    httpPost.releaseConnection();
                }
                if (httpClient != null) {
                    httpClient.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return sbResultData;
    }

    @Override
    public void teardownTest(JavaSamplerContext context) {
        log.debug(getClass().getName() + ": teardownTest");
    }

}

jmeter运行java代码

  • 将代码打包成jar包
  • 把打包成的jar放在\apache-jmeter-5.1.1\lib\ext路径下
  • 打开jmeter,添加线程组,再添加一个java请求,如下图:

  • 添加查看结果树,运行后结果如下:

 

补充事项
 如果我们的代码在运行时发生异常,就会被打印在doc窗口中

我这里没有发生异常,所以没有数据,当发生异常时就会打印在这里。注意观察,有助于调试代码

 

总结

继承了AbstractJavaSamplerClient后,可以对测试结果,做很多处理,这里仅仅做了一个抛砖引玉,上面的代码只是模拟了HTTP请求,实际意义不大。
但是当我们需要进行一段代码的性能测试的时候,可以通过这样的形式来进行书写,并且在runTest方法中进行调用后,那么就可以测试出这段代码的性能如何了。
 
参考文章:https://www.cnblogs.com/lingfengblogs/p/4269587.html
 
附接口服务启动图:

 

posted @ 2019-06-30 20:19  久曲健  阅读(1589)  评论(0编辑  收藏  举报