Pytest 特点:
- 非常容易上手,入门简单,文档丰富,文档中有很多实例可以参考
- 能够支持简单的单元测试和复杂的功能测试
- 支持参数化
- 执行测试过程中可以将某些测试跳过(skip),或者对某些预期失败的case标记成失败
- 支持重复执行(rerun)失败的 case
- 支持运行由 nose, unittest 编写的测试 case
- 可生成 html 报告
- 方便的和持续集成工具 jenkins 集成
- 可支持执行部分用例
- 具有很多第三方插件,并且可以自定义扩展
安装:
cmd运行
1 2 3 |
|
查看版本
1 |
|
Pytest用例的设计原则
用Pytest写用例时候,一定要按照下面的规则去写,否则不符合规则的测试用例是不会执行的
- 文件名以 test_*.py 文件和*_test.py
- 以 test_ 开头的函数
- 以 Test 开头的类,不能包含 __init__ 方法
- 以 test_ 开头的类里面的方法
- 所有的包 pakege 必须要有__init__.py 文件
Pytest执行用例规则
注意,下面讲的都是在cmd中执行pytest命令
1、某个目录下所有的用例
pytest
2、执行某一个 py 文件下用例
pytest 脚本名称.py
3、运行ptest1.py 模块里面的某个函数,或者某个类,某个类里面的方法
加v和不加-v都可以,加-v的话,打印的信息更详细
pytest -v ptest1.py::TestClass::test_method
pytest ptest1.py::TestClass::test_method
pytest ptest1.py::test_answer
4、运行ptest1.py 模块里面,测试类里面的某个方法
pytest ptest1.py::TestClass::test_two
5、-m 标记表达式
pytest -m login
将运行用 @pytest.mark.login 装饰器修饰的所有测试
6、-q 简单打印,只打印测试用例的执行结果
7、-s 详细打印
8、-x 遇到错误时停止测试
9、—maxfail=num,当用例错误个数达到指定数量时,停止测试
10、-k 匹配用例名称
执行测试用例名称包含http的所有用例
pytest -s -k http ptest1.py
11、-k 根据用例名称排除某些用例(not)
pytest -s -k "not http" ptest1.py
12、-k 同时匹配不同的用例名称(or)
pytest -s -k "method or weibo" ptest1.py