码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • pytest实现日志按用例输出到指定文件中


    场景

    执行自动化用例时,希望日志按用例生成一个文件,并且按用例所在文件生成目录,用例失败时便于查看日志记录

    实现方式

    • pytest.ini文件
      在pytest.ini配置文件中设置配置项(定义日志输出级别和格式)
    log_cli=true
    log_cli_level = DEBUG
    log_file_date_format = %Y-%m-%d %H:%M:%S
    log_file_format = %(asctime)s %(filename)s:%(funcName)s:%(lineno)d  %(levelname)s:%(message)s
    
    • 1
    • 2
    • 3
    • 4
    • conftest.py文件
      设置日志文件路径
    import logging
    
    @pytest.hookimpl(hookwrapper=True, tryfirst=True)
    def pytest_runtest_setup(item):   #pytest_runtest_setup是pytest中hook函数,用例执行前都会执行
        file = os.path.basename(item.path) # 获取case所在文件
        logging.info(file)
        config = item.config
        logging_plugin = config.pluginmanager.get_plugin("logging-plugin") #获取logging-plugin,在_pytest/logging.py文件中可以看到此plugin的实现
        full_fname = os.path.join("logs/", file, item._request.node.name + '.log')  #日志文件路径
        logging_plugin.set_log_path(full_fname) #设置日志路径
        yield
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • test_case.py 测试文件
      如下所示编写测试用例, 会在logs文件下生成目录"test_case.py", 并且此目录下会有执行的两个用例的日志文件
    import logging
    test_data = [{"id": "11111"}, {"id": "2222"}]
    
    @pytest.mark.parametrize("data", test_data,ids=["test1", "test2"])
    class TestCase:
        def test_case(self,data):
            logging.inf("test info")
            pass
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
  • 相关阅读:
    C语言解题——指针解析(牛客网题目)
    Java异常的处理(超详细)
    基于MATLAB开发AUTOSAR软件应用层模块-part11.AUTOSAR Dictionary-2 mapping
    UDP单播和组播通讯之C#设计笔记(十四)
    Android Jetpack Compose之确定重组范围并优化重组
    第四十五篇,STL标准模板库常见算法
    Docker安装canal、mysql进行简单测试与实现redis和mysql缓存一致性
    【ESP8266点焊机】基于 ESP8266 for Arduino
    用CSS+SVG做一个优雅的环形进度条
    差分+差分矩阵(更适合新手宝宝体质)
  • 原文地址:https://blog.csdn.net/z917185537/article/details/125560040
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号