【30天玩转python】单元测试与调试

单元测试与调试

在 Python 开发中,编写单元测试和进行调试是保证代码质量、减少错误的重要步骤。单元测试可以帮助我们验证代码功能是否符合预期,调试则可以在代码出现问题时快速定位错误原因。


1. 单元测试简介

单元测试是对程序中最小可测试部分(通常是函数或类)进行验证的过程,确保每个部分都能正常工作。Python 中有多个测试框架,其中最常用的是 unittest 模块。


2. 使用 unittest 进行单元测试

unittest 是 Python 标准库中的单元测试框架,类似于其他语言中的 JUnit、NUnit 等。它可以用于创建测试用例、测试集以及对代码进行断言。

2.1 基本结构

要使用 unittest 进行单元测试,通常需要创建一个测试类,该类继承自 unittest.TestCase。在这个类中,编写测试方法,并使用 assert 系列方法来验证代码的输出。

示例:简单的加法函数测试

import unittest# 被测试函数
def add(a, b):return a + b# 创建测试类,继承 unittest.TestCase
class TestMathFunctions(unittest.TestCase):# 测试 add 函数def test_add(self):self.assertEqual(add(1, 2), 3)  # 测试 1 + 2 是否等于 3self.assertEqual(add(-1, 1), 0) # 测试 -1 + 1 是否等于 0self.assertNotEqual(add(1, 2), 4) # 测试 1 + 2 不等于 4# 运行测试
if __name__ == '__main__':unittest.main()
2.2 断言方法

unittest 提供了多种断言方法,用于验证不同的测试结果:

断言方法描述
assertEqual(a, b)检查 a == b 是否为 True
assertNotEqual(a, b)检查 a != b 是否为 True
assertTrue(x)检查 x 是否为 True
assertFalse(x)检查 x 是否为 False
assertIsNone(x)检查 x is None 是否为 True
assertIsNotNone(x)检查 x is not None 是否为 True
assertIn(a, b)检查 a 是否包含在 b
assertNotIn(a, b)检查 a 是否不包含在 b
assertRaises(Exception)检查是否抛出了指定的异常

示例:更多断言方法

import unittestdef divide(a, b):if b == 0:raise ValueError("除数不能为零")return a / bclass TestDivideFunction(unittest.TestCase):def test_divide(self):self.assertEqual(divide(10, 2), 5)self.assertRaises(ValueError, divide, 10, 0)  # 检查是否抛出 ValueErrorif __name__ == '__main__':unittest.main()
2.3 测试套件

当有多个测试类或测试方法时,可以将它们组织到测试套件(test suite)中,通过一次运行来测试多个功能。

def suite():suite = unittest.TestSuite()suite.addTest(TestMathFunctions('test_add'))suite.addTest(TestDivideFunction('test_divide'))return suiteif __name__ == '__main__':runner = unittest.TextTestRunner()runner.run(suite())

3. 使用 pytest 进行单元测试

除了 unittest,Python 中还有更简洁的第三方测试框架,如 pytestpytest 提供了更灵活的断言方式和更简单的测试用例编写方式。

3.1 pytest 示例

使用 pytest 时,不需要像 unittest 那样创建测试类,只需编写简单的测试函数即可。pytest 通过函数名称的前缀 test_ 自动识别测试用例。

示例:使用 pytest 测试加法函数

# 被测试函数
def add(a, b):return a + b# 测试函数
def test_add():assert add(1, 2) == 3assert add(-1, 1) == 0assert add(1, 2) != 4

运行 pytest 时,只需在终端中执行 pytest 命令,它会自动寻找所有以 test_ 开头的函数并运行测试。


4. 调试方法

调试是编程过程中非常重要的一部分,Python 提供了多种调试方法,最常用的是 pdb 模块和 print() 调试。

4.1 使用 print() 进行调试

最简单的调试方式是通过在代码中插入 print() 函数,查看变量的值或函数的执行情况。虽然简单,但当项目较大或逻辑复杂时,print() 调试会变得混乱且难以维护。

示例:print() 调试

def add(a, b):result = a + bprint(f"add({a}, {b}) = {result}")return resultadd(5, 3)

尽管 print() 调试是快速查看问题的方法,但在大型项目中,建议使用更专业的调试工具。

4.2 使用 pdb 模块

pdb 是 Python 内置的调试器,可以让我们逐行执行代码,查看变量的状态,设置断点等。使用 pdb.set_trace() 可以在代码中设置断点,进入调试模式。

