背景

最近在使用pytest框架写测试用例的时候,为了调试case,我在其中使用了print来打印相关的变量值,如下图:

分析

图中的setup_class和setup_method分别在类开始时和用例执行前被调用,但是实际运行pytest xxx.py的时候,print函数打印的信息没有输出到控制台!

我最开始怀疑是把setup函数放错位置了,对照官网文档查看了下,位置并没有放错。

那问题出在哪里呢?难道pytest默认不会输出print语句吗?然后我又去网上搜一圈,才发现pytest确实不会输出print的信息到控制台,如果要想打印所有内容,需要运行时加上"-s"参数,即pytest -s xxx.py

原来问题出现在我没有加-s参数,由于我是直接上手pytest框架,并没有仔细阅读其文档,以至于一个很简单的问题,却让我困惑了一个小时。

博主:测试生财

座右铭:专注测试与自动化,致力提高研发效能;通过测试精进完成原始积累,通过读书理财奔向财务自由。

csdn:https://blog.csdn.net/ccgshigao

博客园:https://www.cnblogs.com/qa-freeroad/

51cto:https://blog.51cto.com/14900374