美文网首页
HttpRunner3.X学习笔记(3) -用例文件的confi

HttpRunner3.X学习笔记(3) -用例文件的confi

作者: 是立品啊 | 来源:发表于2020-09-18 11:05 被阅读0次

    在用例的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(必填)

    测试用例的名称,必填项,将显示在执行日志和测试报告中。

    image.png

    base_url(选填)

    这个配置通常在多环境切换中最常用。结合.env文件或者环境变量实现多环境切换

    image.png

    variables(选填)

    全局变量variables(**{}),存放一些公共的变量,可以在整个测试用例里引用。与之对应的是Step中的局部(步骤)变量.with_variables(**{})

    1. 比如公共变量用户名username,而且后面的每一个Step都会用到这个参数,那么username就可以放在config的公共变量里。
    2. Step里的变量优先级是比config里的变量要高的,如果有2个同名的变量的话,那么引用的时候,是优先引用步骤里的变量的。
    3. 写在全局的变量可以通过测试类对象.test_start()param参数传递覆盖,所以如果需要自定义覆盖参数,则需要把参数提到全局变量部分。

    verify(选填)

    用来决定是否验证服务器TLS证书的开关。
    通常设置为False,当请求https请求时,就会跳过验证。如果你运行时候发现抛错SSLError,可以检查一下是不是verify没传,或者设置了True

    export(选填)

    需要导出的变量,主要是用于不同caseStep之间参数的传递。还是以上面的代码为例:

    image.png
    1. 在第一个Step中,.extract() 提取了"body.data.reqNo"给变量"reqNo",提取了"body.data.outOrderNo"给变量"outOrderNo"
    1. config中配置export(*["reqNo","outOrderNo"])这个变量。export中变量名应该和第一步骤的变量名一致。(其实这边所有的Step都是RunRequest型的,前面Step中提取的变量无须export也能被后面的Step引用,这个export主要是用于此用例还需要被其他的用例引用的情况下(RunTestCase)需要手动在该用例下export一下,方便后续使用)

    2. 在第二个Step中,引用变量"reqNo","outOrderNo",需要加$

    相关文章

      网友评论

          本文标题:HttpRunner3.X学习笔记(3) -用例文件的confi

          本文链接:https://www.haomeiwen.com/subject/halqyktx.html