![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=1738861613-1QwpKYeQqsb1nZEJMt9uSJ1c6mjKtQlz-0-a2fea81deed966e688757351f9d909a6)
不带-v参数的命令如下。
python3 -m pytest test_command.py
不带-v参数命令执行后的结果如图1-7所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P20_1722.jpg?sign=1738861613-KxkV1dImmffR5XheEf54cJ2RAsazmSZ9-0-abf9f892fccdc5b527b0b850ec19948e)
图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=1738861613-zJy5csfaN10tObvjtRzuPVUQRDWtenxJ-0-e0f4e47cf7d824eb466dc0bb8b525bfc)
图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=1738861613-Q0p33l4iyCyz0g6TiD5r6NT7AJKrwEEy-0-5527a311af6f2a4a5501d082bd9aa448)
执行命令如下。
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=1738861613-GLHmmZEbLIGmPbQhC8XVIqYzXfeVrC9N-0-27f2e2b21fa20b87f60f7335a2a6ee17)
图1-9 带-s参数命令执行后的结果
备注:
图1-9中显示了测试函数中print()输出的内容。
3.按分类执行
在pytest中,参数-k允许使用表达式来指定希望执行的测试用例,如果测试用例编写的过程中按照业务进行命名,那么在执行过程中可以指定执行哪些业务的测试用例,代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P21_30763.jpg?sign=1738861613-keUdRuYXSTgDBoMqs07mv6PXnzXMlerG-0-354fddbb65ac46b7ee1bacc5f62d8eb3)
在如上代码中,假设开发只调整了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=1738861613-dNJF8BEJ1WYeR0BjQxXccAJgP6DNpBf8-0-1f59f3ba8a34621cf263e1746c0ee297)
图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=1738861613-0elBxNXXl0ikIGatafXtXqMHoTdYUJg7-0-1bd820d79cc3c3a61cdf9994a52d8f31)
图1-11 分类执行条件为或(or)的执行结果
备注:
如果在执行命令中的表达式是或的关系,那么就会执行函数名中带login和logout的测试用例,图1-11中的执行结果显示执行了带不同关键字的两个测试用例。
4.按分组执行
pytest的命令中带参数-m可以快速找到分组并且立刻执行,分组模式主要是根据装饰器执行的。代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P22_30769.jpg?sign=1738861613-yWegZzC17PPrYSp0QGSLFh0LpltsfRpI-0-8ebe7fbdbbf7b68cc9d6d4f65f75eff4)
下面介绍使用分组的方式来执行测试用例,如只执行分组为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=1738861613-eof6BmVHF8CPhJVtafXcNCIs8VKmoUj8-0-549a62e75738c9df365228ceedbea21e)
图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=1738861613-6NiTkqMg9JyFq7CiiIPghk5TGljJD8e5-0-ae7805e9a55ca87fb423b4148730d49e)
图1-13 执行结果
备注:
如果执行的表达式是或关系,则执行所有满足条件的测试用例。
5.执行失败立刻停止
在pytest执行测试用例的过程中,如果有一个测试用例执行失败,就立刻停止执行所有测试用例,使用到的参数是-x,代码如下。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P23_30782.jpg?sign=1738861613-XpoDMJfHwGaDlmontPgnDW6qOGDSLFCT-0-0b6b36845d8ce86efe1080a229a0a75e)
如上代码中第一个测试用例断言执行失败,即说明执行的过程失败,命令如下。
python3 -m pytest -v -x test_command.py
执行结果如图1-14所示。
![](https://epubservercos.yuewen.com/B5D6AE/31397731707980106/epubprivate/OEBPS/Images/Figure-P24_2097.jpg?sign=1738861613-KrldKTJfxwYiFsUNNMUSXYpUs3ifFj6f-0-610dbeae5e20f72913a22920fa1d881b)
图1-14 带-x参数命令执行结果
备注:
如上代码中,执行到第一个测试用例时失败,后面的测试用例就不会执行。一般不建议使用该命令。在测试执行的过程中,不管是否执行失败,都应该把所有的测试用例执行完成。