以前不了解httpRunner实现机制很不喜欢它,认为就是简单的接口录制与回放,只适合处理简单的接口逻辑。随着最近对httpRunner再次解读,发现它也能实现复杂接口的自动化用例,而且对于场景类的实现很快(不涉及特殊处理的,只要做好参数管理)。对于特殊处理的接口,针对特殊部分可以通过封装方法实现调用,如接口的加密,cookie失效等等。
环境准备
涉及多个项目且项目接口实现的机制差距大,建议创建多个自动化项目且环境配置虚拟化以便解决包之间的冲突问题。
创建虚拟化环境步骤
1 创建虚拟环境:C:\py_workspace>python -m venv /venv 2 进入\venv\Scripts目录,激活虚拟环境:activate 3 返回上2级目录 4 安装虚拟安装包:pip install httprunner==3.1.6 (hrun3 低版本支持创建项目,高版本不支持) 5 查看httprunner版本:httprunner -V 6 查看帮助文档: httprunner -h 7 创建项目:httprunner startproject baseProductView Code
录制接口
Charles或fiddler或浏览器抓包,过滤需要使用的host接口,另存为.har文件,把录制的接口放置在创建的项目的har目录下。
生成用例
查看用例生成命令:har2case -h
用例生成命令:har2case xxx.har 默认生成py文件,也可以指定生成yml文件-->har2case xxx.har -2y转换用例格式
查看用例格式生成命令:hmake -h
把默认用例格式转换为pytest默认格式:hmake testcases
备注:转换过程中可能出现click依赖包异常(black是python中用来格式化代码等库,但是本地安装完成后,遇到了这个报错,需要重新安装低版本),具体见截图
解决:pip install click==8.0.2
设置变量
全局变量:定义在类变量config1 config = Config("testcase description").verify(False).variables( 2 **{ 3 "uuid": "VJ7N5NBw", ###15261561010 4 'cookies': "${get_online_cookie()}" 5 } 6 )
base_url 特殊的全局变量:
主域名设置,一个文件设置一个,引用方式:请求方法对应的URL参数,只要写路径即可
局部变量:
1、定义在每个step里 .with_variables({'courseId':'1000'}) 2、引用: 每个请求对应的请求参数 .with_params(**{"time": "1670292083257",'course': '$courseId'}
提取响应字段语法
提取字段语法:数据来源父级,如body、headers、cookies
.extract().with_jmespath('body.result.uuid', 'uid') .extract().with_jmespath('headers.origin', 'origin') .extract().with_jmespath('cookies.“set-cookie“', 'cookie')
引用变量:
1、不涉及边界的变量引用Step( RunRequest("/gateway/xxx/userInfo") .get( "/gateway/xxx/userInfo" ) .with_params(**{"time": "1670292083257"}) .with_headers( **{ "Cookie": "$cookies" } )
2、涉及边界变量引用:
Step( RunRequest("/gateway/xxx/userInfo") .get( "/gateway/xxx/userInfo" ) .with_params(**{"time": "1670292083257"}) .with_headers( **{ "Cookie": "${cookies}testor" } )
3、动态引入函数变量
config = Config("testcase description")\ .verify(False)\ .variables( **{ "uuid": "V...w", 'cookies': "${get_online_cookie()}" } )
hook机制
HttpRunner中,我们可以通过hook机制来实现 setUp() 和 tearDown(),其对应的实现函数可以封装在其他模块
setup_hook:主要用于处理接口的前置的准备工作 teardown_hook:主要用于后置清理工作用例分层
用例分层需要考虑用例的调用与参数调用。用例调用通过RunTestCase类的call方法实现,模块间的参数可以通过export实现传递。特别需关注call调用的用例文件名不要含有test,不然会被当作测试文件执。
用例分层demo截图
导出变量实现:Config()配置 .export("",)
引用上面导出的变量
用例的参数化
先在需要参数化测试类名下定义参数化字段,这样整个文件都可使用定义的参数。HttpRunner3.x支持3种参数化规则:
1、自己定义的变量数组
2、debugtalk.py函数返回值中
3、外部文件中
参数化是固定格式,不能修改否则报错。一般自动化用例涉及参数化的使用很少,如果需要参数化会把整个信息配置化便于遍历和断言。
1 @pytest.mark.parametrize( 2 "param", 3 Parameters( 4 { 5 "user_agent": ["iOS/10.1", "iOS/10.2"], ##自定义参数 6 "username-password": "${parameterize(request_methods/account.csv)}",##外部文件 7 "app_version": "${get_app_version()}",##debugtalk.py 定义函数 8 } 9 ), 10 ) 11 def test_start(self, param): 12 super().test_start(param)View Code
报告
pytest自带报告:hrun testcases/origin_test.py -s --html=origin.html
allure报告:hrun testcases/origin_test.py --alluredir=allurereports/
打开报告:open report文件名
性能
locust是python语言开发的一款的开源的的性能测试框架,他比jmeter更加的轻量级,主要是通过协程(gevent)的方式去实现并发,通过协程的方式可以大幅提高单机的并发能力,同时避免系统级的资源调度。locust具有开源性、分布式、支持高并发,支持webUI的操作方式。
命令:locusts -f testcases/online_origin_test.py,执行命令会唤起locusts服务,通过web访问地址:http://localhost:8089/(请用Chrome浏览器)
标签:origin,cookies,httpRunner,py,汇总,接口,用例,参数,使用 From: https://www.cnblogs.com/margret/p/16956100.html