关于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:\pytest\bopytest-code\code\ch1, 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:\pytest\bopytest-code\code\ch1, 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 files\python\python.exe

cachedir: .pytest_cache

rootdir: G:\pytest\bopytest-code\code\ch1, 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>.

  

pytest 入门及运行的更多相关文章

  1. Linux入门:运行级别解析

    Linux入门:运行级别解析   一.查看当前运行级别 Ubuntu中,runlevel命令 可以查看当前运行级别: CentOS中,who -r 命令查看当前运行级别:   www.2cto.com ...

  2. 数据库入门之运行原始 SQL 查找

    数据库入门之运行原始 SQL 查找 一旦你设置好了数据库连接,就可以使用 DB facade 来进行查找.DB facade 提供每个类型的查找方法:select.update.insert.dele ...

  3. Activity工作流(2)-入门安装运行第一个例子

    转: Activity工作流(2)-入门安装运行第一个例子 置顶 2017年05月24日 15:58:50 li_ch_ch 阅读数:24432   版权声明:本文为博主原创文章,未经博主允许不得转载 ...

  4. Python测试框架pytest入门基础

    Pytest简介 Pytest is a mature full-featured Python testing tool that helps you write better programs.T ...

  5. 1.pytest入门

    一.pytest单元测试框架 概念:单元测试是指在软件开发中,针对软件的最小单位(函数.方法等)进行正确性的检查测试          单元测试框架是自动化测试框架中的组成部分之一           ...

  6. hive UDAF开发入门和运行过程详解(转)

    介绍 hive的用户自定义聚合函数(UDAF)是一个很好的功能,集成了先进的数据处理.hive有两种UDAF:简单和通用.顾名思义,简单的UDAF,写的相当简单的,但因为使用Java反射导致性能损失, ...

  7. Hadoop(六)MapReduce的入门与运行原理

    一 MapReduce入门 1.1 MapReduce定义 Mapreduce是一个分布式运算程序的编程框架,是用户开发“基于hadoop的数据分析应用”的核心框架: Mapreduce核心功能是将用 ...

  8. SpringBoot框架:快速入门搭建运行一个应用程序(一)

    一.环境配置 Java环境:1.8版本 开发工具:IntelliJ IDEA 二.简单应用 1.创建项目 选择创建的项目类型为Spring Initializr,Project SDK选择1.8版本的 ...

  9. pytest - 失败重运行机制:rerun

    失败重运行机制 用例失败的情况下,可以重新运行用例 一旦用例失败,马上重新运行 安装插件:pip install pytest-rerunfailures 使用命令:--reruns 重试次数 如 - ...

随机推荐

  1. PostgreSql别名区分大小写的问题

    PostgreSql是区分大小写的,如果别名的大小不一致就会提示错误: SELECT * FROM ( SELECT cpi."product_item_id" "PRO ...

  2. bed文件格式解读

    1)BED文件 BED 文件(Browser Extensible Data)格式是ucsc 的genome browser的一个格式 ,提供了一种灵活的方式来定义的数据行,以用来描述注释信息.BED ...

  3. java并发:读写锁ReadWriteLock

    在没有写操作的时候,两个线程同时读一个资源没有任何问题,允许多个线程同时读取共享资源. 但是如果有一个线程想去写这些共享资源,就不应该再有其它线程对该资源进行读或写. 简单来说,多个线程同时操作同一资 ...

  4. java并发:AtomicInteger 以及CAS无锁算法【转载】

    1 AtomicInteger解析 众所周知,在多线程并发的情况下,对于成员变量,可能是线程不安全的: 一个很简单的例子,假设我存在两个线程,让一个整数自增1000次,那么最终的值应该是1000:但是 ...

  5. IIS7web服务器调试ASP.net程序遇到的一些故障的解决办法

    1. [由于 Web 服务器上的“ISAPI 和 CGI 限制”列表设置,无法提供您请求的页面] 故障描述:[由于 Web 服务器上的“ISAPI 和 CGI 限制”列表设置,无法提供您请求的页面] ...

  6. Java实现聚类算法k-means

    2016-07 java简单实现聚类算法 但是有一个小问题,,,,我其实每次迭代之后(就是达不到我的收敛标准之前,聚类中心的误差达不到指定小的时候),虽然重新算了聚类中心,但是其实我的那些点并没有变, ...

  7. linux 下的 rsync 文件同步

    rsync是linux下的一款快速增量备份工具Remote Sync,是一款实现远程同步功能的软件,它在同步文件的同时,可以保持原来文件的权限.时间.软硬链接等附加信息.rsync是用 “rsync ...

  8. apache中开启rewrite

    1.在apache配置文件httpd.conf中找到如下行: #LoadModule rewrite_module modules/mod_rewrite.so 去掉该行前面的#号 2.在httpd. ...

  9. 将Boost库添加到Visual Studio 2017

    在windows 环境中,一般比较推荐的打包软件的方式是,将自己所需要的共享库放在软件自己的文件夹中,并且避免与其它的软件共用.除非是微软的官方组件,比如微软自家的VC Runtime. Boost库 ...

  10. .NET 发送邮件

    //邮件配置 public static string mail_smtp = System.Configuration.ConfigurationManager.AppSettings[" ...