为什么PYTHON开发人员应该关心测试
off999 2024-11-17 14:29 107 浏览 0 评论
来源:云云众生s
与任何标准编程语言一样,Python 软件开发中的测试只是验证您的应用程序是否按预期执行。
译自Why Should Python Developers Care About Testing,作者 Victor Iwuoha。
曾经听过那首老诗“Tick says the clock.. .Tick tick. What you have to do, do quick.”?
现在,想象一下这句诗:“请测试代码……先测试。你想要推送的内容,先测试。”我在写这篇文章时,这句诗就跳进了我的脑海。
7月19日将作为互联网时代主要停电事件之一载入史册。那天,网络安全提供商 Crowdstrike 向全球MicrosoftWindows 用户推送了一个更新,导致他们的系统崩溃,出现了可怕的蓝屏死机。这是由于越界内存读取造成的,影响了大约 850 万用户。实际上,我们任何人都可能要为将代码推送到生产环境负责。然而,在阅读了这次事件的教训之后,它又回到了一个永恒的预防措施: 测试你的代码。
什么是测试
虽然我们将重点关注测试Python代码,但核心概念也适用于其他标准编程语言。
软件开发中的测试只是验证你的应用程序是否按预期工作。这意味着你的代码应该满足你设计它要做的预期。在使用 Python 构建软件或数据管道时,你可能需要函数或类的组合来执行一些业务逻辑。这些函数通常需要一个输入来处理并产生一个预期的输出,甚至引发一个异常,因此需要对它们进行测试以确保它们能够正常工作。
假设正在为一家零售企业构建一个电子商务应用程序,以便在线向客户销售商品。可以从这里克隆完整版本的源代码。
测试类型
在Python 编程中,你的应用程序可能需要的最常见的测试包括但不限于:
- 静态测试
- 单元测试
- 集成测试
静态测试
静态检查可确保我们的代码在执行前能够正确编译。这包括格式检查和语法检查,其中一些可能会被你的 IDE 自动捕获。对于我们的电子商务应用程序,我们可能有一个如下所示的Item类:
fromdataclassesimportdataclass, field importuuid @dataclass classItem: name: str description: str price: int sku: str=field(default_factory=lambda: str(uuid.uuid4))
静态检查将帮助我们识别Item类的price字段中缺少冒号“:”。因此,这在生产环境中永远不会起作用。详细的Item 类可能如下所示。可以使用 Flake8、Pylint 等模块,以及最近构建于 Rust 之上并用于验证 Python 代码的 Ruff,在将 Python 代码合并到生产环境之前进行静态检查。本教程使用了 Ruff。
单元测试
假设开发者已经编写了没有语法错误的良好代码,单元测试可以说是最重要的测试类型。单元测试确保应用程序的各个组件(类和方法/函数)能够独立按预期工作。它们确保应用程序/业务逻辑不被违反。单元测试中使用的两个流行框架是unittest和pytest。我们的单元测试示例将使用unittest模块。
这两个库的工作方式类似,但略有不同。这些模块使用断言进行工作,断言通常应产生 True 或 False 结果。pytest使用原始断言,而unittest模块有自己的断言方法,例如assertEquals、assertIn、assertRaises等。unittest模块还要求我们通过子类化unittest.TestCase来创建测试用例类。
使用 unittest 模块进行单元测试
在我们的电子商务应用程序中,对Item类的一个简单测试是验证创建的商品价格永远不会为负。这可能会给零售企业造成巨大的损失。请参阅下面的测试示例。
importunittest classTestItem(unittest.TestCase): deftest_item_price_cannot_be_negative(self): # our item class should raise a ValueError if the price is below zero withself.assertRaises(ValueError): Item("External SSD", "High-speed storage for data transfer", -5.0)
在业务逻辑之前定义这样的测试是测试驱动开发 (TDD)的一部分。上面的测试使用 unittest 模块运行,只是断言如果我们的 Item 类包含负价格,则会引发ValueError。让我们看看如何使上述测试用例通过。
classItem: """Represents a sample item in an e-commerce system.""" name: str description: str price: int sku: str=field(default_factory=lambda: str(uuid.uuid4)) # Added to ensure our items never have a -ve price. def__post_init__(self): ifself.price
运行测试
要在 Python 中运行我们的 unittest 测试,我们只需键入如下所示的命令。
当我们运行此命令时,unittest 模块会自动查找任何父类为unittest.TestCase的文件夹,并将其函数视为要验证的测试。如果满足断言,测试将通过,否则将失败。
其他常见的 CLI 命令包括:
python -m unittest test_module用于运行模块中的所有测试。
在我们的示例中,这将是:
python -m unittest unit_tests/test_item.py(指向 unit_tests 文件夹中的文件路径)或python -m unittest unit_tests.test_item
其他具体示例可以在项目仓库中找到。请注意,使用 pytest 构建的测试也以类似的方式执行。
集成测试
集成测试可确保我们应用程序的不同组件无缝协作。
这很有用,因为在软件开发过程中,功能通常是逐步实现或增强的。
在我们的电子商务应用程序的案例中,我们构建了一个 ShoppingCart 类以允许用户购买商品。我们的第一个方法显然是添加商品的功能,然后是删除商品的方法。下面显示了我们类的简约版本,但完整版本已在此处实现。
fromdatetimeimportdatetimeasdt fromsrc.itemimportItem importuuid importjson classShoppingCart: """Shopping Cart Class (shortened)""" defadd_item(self, item: Item, quantity: int): # check if item exists in cart , then update ifself.__item_in_cart(item): self.increase_cart_item_quantity(item, quantity) else: # add new item using it's __dict__ property for easy access self.cart_obj[f"{item.sku}"] = { "item": item.__dict__, "quantity": quantity, "added_at": dt.now.strftime("%Y-%m-%d %H:%M:%S.%f"), "updated_at": dt.now.strftime("%Y-%m-%d %H:%M:%S.%f"), } print(f"==>> `{item.name}` Added to Cart.") returnjson.dumps( { "status": ShoppingCartStatus.CART_ITEM_ADDED.value, f"{item.name}": self.cart_obj[f"{item.sku}"], }, indent=4, )
使用 pytest 运行测试
我们可以使用以下命令的单元测试来验证上述方法是否有效:
python -m pytest -k test_add_items_to_cart -v(其中-k搜索与其后模式匹配的测试/文件,-v帮助我们获得更详细的输出。更多详细信息此处)。
deftest_add_items_to_cart(shopping_cart: ShoppingCart, item: Item): shopping_cart.add_item(item, 40)
使用 pytest 进行集成测试
虽然上述测试本身有效,但有必要测试将remove_cart_item函数添加到我们的 ShoppingCart 可以与add_item方法一起正常工作。
我们可以编写此测试,假设我们有一个cart_size属性,它向我们显示购物车中唯一商品的数量。
deftest_single_item_cart_size_is_zero_after_removal( shopping_cart: ShoppingCart, item: Item ): shopping_cart.add_item(item, 40) shopping_cart.remove_cart_item(item) assertshopping_cart.cart_size==0
上述测试验证了在将单个商品添加到购物车并从购物车中移除后,购物车大小应减少到零。这验证了我们的 ShoppingCart 及其方法之间的交互产生了预期的行为。
我们现在可以使用下面的简单命令运行所有测试用例。
python -m pytest
关于 pytest 的注意事项
- 通过运行上述命令,请注意,如果没有明确告诉 pytest 使用哪个文件夹、文件或模式进行测试发现,它将运行目录中的所有测试,包括unittest.TestCase的子类的测试用例。
- Pytest 不需要我们为测试用例定义类。另一方面,Unittest 需要类,因为它最初的灵感来自用于 Java 应用程序的 JUnit 测试框架。
- 有关配置测试的更多信息已在...中提供。源代码库
结论
在 Python 中进行测试有助于减少或完全避免生产环境中不必要的故障。需要注意的是,可以使用 GitHub Actions 等持续集成平台自动运行代码库上的测试。
与任何编程范例一样,几乎不可能测试所有未来在现实场景中可能出现的边缘情况。因此,经过实战检验的软件的部署仍应制定回滚计划,并在可能的情况下分阶段进行,以防万一出现问题。
您是否正在寻找熟练的 Python 专家来帮助您的项目更上一层楼? 那么请查看 Andela 的指南“如何聘请 Python 开发人员”。
本文在云云众生(https://yylives.cc/)首发,欢迎大家访问。
相关推荐
- 直接在手机上刷机软件(用手机给手机刷机的软件)
-
例如使用模拟器就可以第三方的刷机软件,或多或少都是带一点广告的!你要说完全好用的话,只能选奇兔了,奇兔它有专门的ROM移植团队。可以登录它的官网搜索每个品牌的手机的型号都有大神在里面,机型覆盖还是比较...
- 光影app下载(光影app下载正版官方)
-
回答如下:光影是一个Minecraft的模组,可以通过以下步骤下载:1.下载和安装Minecraft的启动器,确保已经安装了Minecraft。2.下载和安装Forge,它是运行Minecraft...
- 十大手游交易平台排行榜(手游交易平台2021前十名)
-
一、咪噜游戏盒子一款时下非常火爆的变态、破解、折扣游戏盒子,为玩家推送变态、无限元宝手游。至尊VIP、海量钻石元宝、独家礼包上线即送,开局你就是土豪。一款专门针对手机游戏爱好者设计推出的福利app平台...
- qq游戏大全(QQ游戏大全列表 百度贴吧)
-
弟弟、牵姐的手一起走--姐姐、牵弟的手一起跑、小小理想--大大梦想、圆规画方--直尺画圆、萎靡开枝的茶--彼岸行走的花、指尖旳太阳--指尖旳月亮、弟、笑着转身--姐、哭着等待、甜甜的、棒棒糖--软软的...
- 笔记本电脑选哪个品牌比较好
-
1、苹果APPLE/美国2、戴尔DELL/美国3、华为HUAWEI/中国4、小米MI/中国5、微软Microsoft/美国6、联想LENOVO/中国7、惠普HP/美国8、华硕ASUS/...
- 10系列显卡排名(10系显卡性能排行)
-
十系显卡指NVIDIAGeForce10系列,是英伟达研发并推出的图形处理器系列,被用以取代NVIDIAGeForce900系列图形处理器。新系列采用帕斯卡微架构来代替之前的麦克斯韦微架构,并...
-
- 最新win7系统下载(windows7最新版本下载)
-
最简单的方法就是,下载完镜像文件后,直接把镜像文件解压,解压到非C盘,然后在解压文件里面找到setup.exe,点击运行即可。安装系统完成后,在C盘找到一个Windows.old(好几个GB,是旧系统打包在这里,垃圾文件了)删除即可。扩展资...
-
2026-01-15 06:43 off999
- 哪个电脑管家软件好用(哪个电脑管家好用些)
-
腾讯电脑管家吧,因为这个是杀毒和管理合一的,占用内存小,因此显得更为简洁,使电脑运行更加流畅此外电脑诊所,工具箱以及4+1的杀毒模式让腾讯电脑管家也收到了广泛的关注4+1杀毒引擎,管家反病毒引擎、金山...
- 怎么进入win7安全模式(怎么进入win7安全模式界面)
-
方法如下:1、首先进入Win7系统,然后使用Win键+R组合键打开运行框,输入“Msconfig”回车进入系统配置。2、在打开的系统配置中,找到“引导”选项,然后单击,选择Win7的引导项,然后在“安...
- 怎么分区固态硬盘(怎样分区固态硬盘)
-
固态硬盘的分区方法与传统机械硬盘基本相同,以下是一个简单的步骤:1.打开磁盘管理工具:在Windows操作系统中,按下Win+X键,选择"磁盘管理"。或者打开控制面板,在"...
-
- 笔记本声卡驱动怎么下载(笔记本如何下载声卡)
-
1、在浏览器中输入并搜索,然后下载并安装。2、安装完成后打开360驱动大师,它就会自动检测你的电脑需要安装或升级的驱动。3、检测完毕后,我们可以看到我们的声卡驱动需要安装或升级,点击安装或升级,就会开始自动安装或升级声卡了。4、升级过程中会...
-
2026-01-15 05:43 off999
- win10加快开机启动速度(加快开机速度 win10)
-
一、启用快速启动功能1.按win+r键调出“运行”在输入框输入“gpedit.msc”按回车调出“组策略编辑器”?2.在“本地组策略编辑器”依次打开“计算机配置——管理模块——系统——关机”在右侧...
-
- excel的快捷键一览表(excel的快捷键一览表超全)
-
Excel快捷键大全的一些操作如下我在工作中经常使用诸如word或Excel之类的办公软件。我相信每个人都不太熟悉这些办公软件的快捷键。使用快捷键将提高办公效率,并使您的工作更加轻松快捷。。例如,在复制时,请使用CtrI+C进行复制,...
-
2026-01-15 05:03 off999
- 华硕u盘启动按f几(华硕u盘装系统按f几进入)
-
F8。1、开机的同时按F8进入BIOS。2、在Boot菜单中,置secure为disabled。3、BootListOption置为UEFI。4、在1stBootPriority中usb—HD...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
Python 批量卸载关联包 pip-autoremove
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
