Pytest中doctests的测试方法应用!

在 Python 的测试生态中,Pytest 提供了多种灵活且强大的测试工具。其中,doctests 是一种独特而直观的测试方法,通过直接从文档注释中提取和执行测试用例,确保代码示例的正确性。本文将深入介绍 Pytest 中 doctests 的测试方法,包括基本用法和实际案例,以帮助你更好地利用这一特性。

图片

什么是Pytest中的doctests?

在 Pytest 中,doctests 是一种通过文档注释中的代码示例进行测试的方法。这种测试方法不仅可以作为代码的说明文档,还可以确保文档中的示例代码真正能够运行,并且产生的输出符合预期。

图片

基本用法

在函数、类或模块的文档注释中编写 doctests 很简单。让我们以一个简单的加法函数为例:

def add(a, b):    """    Function to add two numbers.    Example:    >>> add(2, 3)    5    >>> add(-1, 1)    0    """    return a + b

在这个例子中,我们使用了函数的文档注释来包含 doctests。每个示例都以 `>>>` 开始,后面是调用函数的代码,接着是期望的输出结果。当运行 Pytest 时,它会自动检测并执行这些 doctests。

图片

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:691998057【暗号:csdn999】

案例演示

考虑一个更复杂的情景,我们有一个字符串处理的函数 `capitalize_and_reverse`:

def capitalize_and_reverse(text):    """    Function to capitalize a string and reverse it.    Example:    >>> capitalize_and_reverse('pytest')    'TSEYTP'    >>> capitalize_and_reverse('hello')    'OLLEH'    """    capitalized_text = text.capitalize()    reversed_text = ''.join(reversed(capitalized_text))    return reversed_text

这个函数首先将字符串首字母大写,然后将其反转。我们通过 doctests 来验证这个函数的正确性。

图片

运行测试

要运行包含 doctests 的测试,只需在 Pytest 命令中添加 `-k doctest`:

pytest -k doctest

Pytest 将查找包含 doctests 的模块,并执行其中的测试用例。如果所有的测试都通过,输出将显示为 `1 passed`。

图片

与其他测试方法的结合

doctests 可以与其他 Pytest 的测试方法结合使用,构建更全面的测试套件。例如,我们可以在同一个模块中同时使用 doctests 和常规的测试函数:

# test_code.pydef test_add_function():    assert add(2, 3) == 5    assert add(-1, 1) == 0# Run both doctests and regular testspytest -k "doctest or test_add_function"

这样,我们既能够利用 doctests 验证示例代码,又能够使用常规的测试函数覆盖更复杂的测试场景。

图片

优势与注意事项

优势

1. 直观清晰: Doctests 直接嵌入在文档中,使得测试用例与文档保持同步,更易于理解和维护。

2. 文档即测试: Doctests 让文档不仅仅是静态的说明,还可以作为实际的测试用例,确保文档中的示例是可运行的。

3. 一体化: Doctests 不需要额外的配置,与文档紧密结合,方便快捷。

注意事项:

1. 简单场景: Doctests 更适用于简单的测试场景,对于复杂的测试逻辑,建议使用其他 Pytest 的测试方法。

2. 维护成本: 如果 doctests 过于繁琐,可能导致文档难以维护。在实际项目中,需要根据情况权衡使用。

Pytest 中的 doctests 提供了一种简单而直观的测试方法,使得文档不仅仅是说明文档,还可以成为实际的测试用例。通过嵌入在文档中的示例代码,我们可以轻松验证代码的正确性,确保文档中的示例是可运行的。然而,在实际项目中,需要谨慎使用 doctests,根据测试的复杂度和维护成本进行权衡。尝试在你的项目中使用 doctests,发现它的便利之处,让测试更加直观与高效。

下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

最后: 可以在公众号:自动化测试老司机 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/440072.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何使用Python+Flask搭建本地Web站点并结合内网穿透公网访问?

