HttpRunner测试用例的基本结构
-
每个YAML/JSON文件对应一个测试用例(testcase)
-
每个测试用例为一个list of dict结构,其中可能包含全局配置项(config)和若干个测试步骤(test)
-
config为全局配置项,作用域为整个测试用例
-
test对应单个测试步骤,作用域仅限于本身
- 变量作用域以config为主,config如果没有设置,就使用test中设置的变量
一、基础栗子
get请求举例说明
以打开新梦想首页为例
host:http://www.hnxmxit.com
url:/
请求方式:get
使用httprunner进行接口测试步骤:
1、打开pycharm,新建一个httprunner项目,新建一个test_demo.yaml文件,内容如下:
#不带参数的get请求
- config:
name: 验证能否打开新梦想主页
base_url: http://www.hnxmxit.com
- test:
name: open hnxmxit mainpage api
request:
url: /
method: GET
validate:
- eq: [‘status_code‘,200]
2、在pycharm,终端窗口执行如下命令 :hrun yaml文件名
3、执行成功后,会自动生成一个报告,查看报告:
二、模拟带参数的get请求
#模拟带参数的get请求
- config:
name: ‘验证能否获取token值‘
base_url: ‘https://api.weixin.qq.com‘
- test:
name: ‘get access token‘
request:
url: ‘/cgi-bin/token‘
method: GET
params:
grant_type: ‘client_credential‘
appid: ‘wx0ebbdf4a197121‘
secret: ‘b876eeb2af99cc6623995201168e702f‘
validate:
- eq: [‘status_code‘,200]
- eq: [content.expires_in,7200]
三、模拟请求头
#模拟请求头
- config:
name: ‘验证百度搜索是否正确‘
base_url: ‘https://www.baidu.com‘
- test:
name: ‘百度搜索请求‘
request:
url: ‘/s‘
method: GET
headers:
User-Agent: ‘Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.90 Mobile Safari/537.36‘
Accept: ‘text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9‘
Accept-Encoding: ‘gzip, deflate, br‘
Accept-Language: ‘zh-CN,zh;q=0.9‘
params:
wd: ‘newdream01‘
validate:
- eq: [‘status_code‘,200]
四、模拟POST请求
#模拟post请求
- config:
name: ‘验证微信开发平台中,用户标签管理修改标签接口能否成功执行‘
base_url: ‘https://api.weixin.qq.com‘
- test:
name: ‘修改标签接口‘
request:
url: ‘/cgi-bin/tags/update‘
method: POST
headers:
Content-Type: ‘application/json‘
params:
access_token: ‘46_oMQuTV1IE2aTFeGKMHXHSNseS63bwEMxSyU7MrVYvOqXF1y5hnQvgopuZjBSqKBIGVrCaTlQEAeAAf-EtaGWahHTeEzFU-cNZ3_EgT7Xlbwx7rOFW9OTusypC9lIthaIn0Ooq60XJ09wrFYlJMIgAHAVYU‘
json: { "tag" : { "id" : 101, "name" : "newdream123" } }
validate:
- eq: [‘status_code‘,200]
- eq: [content.errcode,0]
五、变量作用域:变量作用域以config为主,config如果没有设置,就使用test中设置的变量
#变量作用域:变量作用域以config为主,config如果没有设置,就使用test中设置的变量
- config:
name: ‘验证能否获取token值‘
base_url: ‘https://api.weixin.qq.com‘
variables:
- grant_type: ‘client_credential‘
- appid: ‘wx0ebbdf4a197121‘
- test:
name: ‘get access token‘
variables: #变量作用域以config为主,config如果没有设置,就使用test中设置的变量
- grant_type: ‘client_credential‘
- appid: ‘wx0ebbdf4a197121‘
request:
url: ‘/cgi-bin/token‘
method: GET
params:
grant_type: $grant_type
appid: $appid
secret: ‘b876eeb2af99cc6623995201168e702f‘
validate:
- eq: [‘status_code‘,200]
- eq: [content.expires_in,7200]