单元测试 pytest 模块

目录

  注意事项

  1. 命名规则

  2. pytest 生成自带的  html 测试报告

    2.1 指定测试用例并生成测试报告

    2.2 运行指定模块下,运行所有test开头的类和测试用例

    2.3 直接执行 pytest.main() 【自动查找当前目录下,以test_ 开头的文件或者以_test 结尾的py 文件】

  3. pytest 调用语句

  4. pytest 的运行方式

注意事项

  前提:需要安装pytest 和 pytest-html (生成html 测试报告)

  pip install pytest 和  pip install pytest-html

  在新建项目时需要选择

  

 

1. 命名规则

  pytest 单元测试中的类方法和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest 更加严谨

  pytest:setup, setup_class 和 teardown, teardown_class 函数(和unittest 执行效果一样)

  运行与测试方法的始末,即:运行一次测试函数会运行一次setup 和 teardown

  运行于测试方法的始末,但是不管有多少测试函数都只执行一次 setup_class 和 teardown_class

  类方法以 test 开头

  

 

  类方法非 test 开头

  

  类方法下的函数名以 test 开头

  

 

  类方法下的函数名非 test 开头

  

 

2. pytest 生成自带的 html 测试报告

  前提条件:需要下载pytest-html模块(python自带的生成测试报告模块)

  pip install pytest-html

  只需要加入参数即可:

  pytest.main(["–html=./report.html"])

  如果不安装  pytest-html

  

 

  安装 pytest-html 以后

  

 

 

  2.1 指定测试用例并生成测试报告

  

 

  

 

   2.2 运行执行模块下,运行所有 test 开头的类和测试用例

  pytest.main(["–html=./report.html",“模块.py”])

  

 

 

 

  2.3  直接执行 pytest.main() 【自动查找当前目录下,以test 开头的文件或者以 _test 结尾的py 文件】

  pytest.main([‘–html=./report.html’])

  在同一目录下新建俩个相同的py文件并写入相同的代码

  

 

  在任意一个py 文件里调用,生成的测试报告如下

  

 

  

 

  py 文件非以 test_ 开头的文件或者以_test 结尾

  在同级目录下新建一个非以test_开头的文件或者以_test结尾的py文件  test01.py

  

 

  此时再调用,不会发现test01中的代码并没有执行

  

 

  

 

3. pytest 调用语句

  pytest.main([’-x’,’–html=./report.html’,‘t12est000.py’])

  -x:出现一条测试用例失败就退出测试

  

 

  -v:丰富信息模式, 输出更详细的用例执行信息

  

 

  -s:显示print内容

  

 

  -q:简化结果信息,不会显示每个用例的文件名

  

 

  使用@pytest.mark.skip()跳过该用例(函数)

  

 

  

 

4. pytest 的运行方式

  . 点号,表示用例通过

  F 表示失败 Failure

  E 表示用例中存在异常 Error

posted @ 2021-04-06 15:47  Mr-刘  阅读(178)  评论(0编辑  收藏  举报