首页 > 解决方案 > Jmeter 仅记录带有 JSR223 侦听器的 HTTPSampler

问题描述

尝试在测试计划级别设置 JSR223 侦听器,以便侦听所有线程组。我想要实现的是它只记录每个 HTTP 请求的方法(GET、POST、HEAD、OPTIONS、PUT、DELETE 和 TRACE)并打印每个方法、URL、响应代码、值和响应数据。

环顾四周,发现了一些左右和中间的片段,并提出了这个:

try{
    if (sampler.getUrl().toString().contains("http")){
    log.warn('Method: ' + sampler.getMethod() + ' URL: ' + sampler.getUrl().toString());
    sampler.getArguments().each {arg ->
    log.warn('CODE: ' + prev.getResponseCode() + ' Value: ' + arg.getStringValue())
    }
    log.warn('CODE: ' + prev.getResponseCode() + ' ResponseData: ' + prev.getResponseDataAsString());
    }else{
    log.warn('Not a HTTPRequest')   
    }
}
catch (Throwable ex) 
{
    log.warn('Something went wrong', ex);
    throw ex;
}

在此处输入图像描述

我根据需要在我的日志查看器中获得结果。

我面临的挑战是,如果任何其他采样器类型处于活动状态,它会记录错误,因为该采样器不是 HTTP 请求而是虚拟采样器,因此它无法返回请求的值。

在此处输入图像描述

groovy.lang.MissingMethodException:没有方法签名:kg.apc.jmeter.samplers.DummySampler.getUrl()

现在我的示例仅显示线程组中的两个采样器,但假设有 100 个不同的采样器我需要更改我的“if”语句以不检查采样器参数,而是检查采样器类型(HTTPRequest),但很好老谷歌的回报不多。那么,是否有可能有一个 if 语句来检查采样器类型,该语法是什么?

if (sampler==HTTPRequest)???

标签: jmeterlog4jhttprequestlog4j2jsr223

解决方案


您可以使用sampler.getClass()并比较它来检查 HTTP 请求是否:

if("HTTPSamplerProxy".equals(sampler.getClass().getSimpleName())) {

您可以使用日志检查类名:

log.info(sampler.getClass().getSimpleName());

推荐阅读