httprunner学习21-正则表达式提取(extract)与校验(validate)

Posted yoyoketang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了httprunner学习21-正则表达式提取(extract)与校验(validate)相关的知识,希望对你有一定的参考价值。

前言

有些接口返回的并不是json格式的内容,返回的是html或者xml格式的内容,这种就不能用前面的 content.的方法去提取了。
httprunner 支持正则表达式提取(extract)参数,也支持正则表达式校验(validate)

返回html

比如我请求博客园的首页https://www.cnblogs.com/yoyoketang/,返回的是应该html格式的内容

技术图片

接下来我要提取html里面的 <title>上海-悠悠 - 博客园</title> 中间的文字 上海-悠悠 - 博客园

正则提取参数(extract)

正则提取语法 ‘<title>(.+?)</title>‘, 提取出来给变量title,用例保存为 test_blog_yoyo.yml

# # 上海悠悠,QQ交流群:750815713
- config:
    name: test demo

- test:
    name: test demo case1
    request:
        url: https://www.cnblogs.com/yoyoketang/
        method: GET
        headers:
            User-Agent: Fiddler
            Content-Type: application/json
        verify: false
    extract:
        - title: '<title>(.+?)</title>'
    validate:
        - eq: [status_code, 200]

用debug模式运行

hrun test_blog_yoyo.yml --log-level debug

技术图片

用 debug 模式可以看到参数提取成功了,后面如果用例有用到这个参数,可以用 $title 引用

正则表达式校验(validate)

对返回的html内容,需要校验结果。之前json格式是通过 content. 的方式去提取,正则表达式提取直接写正则语法就可以了。
用例保存为 test_blog_yoyo.yml

# # 上海悠悠,QQ交流群:750815713
- config:
    name: test demo

- test:
    name: test demo case1
    request:
        url: https://www.cnblogs.com/yoyoketang/
        method: GET
        headers:
            User-Agent: Fiddler
            Content-Type: application/json
        verify: false
    extract:
        - title: '<title>(.+?)</title>'
    validate:
        - eq: [status_code, 200]
        - eq: ['<title>(.+?)</title>', 上海-悠悠 - 博客园]

运行用例就可以看到校验成功了,如果有多个地方需要校验,那就校验多次。

以上是关于httprunner学习21-正则表达式提取(extract)与校验(validate)的主要内容,如果未能解决你的问题,请参考以下文章

03-Httprunner-JMESPath提取返回结果

如何从正则表达式中提取多个值?

httprunner学习7-extract提取content返回对象

正则表达式 - 从字符串中提取电话号码

httprunner 3.x学习16 - 断言使用正则匹配(assert_regex_match)

httprunner 2.x学习14-jsonpath提取(解决:ResponseObject does not have attribute: parsed_body)