文章目录 前言1. 安装部署Flask并制作SayHello问答界面2. 安装Cpolar内网穿透3. 配置Flask的问答界面公网访问地址4. 公网远程访问Flask的问答界面 前言 Flask是一个Python编写的Web微框架,让我们可以使用Python语言快速实现一个网站或Web服务,本期教程…

云计算底层技术奥秘、磁盘技术揭秘、虚拟化管理、公有云概述

云计算基础 实验图例 虚拟化平台安装 创建虚拟机 1、创建虚拟机 2cpu,4G内存(默认用户名: root 密码: a) 2、验证 ecs 是否支持虚拟化 [rootecs ~]# grep -Po "vmx|svm" /proc/cpuinfovmx... ...[rootecs ~]# lsmod |grep kvm…

OpenHarmony—Gradle工程适配为Hvigor工程

该适配场景适用于开发者希望将原OpenHarmony API 7的工程升级到OpenHarmony API 9的工程。 原OpenHarmony API 7的工程采用的是Gradle自动化构建工具,而OpenHarmony API 9的工程则采用Hvigor自动化构建工具,由于Gradle构建工具和Hvigor构建工具的配置文…

自动化测试系列 —— UI自动化测试!

UI 测试是一种测试类型,也称为用户界面测试,通过该测试,我们检查应用程序的界面是否工作正常或是否存在任何妨碍用户行为且不符合书面规格的 BUG。了解用户将如何在用户和网站之间进行交互以执行 UI 测试至关重要,通过执行 UI 测试…

win11安装Telnet功能

win11上很多设置都可以直接搜索了,菜单功能也总是换位置,记录一下。 搜索可选功能 选择可选功能 或者 添加可选功能到最地下选更多Windows功能 选择Telnet客户端即可

企业局域网传输文件最快的方式有哪些?

在当今企业运营的背景下,文件的传递和交换,无论是在公司内部网络还是跨越不同网络环境,都是日常业务运作的关键环节。这种文件交换对于团队协作以及与外部合作伙伴的数据共享至关重要,而一个高效且安全的文件传输系统则是提高工作…

QT使用QFileSystemModel实现的文件资源管理器(开源)

文章目录 效果图现实的功能总体框架功能介绍视图双击进入处理复制与剪切粘贴重命名,新建显示文件详细信息文件路径导航栏 总结 效果图 现实的功能 支持文件/文件夹复制,粘贴,剪切,删除,重命名的基本操作支持打开图片&…

git远程仓库基本操作

目录 gitremote (查看远程仓库) git remote add [仓库名] [url] git clone [url](克隆远程仓库到本地) git push [名][分支名](提交到远程仓库)​编辑 git pull [名][分支名]从远程仓库拉取​编辑 注意操作…

图形绘制-仪表盘(3)

本章节我们介绍如何绘制仪表盘内的车速、单位(Km/h)、标题等信息。 效果如下: 关于通过继承重写QWidget的绘制事件paintEvent(),来绘制仪表盘的基础操作,请看 《图形绘制-仪表盘(1)-CSDN博客》…

鸿蒙南向开发——GN快速入门指南

运行GN(Generate Ninja) 运行gn,你只需从命令行运行gn,对于大型项目,GN是与源码一起的。 对于Chromium和基于Chromium的项目,有一个在depot_tools中的脚本,它需要加入到你的PATH环境变量中。该脚本将在包含当前目录的…

2024年【陕西省安全员B证】最新解析及陕西省安全员B证证考试

题库来源:安全生产模拟考试一点通公众号小程序 陕西省安全员B证最新解析参考答案及陕西省安全员B证考试试题解析是安全生产模拟考试一点通题库老师及陕西省安全员B证操作证已考过的学员汇总,相对有效帮助陕西省安全员B证证考试学员顺利通过考试。 1、【…

深度学习与神经网络pytorch版 2.3 线性代数

深度学习与神经网络pytorch版 2.3 线性代数 1. 简介 深度学习与线性代数之间有着密切的联系。线性代数是深度学习算法中用于表达和处理数据的数学工具之一,尤其是在构建神经网络和处理多维数据时。 线性代数中的基本概念包括向量、矩阵和线性变换等,这…