httprunner 2.x学习18 - 报告validate显示LazyString($msg)问题解决

前言

使用 httprunner 2.x版本,validate校验的时候引用变量,在测试报告会显示LazyString($msg)。

问题描述

httprunner 版本是2.5.7
demo.yml文件用例先定义变量,在validate引用变量

config:
    name: demo case
    base_url: http://192.168.1.0:8000
    variables:
        msg: 成功success!

teststeps:
-   name: demo
    request:
        url: /api/test/demo
        method: GET
    validate:
    - eq: [body.code, 0]
    - eq: [body.msg, $msg]

执行后生成测试报告

可以在github上找到解决办法https://github.com/httprunner/httprunner/issues/693
在模板搜索{{validator.expect | e}},将其修改为{{validator.expect_value | e}}就可以了

这个问题很多用户都有提到https://github.com/httprunner/httprunner/issues/892,但是作者给的答复是让升级到3.x,言外之意是不想解决这个问题了。

问题分析

先找到validator.py中validator_dict部分

  • comparator 是校验方式
  • check 是检查点
  • check_value 是实际结果
  • expect 期望值
  • expect_value 期望的实际值
validator_dict = {
                "comparator": comparator,
                "check": check_item,
                "check_value": check_value,
                "expect": expect_item,
                "expect_value": expect_value
            }

不用命令行执行,用httprunner提供的API执行用例

from httprunner.api import HttpRunner
runner = HttpRunner()
summary = runner.run('demo.yml')
print(summary)

运行结果找到validators

'validators': 
    {'validate_extractor': [
        {'comparator': 'equals', 'check': 'body.code', 'check_value': 0, 'expect': 0, 'expect_value': 0, 'check_result': 'pass'}, 
        {'comparator': 'equals', 'check': 'body.msg', 'check_value': '成功success!', 'expect': LazyString($msg), 'expect_value': '成功success!', 'check_result': 'pass'}
]}

因为expect_value是实际得到的结果值,所以在模板里面{{validator.expect | e}},将其修改为{{validator.expect_value | e}}就可以,这种方法只能解决测试报告的显示问题。

如果我们不需要html的测试报告,只需得到summary结果,summary结果在转json的时候,会出现异常:Object of type 'LazyString' is not JSON serializable

from httprunner.api import HttpRunner
runner = HttpRunner()
summary = runner.run('demo.yml')
print(summary)
import json
print(json.dumps(summary))

因为LazyString 是自定义的一个类,无法解析json,关于自定义类解析json的问题在前面一篇有讲解https://www.cnblogs.com/yoyoketang/p/15588036.html

猴子补丁解决 LazyString

出现这个问题的最根本问题在于 LazyString 类,找到parser.py中的 LazyString 类

class LazyString(object):

    def __repr__(self):
       return "LazyString({})".format(self.raw_string)

__repr__方法返回的内容就是我们所看到的LazyString($msg), 是这个类的实例化对象打印内容。

于是可以用猴子补丁解决

from httprunner.api import HttpRunner
from httprunner.parser import LazyString
from httprunner.report import gen_html_report
import json


def new__repr__(self):
    return "{}".format(self.raw_string)
LazyString.__repr__ = new__repr__

runner = HttpRunner()
summary = runner.run('demo.yml')
gen_html_report(summary=summary)

生成报告后显示效果

summary转json,需定义解析LazyString类的方法

from httprunner.api import HttpRunner
from httprunner.parser import LazyString
from httprunner.report import gen_html_report
import json
from json import JSONEncoder

def new__repr__(self):
    return "{}".format(self.raw_string)
LazyString.__repr__ = new__repr__

runner = HttpRunner()
summary = runner.run('demo.yml')
# gen_html_report(summary=summary)


def new_default(self, obj):
    if isinstance(obj, LazyString):
        return str(obj)
    else:
        return json.JSONEncoder.default(self, obj)

JSONEncoder.default = new_default
print(json.dumps(summary, indent=4))
posted @   上海-悠悠  阅读(330)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2021-05-12 面试题-python3 查找字符串数组中的最长公共前缀
2020-05-12 Cypress web自动化14-window窗口属性
2020-05-12 Cypress web自动化13-viewport设置不同分辨率,适配不同设备,手机型号
2020-05-12 Cypress web自动化12-父子元素定位
2020-05-12 Cypress web自动化11-定位元素(Querying)
2020-05-12 Cypress web自动化10-Navigation 导航功能(go,reload,visit)
2020-05-12 Cypress web自动化9-聚焦元素focused,截图screenshot使用
点击右上角即可分享
微信分享提示