在平时用jmeter做测试时,生成报告的模板,不是特别好。大家应该也知道allure报告,页面美观。

先来看效果图,报告首页,如下所示:

报告详情信息,如下所示:

运行run.py文件,运行成功,如下所示:

接下来来看下实现过程。

安装allure

allure是开源的,直接到github上下载即可。就不细说了。需要注意的是,环境变量的配置,allure的bin路径,需要配置到环境变量path中。

jmeter配置

找到bin目录下的 jmeter.properties 配置文件,将如下所示对应配置取消注释,jmeter.save.saveservice.output_format 修改为xml。

# This section helps determine how result data will be saved.
# The commented out values are the defaults. # legitimate values: xml, csv, db. Only xml and csv are currently supported.
jmeter.save.saveservice.output_format=xml # The below properties are true when field should be saved; false otherwise
#
# assertion_results_failure_message only affects CSV output
#jmeter.save.saveservice.assertion_results_failure_message=true
#
# legitimate values: none, first, all
#jmeter.save.saveservice.assertion_results=none
#
jmeter.save.saveservice.data_type=true
jmeter.save.saveservice.label=true
jmeter.save.saveservice.response_code=true
# response_data is not currently supported for CSV output
jmeter.save.saveservice.response_data=true
# Save ResponseData for failed samples
jmeter.save.saveservice.response_data.on_error=true
jmeter.save.saveservice.response_message=true
jmeter.save.saveservice.successful=true
jmeter.save.saveservice.thread_name=true
jmeter.save.saveservice.time=true
jmeter.save.saveservice.subresults=true
jmeter.save.saveservice.assertions=true
jmeter.save.saveservice.latency=true
# Only available with HttpClient4
jmeter.save.saveservice.connect_time=true
jmeter.save.saveservice.samplerData=true
jmeter.save.saveservice.responseHeaders=true
jmeter.save.saveservice.requestHeaders=true
jmeter.save.saveservice.encoding=true
jmeter.save.saveservice.bytes=true
# Only available with HttpClient4
jmeter.save.saveservice.sent_bytes=true
jmeter.save.saveservice.url=true
jmeter.save.saveservice.filename=true
jmeter.save.saveservice.hostname=true
jmeter.save.saveservice.thread_counts=true
jmeter.save.saveservice.sample_count=true
jmeter.save.saveservice.idle_time=true # Timestamp format - this only affects CSV output files
# legitimate values: none, ms, or a format suitable for SimpleDateFormat
jmeter.save.saveservice.timestamp_format=ms
jmeter.save.saveservice.timestamp_format=yyyy/MM/dd HH:mm:ss.SSS

生成jmeter结果文件

使用命令 jmeter -n -t C:\Users\Desktop\auth.jmx -l C:\Users\Desktop\result.xml 即可生成xml文件

安装依赖包

按项目中的 requirements.txt 文件,安装对应的依赖包即可。

文件解析生成allure报告

文件解析

xml文件内容如下:

从上述的内容,我们可以分析得出如下内容:

t 从请求开始到响应结束的时间
ts 表示访问的时刻: date
s 运行的结果
lb 表示标题
rc 返回的响应码
rm 响应信息
tn 线程的名字
assertionResult: 断言信息
responseData/samplerData: 返回数据
queryString: 请求信息

代码实现

利用生成的结果文件生成pytest的参数化数据

    try:
converte_data = xmltodict.parse(result_file, encoding='utf-8')
sample_keys = list(converte_data['testResults'].keys())
result = []
ws_result = []
sample_result = converte_data['testResults']['httpSample'] if isinstance(
converte_data['testResults']['httpSample'],
list) else [converte_data['testResults']['httpSample']]
if 'sample' in sample_keys:
ws_result = converte_data['testResults']['sample'] if isinstance(converte_data['testResults']['sample'],
list) else [
converte_data['testResults']['sample']]
result_data = sample_result + ws_result
for data in result_data:
time = data['@t'] if '@t' in data else ''
date = data['@ts'] if '@ts' in data else ''
status = data['@s'] if '@s' in data else ''
title = data['@lb'] if '@lb' in data else ''
status_code = data['@rc'] if '@rc' in data else ''
status_message = data['@rm'] if '@rm' in data else ''
thread = data['@tn'] if '@tn' in data else ''
assertion = data['assertionResult'] if 'assertionResult' in data else ''
response_data = data['responseData']['#text'] if 'responseData' in data and '#text' in data['responseData'] \
else ''
sampler_data = data['samplerData']['#text'] if 'samplerData' in data and '#text' in data['samplerData'] \
else ''
request_data = data['queryString']['#text'] if 'queryString' in data and '#text' in data[
'queryString'] else ''
request_header = data['requestHeader']['#text'] if 'requestHeader' in data and '#text' in data[
'requestHeader'] else ''
request_url = data['java.net.URL'] if 'java.net.URL' in data else ''
story = '未标记'
assertion_name, assertion_result = None, None
if status == 'false':
assertion_name, assertion_result = get_assertion(assertion) meta_data = (
time, date, status, story, title, status_code, status_message, thread, assertion_name, assertion_result,
response_data
, sampler_data, request_data, request_header, request_url)
result.append(meta_data)
return result
except Exception as e:
print(e)
return [
('time', 'date', 'true', 'story', 'title', 'status_code', 'status_message', 'thread', 'assertion_name',
'assertion_result',
'response_data', 'sampler_data', 'request_data', 'request_header', 'request_url')]

