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.py

def 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自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

幻兽帕鲁服务器视频教程,3分钟快速搭建,新手0基础也可以!

幻兽帕鲁服务器搭建教程,基于阿里云计算巢新手3分钟0基础搞定,详细参考 aliyunbaike.com/go/palworld 视频教程 1分钟部署幻兽帕鲁搭建,新手成功创建! 大家也可以参考阿里云百科下方的教程: 如何自建幻兽帕鲁服务器&a…

二极管漏电流对单片机ad采样偏差的影响

1,下图是常规的单片机采集电压电路,被测量电压经过电阻分压,给到mcu采集,反向二极管起到钳位作用,避免高压打坏mcu。 2,该电路存在的问题 二极管存在漏电流,会在100k电阻上产生叠加电压&#x…

pve宿主机更改网络导致没网,pve更改ip

一、问题描述 快过年了,我把那台一直在用的小型服务器,带回去了,导致网络发生了变更,需要对网络进行调整,否则连不上网,我这里改的是宿主机,不是pve虚拟机中的系统。 二、解决方法 pve用的是…

07.领域驱动设计:3种常见微服务架构模型的对比和分析

目录 1、概述 2、整洁架构 3、六边形架构 4、三种微服务架构模型的对比和分析 5、从三种架构模型看中台和微服务设计 5.1 中台建设要聚焦领域模型 5.2 微服务要有合理的架构分层 5.2.1 项目级微服务 5.2.2 企业级中台微服务 5.3 应用和资源的解耦与适配 6、总结 1、概…

2024年CSC公派研究生项目(含联培)选派办法及解读

2024年春节将至,知识人网提前祝大家新年快乐,心想事成!同时提醒申请者关注国家留学基金委(CSC)的申报政策。近日CSC官网发布了2024年国家建设高水平大学公派研究生项目通知,知识人网小编现将其选派办法原文…

13.前端--CSS-盒子模型

1.盒子模型的组成 CSS 盒子模型本质上是一个盒子,封装周围的 HTML 元素,它包括:边框、外边距、内边距、和 实际内容 2.边框(border) 2.1 边框的使用 1、border设置元素的边框。边框有三部分组成:边框宽度(粗细) 边框…

ucharts 让x轴文字倾斜文字

ucharts 让x轴文字倾斜文字 xAxis: {disableGrid: true,scrollShow: false,//x轴文字倾斜rotateLabel:true},

2023年天猫食用油市场行业分析(电商数据查询软件):市场细分,营养调和油高速成长

食用油是人类膳食的重要组成部分,除了为日常饮食提供美味外,也是人体所需脂肪和能量的重要来源,对人体健康发挥着重要作用。因此,作为日常生活中的刚需品,食用油市场的整体规模也较大。 首先来看食用油市场的年度销售…

华为OD-华为机试精讲500篇系列文章目录介绍(持续补充ing)

目录 背景介绍 什么是华为OD? OD现状 OD趋势 华为OD机考刷题攻略 1、刷题资料:投递岗位通过筛选后提供 2、注意事项: 真题代码目录 背景介绍 经济下行的这几年,每个人都感同身受,如何让自己在芸芸众生中脱颖而…

深度学习之卷积神经网络

卷积神经网络简称为CNN 首先我们来回顾一下,我们之前学到的全连接的神经网络: 上面我们通过线性层串行连接起来的神经网络,我们叫做全链接的网络,在线性层里面,我们的输入值和任意的输出值之间都存在权重,…

05 Redis之Benchmark+简单动态字符串SDS+集合的底层实现

3.8 Benchmark Redis安装完毕后会自动安装一个redis-benchmark测试工具,其是一个压力测试工具,用于测试 Redis 的性能。 src目录下可找到该工具 通过 redis-benchmark –help 命令可以查看到其用法 3.8.1 测试1 3.9 简单动态字符串SDS 无论是 Redis …

中间件系列 - Kafka3.x从入门到精通

前言 学习视频:【尚硅谷】Kafka3.x教程(从入门到调优,深入全面)本内容仅用于个人学习笔记,如有侵扰,联系删除 1 Kafka 概述 1.1 定义 Kafka传统定义: Kafka 是一个分布式的基于发布/订阅模式的消息队列…

JMeter GUI:测试计划和工作台

什么是测试计划? 测试计划是您添加 JMeter 测试所需元素的地方。 它存储运行所需测试所需的所有元素(如线程组、计时器等)及其相应的设置。 下图显示了测试计划的示例 测试计划是您添加 JMeter 测试所需元素的地方。 它存储运行所需测试…

OpenCV实战:控制手势实现无触摸拖拽功能

前言: Hello大家好,我是Dream。 今天来学习一下如何使用OpenCV来控制手势,瞬间提升操作体验!跨越界限,OpenCV手势控制拖拽功能现身。 一、主要步骤及库的功能介绍 1.主要步骤 要实现本次实验,主要步骤如下…

设计模式——职责链模式(Chain of Responsibility Pattern)

概述 职责链模式(Chain of Responsibility Pattern):避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止。职责链模式是一种对象行为…

【基础算法】1、快速排序快速选择

快速排序思想: 1、找一个分界点。 2、在分界点两边开始调整范围。 3、递归两边,重复。 例题: 给定你一个长度为 n的整数数列。 请你使用快速排序对这个数列按照从小到大进行排序。 并将排好序的数列按顺序输出。 输入格式 输入共两行&#xf…

prism 10 for Mac v10.1.1.270激活版 医学绘图分析软件

GraphPad Prism 10 for Mac是一款专为科研工作者和数据分析师设计的绘图和数据可视化软件。以下是该软件的一些主要功能: 软件下载:prism 10 for Mac v10.1.1.270激活版 数据整理和导入:GraphPad Prism 10支持从多种数据源导入数据&#xff0…

第六讲_JavaScript原型

JavaScript原型 1. 原型的概念2. 原型继承2.1 原型链 3. class类的原型对象 1. 原型的概念 原型是 JavaScript 对象相互继承特性的机制。 每个函数都有一个 prototype 属性,这个属性指向一个对象,这个对象称为原型对象。每个对象都有一个 [[Prototype]…

Linux操作系统权限相关问题(一站式速通权限)

一、sudo命令 sudo yum install -y sl sudo命令的作用 不切换用户,就想让普通用户以root的身份,执行对应的指令 输入密码时,输入的是自己普通用户的密码,而不是root的密码!!! sudo可以进行…

C语言——如何进行文件操作

大家好,我是残念,希望在你看完之后,能对你有所帮助,有什么不足请指正!共同学习交流 本文由:残念ing原创CSDN首发,如需要转载请通知 个人主页:残念ing-CSDN博客,欢迎各位→…