示例:使用 pdb 进行调试

import pdbdef add(a, b):pdb.set_trace()  # 在此处设置断点return a + badd(5, 3)

运行上面的代码后,程序会在 pdb.set_trace() 处暂停,我们可以在终端中输入调试命令,比如:

  • n:执行下一行代码
  • c:继续运行代码直到下一个断点
  • p variable_name:打印变量的值
  • q:退出调试器
4.3 使用 VSCode 进行调试

VSCode 提供了集成的调试功能,通过图形化界面设置断点、逐行执行代码以及查看变量状态。以下是使用 VSCode 调试 Python 代码的步骤:

  1. 打开 VSCode 并加载 Python 项目。
  2. 在代码的某行点击左侧的灰色区域设置断点。
  3. 点击 VSCode 窗口左侧的“运行和调试”按钮(或按 F5)启动调试模式。
  4. 调试时可以单步执行、跳过、继续运行等操作。

5. 代码覆盖率

代码覆盖率(Code Coverage)是衡量单元测试对代码的覆盖程度的指标,通常包括语句覆盖、分支覆盖等。高覆盖率的测试可以帮助我们发现潜在的代码问题。

Python 提供了 coverage 工具来生成代码覆盖率报告。

安装 coverage

pip install coverage

生成覆盖率报告

coverage run -m unittest discover  # 运行测试
coverage report  # 生成覆盖率报告
coverage html  # 生成 HTML 格式的覆盖率报告

6. 小结

  • 单元测试 是开发过程中验证代码正确性的重要工具,Python 中的 unittestpytest 框架可以帮助我们轻松编写测试用例。
  • 调试 是定位错误的关键步骤,除了简单的 print() 调试,还可以使用专业的 pdb 调试器以及 IDE 集成的调试功能。
  • 通过良好的单元测试和调试习惯,可以有效提升代码质量,减少错误,并保证项目的长期维护性。

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

C++_多态

C_多态 多态的概念 通俗来讲,就是多种形态。多态分为编译时多态(静态多态)和运行时多态(动态多态)。 编译时多态主要就是函数重载和函数模板,他们传不同类型的参数就可以调用不同的函数,通过…

简单有效关于msvcp140.dll丢失的解决方法,msvcp140.dll

这篇文章将和大家分享几种msvcp140.dll丢失的解决方法,分析解决方法为什么能够通过这种方法进行修复成功,有效的将丢失的msvcp140.dll文件进行修复完成。 msvcp140.dll丢失?简单有效的解决途径 一、重新安装相关软件 原理 许多应用程序在安…

研究生数学建模竞赛E题思路模型参考文献高速公路应急车道紧急启用模型——高速公路饱和路段动态应急车道开放决策模型研究

1 概述 动态应急车道 ( Hard Shoulder Running ) 作为 调整路段交通流运行现状的重要管理手段, 可以在短时间内提供道路供给, 有效提升瓶颈路段的通行 能力。 早在 21 世纪初 , 欧美国家就已经通过开放 应急车道缓解的方式来解决路段的交…

2024最受人追捧的电脑远程控制软件推荐!首选这五款!好用、连接稳定、安全性高!

在2024年,电脑远程控制软件市场上涌现了众多受欢迎且功能强大的选择。 以下是根据最新信息推荐的五款好用、连接稳定、安全性高的电脑远程控制软件: 1. 安企神 特点:它是全球知名的远程控制软件,以其稳定性和可靠性著称。 它支…

C++——初步认识C++和namespace的用法

