在用例的config中,我们可以配置测试用例级别的一些设置,比如base_url
、验证、变量、导出。
from httprunner import HttpRunner, Config, Step, RunRequest
from utils.FakerData import *
from api.dlvopenapi import unified_order, order_query
from utils.SigleData import FakerSingleData
class TestCaseDlvOpenApiSuccess(HttpRunner):
config = (
Config("发放成功的测试案例")
.variables(
**{
"appId": "200803014515363414",
"accountName": get_name(),
"idCard": "420624199109037552",
"amount": "0.02",
"signType":"rsa2",
"version":"1.0",
"accountNo": "6225380092315252",
"phone":get_phone(),
"serviceCompanyId": "10000032",
"key": "MIICeAIBADANBgkqhkiG9w0BAQEFAASCAmIwggJeAgEAAoGBAOI4fc5POr0cZmyyGuw"
}
)
.base_url("http://192.168.1.92:11958")
.verify(False)
.export( *["reqNo", "outOrderNo"])
)
teststeps = [
Step(
RunRequest("发放收单成功").
setup_hook('${setup_request($request,$key)}')
.with_variables(
**{
"attach": "附件",
"bank": "ICBC1",
"batchNo": "20200801",
"depositBank": "工商",
"extInfo": "API001-商户004-攻城狮",
"foreignNationality": "CN",
"memo": "API_AUTO1",
"outOrderNo": get_outOrderNo(),
"personalIncomeTax": "0",
"phone": "$phone",
"postId": "10468",
"postName": "tester",
"serviceFee": "0",
"serviceType": "10002",
"shouldAmount": "0",
"totalFee": "0",
"nonce": get_nonce(),
"timestamp": get_current_time()}
)
.post(unified_order.UnifiedOrderApi.path)
.with_json(unified_order.UnifiedOrderApi.json)
.teardown_hook('${polling_assert(state_,30)}')
.extract()
.with_jmespath("body.data.reqNo", "reqNo")
.with_jmespath("body.data.outOrderNo", "outOrderNo")
.validate()
.assert_equal("status_code", 200)
.assert_equal("body.code", "0000")
.assert_equal("body.msg", "处理成功")
.assert_equal('${db_filed_states_with_parm(state_)}', 30)
.assert_equal('${db_filed_states_with_parm(balance_state_)}', 39)
.assert_equal('${db_filed_states_with_parm(channel_balance_state_)}', 39)
),
Step(
RunRequest("发放订单查询")
.setup_hook('${setup_request($request,$key)}')
.with_variables(**{
"method": "ayg.salary.payQuery",
"nonce": get_nonce(),
"timestamp": get_current_time(),
})
.post(order_query.OrderQueryApi.path)
.with_json(order_query.OrderQueryApi.json)
.validate()
.assert_equal("status_code", 200)
.assert_equal("body.code", "0000")
.assert_equal("body.data.code", "30")
.assert_equal("body.data.msg", "支付成功")
)
]
if __name__ == "__main__":
TestCaseDlvOpenApiSuccess().test_start()
name(必填)
测试用例的名称,必填项,将显示在执行日志和测试报告中。
base_url(选填)
这个配置通常在多环境切换中最常用。结合.env
文件或者环境变量
实现多环境切换
variables(选填)
全局变量variables(**{})
,存放一些公共的变量,可以在整个测试用例里引用。与之对应的是Step
中的局部(步骤)变量.with_variables(**{})
。
- 比如公共变量用户名
username
,而且后面的每一个Step
都会用到这个参数,那么username
就可以放在config
的公共变量里。 -
Step
里的变量优先级是比config
里的变量要高的,如果有2个同名的变量的话,那么引用的时候,是优先引用步骤里的变量的。 - 写在全局的变量可以通过
测试类对象.test_start()
的param
参数传递覆盖,所以如果需要自定义覆盖参数,则需要把参数提到全局变量部分。
verify(选填)
用来决定是否验证服务器TLS
证书的开关。
通常设置为False
,当请求https
请求时,就会跳过验证。如果你运行时候发现抛错SSLError
,可以检查一下是不是verify
没传,或者设置了True
。
export(选填)
需要导出的变量,主要是用于不同case
的Step
之间参数的传递。还是以上面的代码为例:
- 在第一个
Step
中,.extract()
提取了"body.data.reqNo"
给变量"reqNo"
,提取了"body.data.outOrderNo"
给变量"outOrderNo"
。
在
config
中配置export(*["reqNo","outOrderNo"])
这个变量。export中变量名应该和第一步骤的变量名一致。(其实这边所有的Step
都是RunRequest
型的,前面Step
中提取的变量无须export
也能被后面的Step
引用,这个export
主要是用于此用例还需要被其他的用例引用的情况下(RunTestCase
)需要手动在该用例下export
一下,方便后续使用)在第二个
Step
中,引用变量"reqNo","outOrderNo"
,需要加$