用例详情字段

@allure.step('用例名称:{title}')
def title_step(self, title):
pass @allure.step('请求信息')
def request_step(self, request_url, request_header, request_data, sampler_data):
pass @allure.step('断言信息')
def assert_step(self, assertion_name, assertion_result):
assert False @allure.step('文件信息:{thread}')
def file_step(self, thread):
pass @allure.step('返回信息')
def response_step(self, status_code, status_message, response_data):
pass @allure.step('附件(全部信息)')
def attach_all(self, data):
allure.attach(str(data), name='attach_all_data',
attachment_type=allure.attachment_type.JSON) def base_step(self, time, date, status, title, status_code, status_message, thread, assertion_name,
assertion_result, response_data,
sampler_data, request_data, request_header,
request_url):
data = {'title': title, 'thread': thread, 'request_url': request_url, 'request_header': request_header,
'request_data': request_data, 'sampler_data': sampler_data, 'status_code': status_code,
'response_data': response_data, 'assertion_name': assertion_name, 'assertion_resul': assertion_result}
self.file_step(thread)
self.title_step(title)
self.request_step(request_url, request_header, request_data, sampler_data)
self.response_step(status_code, status_message, response_data)
self.attach_all(data)
if status == 'false':
self.assert_step(assertion_name, assertion_result)
assert False
else:
assert True @allure.title("{title}")
@allure.feature("失败信息")
@pytest.mark.parametrize(
"time,date,status,story,title,status_code,status_message,thread,assertion_name,assertion_result,response_data,sampler_data,request_data,request_header,"
"request_url",
xml_2_data(type=1))
def test_gjw(self, time, date, status, story, title, status_code, status_message, thread, assertion_name,
assertion_result,
response_data, sampler_data, request_data, request_header,
request_url):
# allure.dynamic.story(story)
self.base_step(time, date, status, title, status_code, status_message, thread, assertion_name, assertion_result,
response_data,
sampler_data, request_data, request_header,
request_url)

处理报告转化时间一致

def report_edit(env):
path = os.path.join(Path().get_report_path(), env, 'data')
# 批量更新聚合文件
for file in os.listdir(path):
if '.json' in file and 'categories' not in file:
try:
with open(os.path.join(path, file), 'r') as f:
json_str = json.loads(f.read())
for data in json_str['children'][0]['children']:
name = data['name']
for meta in result:
if name == meta[3]:
data['time']['start'] = int(meta[1])
data['time']['stop'] = int(meta[1]) + int(meta[0])
data['time']['duration'] = int(meta[0])
with open(os.path.join(path, file), 'w') as w:
json.dump(json_str, w, indent=2, sort_keys=True, ensure_ascii=False)
except Exception as e:
print(e)
# 批量更新case文件
cases_path = os.path.join(path, 'test-cases')
for file in os.listdir(cases_path):
if '.json' in file and 'categories' not in file:
try:
with open(os.path.join(cases_path, file), 'r') as f:
json_str = json.loads(f.read())
name = json_str['name']
for meta in result:
if name == meta[3]:
json_str['time']['start'] = int(meta[1])
json_str['time']['stop'] = int(meta[1]) + int(meta[0])
json_str['time']['duration'] = int(meta[0])
with open(os.path.join(cases_path, file), 'w') as w:
json.dump(json_str, w, indent=2, sort_keys=True, ensure_ascii=False)
except Exception as e:
print(e)

上述只是部分代码,完整代码已上传,JmeterAllureReport ,有兴趣的可以再完善。

