前言:

之前同事在跑脚本的时候报错了,发现没法把需要的log信息打印出来,我这边定位问题比较麻烦,所以增加了log的打印。这个问题之前已经处理过了,本来以为是小问题,结果今天又要用到这个小技巧的时候居然想不起来了,还得去翻代码(忘性越来越大了( ̄_ ̄|||)想想还是决定把它记录下来,并且总结一下相关知识点。

需要解决的问题:

  1. 代码里添加的logging模块的报错信息不打印
  2. 没法打印pytest的报错信息
  3. 某个功能添加了try...except去捕获异常,打印了自定义的报错信息,捕获异常之后让用例fail,并打印原有的报错信息

处理方法:

一、 使用pytest_runtest_makereport方法打印 pytest的故障信息和用例执行结果

  1. 添加conftest.py文件
  2. 写pytest_runtest_makereport方法
import os
import pytest
import logging @pytest.hookimpl(hookwrapper=True, tryfirst=True)
def pytest_runtest_makereport(item, call):
out = yield
res = out.get_result()
print(res)
if res.when == "call":
logging.info(f"item:{item}")
logging.info(f"异常:{call.excinfo}")
logging.info(f"故障表示:{res.longrepr}")
logging.info(f"测试结果:{res.outcome}")
logging.info(f"用例耗时:{res.duration}")
logging.info("**************************************")

相关知识点:

  1. pytest_runtest_makereport(item, call)是pytest带有的钩子函数

    测试用例的执行结果会自动跳到这个函数,在这个函数下可以编辑代码进行一些操作

    item为用例对象

    call为用例的测试步骤(pytest的执行流程为 setup -> call ->teardown)
  2. res.longrepr 返回的是pytest的报错信息,通过打印这个值,可以像在控制台一样获取报错的文件行号等信息

二、 添加log文件,使得报错信息打印在本地log文件中

  1. conftest.py文件中写pytest_configure方法,设置log文件路径
  2. pytest.ini文件中 设置log的级别、格式等信息
# conftest.py
def pytest_configure(config):
config.option.log_file = os.path.join(config.rootdir, 'log', 'log.log')

相关知识点:

  1. config.rootdir 为项目的根目录
# pytest.ini
[pytest]
log_cli = 1
log_cli_level = INFO
log_cli_format = %(asctime)s [%(levelname)s] %(message)s (%(filename)s:%(lineno)s)
log_cli_date_format = %Y-%m-%d %H:%M:%S
log_file_level = INFO
log_file_format = %(asctime)s [%(levelname)s] %(message)s (%(filename)s:%(lineno)s)
log_file_date_format = %Y-%m-%d %H:%M:%S

相关知识点:

  1. log_cli = 1 输出日志到控制台
  2. log_cli_level = INFO 设置控制台日志级别,注意:这里设置之后,脚本文件里设置的导入logging模块, logging.basicConfig(level=logging.DEBUG)设置的日志级别就不起作用了
  3. log_cli_format 设置控制台日志格式
  4. log_cli_date_format 设置控制台输出的时间格式
  5. log_file_format 设置输出到log文件的日志格式
  6. log_file_date_format 设置输出到log文件的时间格式

三、 在脚本文件中try...except捕获错误,打印需要的信息后,再把这个错误暴露出来,让这条用例failed

  1. 如果不try...except的话,pytest返回的报错信息为代码的错误信息,但是没法显示出给出想要的提示信息

  2. 通过try...except之后,代码就不会报错,错误就会被隐藏,所以必须让pytest报错,并且把原先代码的错误信息显示出来

# 这部分是我自己的脚本代码,就简单举个例子

def mycode:
a = 3
b = [1,2]
try:
out = b[a]
except IndexError as e: # 捕获异常,并把报错信息存在 e 中
loggging.error(f"列表b的长度不够,需要先把b的长度扩展到{a}个元素") # 打印自己想要的提示信息
pytest.fail(str(e)) # 再把这个报错暴露出来,打印捕获到的报错信息

pytest框架增加log打印(包括pytest的执行结果、自定义的log信息)的更多相关文章

  1. 『德不孤』Pytest框架 — 3、Pytest的基础说明

    目录 1.Pytest参数介绍 2.Pytest框架用例命名规则 3.Pytest Exit Code说明 4.pytest.ini全局配置文件 5.Pytest执行测试用例的顺序 1.Pytest参 ...

  2. android-----JNI中的log打印

    1. 导入log头文件 在你使用的 .c/ .cpp 文件中 导入 log.h 头文件 #include<android/log.h> 2.在Android.mk 中 加上 LOCAL_L ...

  3. android-----JNI中的log打印【转】

    本文转载自:http://blog.csdn.net/zengraoli/article/details/11644815 1. 导入log头文件 在你使用的 .c/ .cpp 文件中 导入 log. ...

  4. pytest框架之命令行参数1

    前言 pytest是一款强大的python自动化测试工具,可以胜任各种类型或者级别的软件测试工作.pytest提供了丰富的功能,包括assert重写,第三方插件,以及其他测试工具无法比拟的fixtur ...

  5. pytest框架之fixture详细使用

    本人之前写了一套基于unnitest框架的UI自动化框架,但是发现了pytest框架之后觉得unnitest太low,现在重头开始学pytest框架,一边学习一边记录,和大家分享,话不多说,那就先从p ...

  6. pycharm中脚本执行的3种模式(unittest框架、pytest框架、普通模式)

    背景知识,某次使用HTMLTestRunner的时候,发现一直都无法导出报告,后来查询资料发现了一些坑,现在整理一下来龙去脉. 一:pycharm默认的是pytest框架去执行unittest框架的测 ...

  7. Appium 并发多进程基于 Pytest框架

    前言: 之前通过重写unittest的初始化方法加入设备参数进行并发,实现了基于unittest的appium多设备并发,但是考虑到unittest的框架实在过于简陋,也不方便后期的Jenkins的持 ...

  8. 【Pytest01】全网最全最新的Pytest框架快速入门

    一.Pytest简介pytest是一个非常成熟的全功能的Python测试框架,主要有一下几个特点:1.简单灵活,容易上手,支持参数化2.能够支持简单的单元测试和复杂的功能测试,还可以用来做seleni ...

  9. python之pytest框架实现

    一.pytest测试框架简介: pytest是一个非常成熟的全功能的Python测试框架,主要有以下几个特点: 简单灵活,容易上手 支持参数化 能够支持简单的单元测试和复杂的功能测试,还可以用来做se ...

  10. Pytest测试框架(一):pytest安装及用例执行

    PyTest是基于Python的开源测试框架,语法简单易用,有大量的插件,功能非常多.自动检测测试用例,支持参数化,跳过特定用例,失败重试等功能. 安装 pip install -U pytest  ...

随机推荐

  1. C语言指针常见问题

    我们在学C语言时,指针是我们最头疼的问题之一,针对C语言指针,博主根据自己的实际学到的知识以及开发经验,总结了以下使用C语言指针时常见问题. 指针 指针做函数参数 学习函数的时候,讲了函数的参数都是值 ...

  2. python之路27 单例模式实现方式、pickle模块、选课系统目录搭建

    单例模式实现的多种方式 单例1:(提前定义一个名字) class C1: __instance = None def __init__(self,name,age): self.name = name ...

  3. LVGL 中图片使用问题

    此笔记主要是记录在 LVGL 中使用图片的几种方式,以及使用过程中遇到的问题.最近在 ARM linux 中使用 LVGL 时,发现加载图片变得很卡,一开始还好,当连续加载的图片变多后,特别是动画的过 ...

  4. [深度探索C++对象模型]trival constructor和non-trival constructor

    分清楚user-declared constructor和implict default constructor 首先要知道,如果你没有自定义一个类的构造函数,那么编译器会在暗中声明一个构造器,这个构 ...

  5. P8622 [蓝桥杯 2014 国 B] 生物芯片

    简要题意 有 \(N\) 个二进制数,编号为 \(1\sim N\),初始时都是 \(0\).博士进行了 \(N-1\) 次操作,在第 \(i\) 次操作时,会将 \(1\sim N\) 中所有编号为 ...

  6. Python3+Selenium3自动化测试-(六)

    这里来说一说selenium中的等待方式,其实在webdriver只有两种类型等待方式,显式等待和隐式等待,之前是在程序运行过程中使用time模块中的sleep进行代码的休眠进行强制等待,是显式等待中 ...

  7. JDK8 四大核心函数式接口及扩展接口总结

    前言 Java8的四大函数式接口及相关的扩展接口在日常使用中的频率也是非常多的,包括自己定义的函数式接口,在JDK1.8之前,我们定义的方法都是用来接收参数,然后自己根据参数传递实现逻辑.在1.8之后 ...

  8. VSCode一键接入Notebook体验算法套件快速完成水表读数

    摘要:本示例围绕真实AI需求场景,介绍VSCode一键接入Notebook体验算法套件快速完成水表读数的使用流程. 本文分享自华为云社区<VSCode一键接入Notebook体验算法套件快速完成 ...

  9. FAQ os.system调用失效问题

    os.system调用失效问题 背景 有个学员反馈allure无法生成报告 # 示例代码 import pytest,os def test_os(): pass if __name__ == '__ ...

  10. 分布式配置nacos搭建踩坑指南(下)

    上一篇介绍了在配置nacos中的碰到的坑,这一篇介绍一下如何正确进行nacos的环境搭建和配置,所以本文分为两部分,第一部分为环境搭建,介绍如何安装和运行.第二部分为alibaba Sprint Bo ...