![Python服务端测试开发实战](https://wfqqreader-1252317822.image.myqcloud.com/cover/984/52841984/b_52841984.jpg)
1.4 pytest常用命令
在pytest测试框架中执行程序时会用到很多命令,下面详细介绍一些常用命令的使用。
1.打印详细信息
在pytest中执行命令时带上-v参数,就会输出详细的信息,代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P19_30752.jpg?sign=1739047957-3WXqGaVBY1N7lAk22xb87aZR71acBl8M-0-9a8b928ac248e95f3ac25704055c92b8)
不带-v参数的命令如下。
python3 -m pytest test_command.py
不带-v参数命令执行后的结果如图1-7所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P20_1722.jpg?sign=1739047957-AINwl2NBbNXRhxZXHtutou0gdNU0HrjE-0-b6506fb09b52ea7c12da297d7b4443da)
图1-7 不带-v参数命令执行后的结果
在图1-7中可以看到执行结果是.,.表示的是通过。带-v参数的命令如下。带-v参数命令执行后的结果如图1-8所示。
python3 -m pytest -v test_command.py
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P20_1733.jpg?sign=1739047957-pYHQSsmwbyZ9j3xjRYHcOoW4clTkvssx-0-987710ec911920867a6f2272be37e760)
图1-8 带-v参数命令执行后的结果
备注:
执行带-v参数的命令的输出结果中详细地显示了测试模块中具体的测试函数,结果信息也是通过PASSED来表示。
2.输出信息
在实际测试中,当测试函数出现错误时,需要进行具体的调试,可以通过在测试函数中添加print()函数输出调试信息来帮助调试具体的错误。pytest执行时,如果需要输出测试函数的信息,则应带上-s参数。修改test_command.py模块的代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P20_30758.jpg?sign=1739047957-vAkQVhrqMxeIIhJSareEx2bZhDAq0VoU-0-7de08cd005b704c527c59259dec53585)
执行命令如下。
python3 -m pytest -v -s test_command.py
带-s参数命令执行后的结果如图1-9所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P21_1795.jpg?sign=1739047957-GrzNIaT4fEAYceVZSy4YxwtwlmLQli67-0-29e15b21a52c284d6a3ade6cde01822e)
图1-9 带-s参数命令执行后的结果
备注:
图1-9中显示了测试函数中print()输出的内容。
3.按分类执行
在pytest中,参数-k允许使用表达式来指定希望执行的测试用例,如果测试用例编写的过程中按照业务进行命名,那么在执行过程中可以指定执行哪些业务的测试用例,代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P21_30763.jpg?sign=1739047957-ZJbEux6EOhqPQN4tCwXzohObWStXGd6K-0-fc3f396f317eddfd239136acee6b0918)
在如上代码中,假设开发只调整了login模块,那么可以只执行测试函数名中带login的测试用例,命令如下。
python3 -m pytest -v -k "login" test_login.py
带-k参数命令执行后的结果如图1-10所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P21_1859.jpg?sign=1739047957-e3i58xJWzVqaBJX9JlfjZ5LPpSKwGiso-0-a4efe2bc7b383b54fc38cf902a5e5c5b)
图1-10 带-k参数命令执行后的结果
备注:
如上结果中,只执行了函数名中带login关键字的测试用例。如果想同时执行函数名中带login和logout的测试用例,可以使用以下命令。
python3 -m pytest -v -k "login or logout" test_command.py
执行后输出的结果如图1-11所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P22_1880.jpg?sign=1739047957-QXa8civzCsXTDNGENoS5tkYiuQwy7BAP-0-af98b96f70d1afb342007ee0958173d3)
图1-11 分类执行条件为或(or)的执行结果
备注:
如果在执行命令中的表达式是或的关系,那么就会执行函数名中带login和logout的测试用例,图1-11中的执行结果显示执行了带不同关键字的两个测试用例。
4.按分组执行
pytest的命令中带参数-m可以快速找到分组并且立刻执行,分组模式主要是根据装饰器执行的。代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P22_30769.jpg?sign=1739047957-wG1roooYWsmP4KiTacmK9JT7CHAZjnUt-0-2210dc2d326cac1440896b56823bf517)
下面介绍使用分组的方式来执行测试用例,如只执行分组为login和logout的测试用例,命令如下。
python3 -m pytest -v -m "login and logout" test_command.py
带-m参数命令执行后的结果如图1-12所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P23_2002.jpg?sign=1739047957-UdZMYUXMoviFzHAkqtrqV19Ax6xOeYSk-0-c6276d14e437e13a0b4b49d7e6ecdb16)
图1-12 带-m参数命令执行后的结果
备注:
如上输出结果中,同时满足login和logout分组的测试用例只有test_command_001()测试函数,所以只执行了该函数。
对执行的命令进行调整,同时执行分组login和logout的测试用例,命令如下。
python3 -m pytest -v -m "login or logout" test_command.py
执行结果如图1-13所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P23_2015.jpg?sign=1739047957-vnnSRnzFu2PW54TgVrDWxZuo8NDPTNwQ-0-6f5bba2c574f4dd3ad6ec8e58f0c7bf7)
图1-13 执行结果
备注:
如果执行的表达式是或关系,则执行所有满足条件的测试用例。
5.执行失败立刻停止
在pytest执行测试用例的过程中,如果有一个测试用例执行失败,就立刻停止执行所有测试用例,使用到的参数是-x,代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P23_30782.jpg?sign=1739047957-n7E0g5Xwr8ukH1yaJoVsi7BA1wNMXWzq-0-1872c4743098459bed75c42789384dea)
如上代码中第一个测试用例断言执行失败,即说明执行的过程失败,命令如下。
python3 -m pytest -v -x test_command.py
执行结果如图1-14所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P24_2097.jpg?sign=1739047957-eoyZcGxJVGZ8e01fetVFAVAEY1vHyHD8-0-0c08becce9620824545f8b9189b8cec5)
图1-14 带-x参数命令执行结果
备注:
如上代码中,执行到第一个测试用例时失败,后面的测试用例就不会执行。一般不建议使用该命令。在测试执行的过程中,不管是否执行失败,都应该把所有的测试用例执行完成。