Jmeter——结合Allure展示测试报告的更多相关文章

  1. pytest+allure展示环境信息

    allure展示环境信息 要将信息添加到Environment小部件,只需在生成报告之前在目录中创建environment.properties(或environment.xml)文件allure-r ...

  2. Pytest测试框架(五):pytest + allure生成测试报告

    Allure 是一款轻量级.支持多语言的开源自动化测试报告生成框架,由Java语言开发,可以集成到 Jenkins. pytest 测试框架支持Allure 报告生成. pytest也可以生成juni ...

  3. pytest(11)-Allure生成测试报告(一)

    Allure是一个开源的测试报告生成框架,提供了测试报告定制化功能,相较于我们之前使用过pytest-html插件生成的html格式的测试报告,通过Allure生成的报告更加规范.清晰.美观. pyt ...

  4. Allure自动化测试报告我是这样用的

    关于自动化测试报告: 之前用过testNG自带的测试报告.优化过reportNG的测试报告.extentreport.Zreport(大飞总原创),这些是我之前都用过的,也是在去年雯姐和我说过Allu ...

  5. Allure自动化测试报告之修改allure测试报告名称

    1.从github获取allure代码 https://github.com/allure-framework/allure2 2.安装gradle,用于打包jar brew install grad ...

  6. python + pytest + allure生成测试报告

    pytest结合allure生成测试报告 环境搭建 要安装java环境,版本要是jdk1.8的,配置好java环境变量,不然输入allure命令会报错,JAVA_HOME环境,自行配置 安装allur ...

  7. pytest+jenkins+allure 生成测试报告发送邮件

    前言第一部分:Pycharm for Gitee1. pycharm安装gitee插件2. gitee关联本地Git快速设置- 如果你知道该怎么操作,直接使用下面的地址简易的命令行入门教程:3. Gi ...

  8. python自动化之使用allure生成测试报告

    Allure测试报告框架帮助你轻松实现"高大上"报告展示.本文通过示例演示如何从0到1集成Allure测试框架.重点展示了如何将Allure集成到已有的自动化测试工程中.以及如何实 ...

  9. Pytest使用pytest-html和allure生成测试报告

    Pytest-html 1.安装命令pip3 install pytest-html,如下图: 执⾏后,会在当前⽬录下⽣成 ⼀个report.html的⽂件,打开后会展示详细的测试报告,执行该命令py ...

  10. Jmeter生成html格式测试报告

    使用jmeter进行性能测试,运行完毕后生成html格式的测试报告,需要进行如下操作: 1.在C:\apache-jmeter-3.0\bin文件夹下的user.properties文本中添加如下信息 ...

随机推荐

  1. vue3中defineComponent 的作用

    vue3中,新增了 defineComponent ,它并没有实现任何的逻辑,只是把接收的 Object 直接返回,它的存在是完全让传入的整个对象获得对应的类型,它的存在就是完全为了服务 TypeSc ...

  2. 在终端启动Python时报错的解决

    最近,在终端启动Python时,报了一个错误: 1 Failed calling sys.__interactivehook__ 2 Traceback (most recent call last) ...

  3. fastapi教程进阶

    一个简单的栗子 from fastapi import FastAPI app = FastAPI() @app.get("/") async def root(): return ...

  4. Winsw将jar包部署为windows服务

    1. 下载Winsw https://github.com/winsw/winsw/releases 下载winsw官网上的xml文件和.exe文件 2. 编辑配置文件 创建一个文件夹demo,将所需 ...

  5. 延申三大问题中的第一个问题处理---原先shell脚本中启动jar文件命令的配置,附加参数等

    经过一系列的试错,最终采用的解决办法如下: 采用的配置文件 附加的启动参数 或者把这些都给统一添加到ConfigMap中

  6. GitLab 之 Git LFS 大文件存储的配置

    转载自:https://cloud.tencent.com/developer/article/1010589 1.Git LFS 介绍 Git 大文件存储(Large File Storage,简称 ...

  7. .NET 反向代理 YARP 自定义配置提供程序(Configuration Providers)

    介绍 基本 Yarp 示例显示从 appsettings.json 加载的代理配置.相反,代理配置可以从您选择的源以编程方式加载.您可以通过提供几个实现 IProxyConfigProvider 和 ...

  8. 改善C#程序的方法-2 使用TryParse

    一 使用TryParse,而不是Parse 除string外的所有基元类型,都有两个将string类型转型为其本身类型的方法:Parse 和 TryParse. 以double类型为例,这两个方法最简 ...

  9. kubernetes Tcp流量可视化

    kubernetes Tcp流量可视化 使用k8spacket和grafana的node graph插件可以查看kubernetes pod的TCP相关信息,如connection.bytes.和du ...

  10. linux 安装/卸载go环境

    linux 安装/卸载go环境(基于centos8) 安装 下载go的安装包 Golang官网下载地址:https://golang.org/dl/ 将安装包解压放到到usr/local中,并解压 c ...