51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2740|回复: 5
打印 上一主题 下一主题

如何让 unittest 的报告中错误输出有日志输出?

[复制链接]
  • TA的每日心情
    无聊
    2 小时前
  • 签到天数: 528 天

    连续签到: 1 天

    [LV.9]测试副司令

    跳转到指定楼层
    #
    发表于 2020-12-17 10:08:32 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
    1测试积点

    使用logger封装logging,设置输出流为sys.stdout.
    当运行unittest suite并生成report时,logger产生的日志会输出在下面的console中,但是并不输出在report中。

    首先声明需求,因为公司希望我在报告中错误信息简化为一些其他人能看懂业务就能知道的文字,而不是traceback。

    我的想法是两份报告,一份给开发,输出的报告中的错误信息是业务相关的错误
    一份给测开,是含有traceback的错误

    测开的不用改
    但是如何将报告中输出的错误翻译成业务相关呢?

    因此,我需要将logger.error中的信息输出在报告中,但是不管是sys.stdout还是sys.stderr.都是在控制台输出,而report中的输出流其实是io.StringIO,如何让report也能输出部分日志呢?

    这是报告中关于输出流的代码

    请教一下怎么改,如果需要详细的其他信息,请于评论处问我




    附件: 您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    3 小时前
  • 签到天数: 992 天

    连续签到: 1 天

    [LV.10]测试总司令

    5#
    发表于 2020-12-18 15:45:31 | 只看该作者
    https://testerhome.com/topics/26885   参考下这篇文章
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    2024-10-22 14:23
  • 签到天数: 1007 天

    连续签到: 1 天

    [LV.10]测试总司令

    4#
    发表于 2020-12-18 13:12:10 | 只看该作者
    pytest+allure,应该可以解决。
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    2 小时前
  • 签到天数: 1517 天

    连续签到: 1 天

    [LV.Master]测试大本营

    3#
    发表于 2020-12-18 10:59:09 | 只看该作者
    打印日志的时候写两份
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    3 小时前
  • 签到天数: 1802 天

    连续签到: 1 天

    [LV.Master]测试大本营

    2#
    发表于 2020-12-18 10:18:09 | 只看该作者
    回复

    使用道具 举报

  • TA的每日心情
    擦汗
    2024-9-30 15:02
  • 签到天数: 751 天

    连续签到: 2 天

    [LV.10]测试总司令

    1#
    发表于 2020-12-18 09:57:27 | 只看该作者
    可以使用pytest+allure ,在allure报告里面会将assert失败得msg进行显示
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-18 12:34 , Processed in 0.070370 second(s), 23 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表