1.编程语言排行榜 我们通过排行可以看出 C在变成语言中还是占据着重要的地位 2.C在工作领域中的应用 1.PC客户端开发。⼀般是开发Windows上的桌面软件,比如WPS之类的,技术栈的话⼀般是C和 QT,QT 是⼀个跨平台的 C图形用户界面(G…

sourceTree使用脚本一键push代码到gerrit

问题 在gerrit,我们无法直接把代码push到对应的分支。需要把代码push到 HEAD:refs/for/branch,review通过后再submit到分支。所以无法直接使用sourceTree上的推送按钮来push代码。但是可以通过自定义操作和脚本来实现这一功能。 脚本编写 新建文本文档写入以下内容&#xff…

fmql之ubuntu添加dhcp服务

按照官方指示:【在文末】 2024-08-22 buildroot linux 使用wpa_supplicant -B -i wlan0 切换WIFI 设备之后无法上网的问题。解决方法,使用udhcpc -i wlan0 命令-CSDN博客 网口连接路由器,然后发现路由器分配了ip,但是板卡没有配置…

VulnHub-Narak靶机笔记

Narak靶机笔记 概述 Narak是一台Vulnhub的靶机,其中有简单的tftp和webdav的利用,以及motd文件的一些知识 靶机地址: https://pan.baidu.com/s/1PbPrGJQHxsvGYrAN1k1New?pwda7kv 提取码: a7kv 当然你也可以去Vulnhub官网下载 一、nmap扫…

写作练习(一)

一、reply Z-Library The aim is to express gratitude and practice writing, and as a record. 二、Original letter As a college student of computer and a blogger, Z-Library is always a part of my study, which provide many books that I need pay a lost of time …

安捷伦Agilent/keysight 53220A参数资料 通用频率计 计数器

Agilent 53220A,Keysight 53220A,通用频率计数器/计时器,350 MHz,12 位,100 ps 53220A 350 MHz 通用频率计数器/计时器是一款双通道频率计数器,能够执行所需的全部频率和时间间隔测量。它可以添加可选的射…

突破常规:如何利用动态系统思维彻底变革你的团队!

引言 在现代社会中,变化是唯一不变的。面对快速发展的科技和瞬息万变的市场环境,企业和开发团队必须具备适应性和灵活性。动态系统思维作为一种理解和应对复杂系统中变化的方法,提供了有效的解决方案。本文将探讨动态系统思维在敏捷方法中的应…

load jsonl File with OpenAI API request results to pandas data.frame

题意:将包含 OpenAI API 请求结果的 jsonl 文件加载到 pandas DataFrame 中 问题背景: I have a large data set containing around 500k observation. It has a string variable that I want to create an embedding for. I used the OpenAI API to cr…

AI入门系列 | 如何优雅地下载最前沿的模型?

​简介 一片白云横谷口,几多归鸟尽迷巢。 小伙伴们好,我是微信公众号《小窗幽记机器学习》的小编:卖铁观音的小男孩。本系列主要基于过往经历,总结当时自身环境中实操经验。倘若能够顺便帮到他人,也是善莫大焉。 本文…

[已更新]2024数学建模研赛华为杯E题详细思路代码成品文章研究生数学建模数模辅导

截止2024.8.21 12点 已更新e全部小问的建模和问题一的代码 ####https://docs.qq.com/doc/DVU9YYUFLWlNOY3pyE题: 问题1:统计四个观测点的交通流参数随时间的变化规律 为了统计交通流参数(如车流密度、流量和速度),首先需要从视…

猫咪检测系统源码分享

猫咪检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vision …

Easypoi模板导出

Easypoi模板导出 优点 快速导出:使用预定义的Excel模板,可以快速导出数据,特别是在数据量大的情况下。简化代码:通过模板导出,减少了编写大量POI代码的需要,使得代码更简洁易懂。灵活性:模板可…

Camunda如何共享流程定义但不共享流程实例?

文章目录 一、项目场景二、问题描述三、解决方案方案一:官方实例化共享定义的方法1. 部署共享定义2. 在查询中包含共享的定义3. 实例化共享定义 方案二:自定义TenantIdProvider方法,将租户id作为变量添加到启动的实例中1. 采用自定义的Tenant…

PHP API 框架:构建高效API的利器

在当今快速发展的互联网时代,API(应用程序编程接口)已成为连接不同应用程序和服务的关键。PHP,作为一种流行的服务器端脚本语言,提供了多种强大的框架来简化API的开发。本文将介绍PHP API框架的重要性,以及…

Linux笔记---简单指令

1. 使用的环境 博主使用的是华为云服务器xshell终端的方式学习的,因为据说这样的方式比较接近以后的工作环境。 其中云服务器安装的是Ubuntu操作系统(以Linux为内核,适合新手学习Linux的一个版本) 这里的云服务器不一定使用华为的,但是我在…

论文推荐——犹豫直觉模糊偏好关系积性一致性及其在群决策中的应用

犹豫直觉模糊偏好关系积性一致性及其在群决策中的应用 论文全文 论文全文 论文最巧妙的地方就是修正了积性一致性的条件,使得修复方法完全满足互补条件,也算对大佬的工作做了一个很好的修补。