• jQuery火箭图标返回顶部代码


    关于pytest的入门教程,官网及网上已经很多了,那再多一点也无所谓吧!OK,进入正题~

      下面是一个测试用例,test_one.py

    def test_passing():
        assert (1, 2, 3) == (1, 2, 3)

      在用例当前路径打开终端,输入pytest test_one.py,运行结果如下:

    ============================= test session starts =============================

    platform win32 -- Python 3.7.0, pytest-3.9.2, py-1.5.4, pluggy-0.8.0

    rootdir: G:pytestopytest-codecodech1, inifile:

    collected 1 item

    test_one.py .                                                            [100%]

    ========================== 1 passed in 0.10 seconds ===========================

      下面来逐句说明下pytest运行单个测试文件时的控制台输出信息:

    ============================= test session starts =============================

      pytest为每段测试会话(session)做了明确的分隔,一段会话就是pytest的一次调用,它可能包括多个目录下被执行的测试用例。

    platform win32 -- Python 3.7.0, pytest-3.9.2, py-1.5.4, pluggy-0.8.0

      我使用的windows电脑,所以显示的是platform win32。接着显示Python、Pytest以及pytest包的版本。py和pyluggy都是pytest包,用于pytest的实现,均由pytest团队开发维护。

    rootdir: G:pytestopytest-codecodech1, inifile:

      rootdir(当前起始目录)是pytest搜索测试代码时最常使用的目录,inifile用于列举配置文件(这里没有指定),文件名可能是pytest.ini、tox.ini或者setup.cfg。

    collected 1 item

      搜索范围内找到一个名为test_one.py的测试条目。

    test_one.py .                                                            [100%]

      test_one.py表示测试文件,每个文件的测试情况占据一行,后接的一个点号表示该测试用例已通过。点号仅仅表示通过,而Failurt(失败)、error(异常)、skip(跳过)、xfail(预期失败)、xpass(预期失败但通过)会被分别标记为F、E、s、x、X。使用-v或--verbose可以看到更多细节。100%表示测试完毕。

    ========================== 1 passed in 0.10 seconds ===========================

      表示测试通过的数量以及这段会话耗费的时间,如果存在未通过的测试用例,则会根据未通过的类型列举数量。

    如上面提到的如果想查看详情,可以在pytest后面加上-v或者--verbose选项,pytest -v test_one.py:

    ============================= test session starts =============================

    platform win32 -- Python 3.7.0, pytest-3.9.2, py-1.5.4, pluggy-0.8.0 -- f:progr am filespythonpython.exe

    cachedir: .pytest_cache

    rootdir: G:pytestopytest-codecodech1, inifile:

    collected 1 item

    test_one.py::test_passing PASSED                                         [100%]

    ========================== 1 passed in 0.02 seconds ===========================

      加上-v后,会在测试文件名后显示函数名以及大写的测试结果。如果使用的彩色终端,那么PASSED和底部线条都是绿色的。如下:

      

       下面是一个失败的测试用例,test_two.py:

    def test_failing():
        assert (1, 2, 3) == (3, 2, 1)

      运行结果如下:

      

      pytest展示了很清楚的失败信息,这也是它受欢迎的原因之一。

      如上,pytest有一块专门的区域展示test_failing的失败信息,它能准确指出失败原因:index 0 is mismatch。并且重要的提示信息用红色字体显示,以方便用户阅读。如果你仔细观察,还有一条提示指出,使用-v可以得到更完整的前后对比信息,如下图:

      

      pytest添加几个脱字符(^),准确地指出了前后的区别。

      终端运行pytest --help:

      usage: pytest [options] [file_or_dir] [file_or_dir] [...]

      第一句就说明了使用语法,如果你不提供任何参数,pytest会在当前目录以及子目录寻找测试文件,然后运行搜索到的测试代码。如果你提供一个或者多个文件名、目录名,pytest会逐个查找并运行所有测试。为了搜索到所有测试代码,pytest会递归遍历每个目录及其子目录。

      如在之前路径下直接运行pytest,结果如下 :

      

      也可以在pytest中指定需要测试的文件名或者目录,或者预先切换到需要运行的目录:

      

      我们把pytest搜索测试文件和测试用例的过程称为测试搜索(test discovery)。只要你按pytest的命名规则,pytest就能自动搜索到所有待执行的测试用例。

      以下是几条主的命名规则:

      1. 测试文件应当命名为 test_<something>.py或者<somethins>_test.py

      2. 测试函数、测试类方法应当命名为test_<something>

      3. 测试类应当命名为Test<Something>.

      

  • 相关阅读:
    Qt 布局之二:水平、垂直布局的使用详解
    Qt 布局之一:布局初探
    [数据库] SQL 语法之进阶篇
    [数据库] SQL 语法之基础篇
    看图深入理解单链表的反转
    [数据结构
    (原)tslib的交叉编译
    (转) s-video vs. composite video vs. component video 几种视频格式详细说明和比较
    (转)BT1120接口及协议
    (转)Ubuntu12.04上NFS Server安装使用过程
  • 原文地址:https://www.cnblogs.com/cnkemi/p/9930884.html
Copyright © 2020-2023  润新知