使用Pytest进行单元测试 pytest教程
zhezhongyun 2024-12-16 17:34 75 浏览
PyTest简介
`pytest` 是一个非常流行的 Python 测试框架,提供了简单易用的测试功能。以下是 `pytest` 的基本使用方法:
- 安装 `pytest`
pip install pytest
- 创建测试文件
`pytest` 会自动发现以 `test_` 开头或 `_test` 结尾的文件。你可以创建一个名为 `test_example.py` 的文件。
# test_example.py
def add(a, b):
return a + b
def test_add():
assert add(1, 2) == 3
assert add(-1, 1) == 0
assert add(0, 0) == 0
- 运行测试
在命令行中,导航到包含测试文件的目录,然后运行以下命令:
pytest
`pytest` 会自动查找以 `test_` 开头的测试文件,并执行其中的测试函数。
- 查看测试结果
运行 `pytest` 后,你会看到测试的结果,包括通过的测试和失败的测试。如果测试失败,`pytest` 会提供详细的错误信息,帮助你调试。
- 测试夹具(Fixtures)
`pytest` 还支持测试夹具,用于设置测试环境。可以使用 `@pytest.fixture` 装饰器定义夹具。例如:
import pytest
@pytest.fixture
def sample_data():
return [1, 2, 3]
def test_sum(sample_data):
assert sum(sample_data) == 6
- 参数化测试
你可以使用 `@pytest.mark.parametrize` 来参数化测试函数。例如:
import pytest
@pytest.mark.parametrize("a, b, expected", [
(1, 2, 3),
(-1, 1, 0),
(0, 0, 0)
])
def test_add(a, b, expected):
assert add(a, b) == expected
- 运行特定测试
如果你只想运行特定的测试,可以使用以下命令:
pytest -k "test_add"
- 生成测试报告
你还可以生成测试报告,比如 HTML 格式的报告。首先安装 `pytest-html`:
pip install pytest-html
然后运行测试并生成报告:
pytest --html=report.html
`pytest` 是一个功能强大且灵活的测试框架,适合用于单元测试和集成测试。通过上述方法,你可以快速上手并编写测试用例。
实践
这里有一个基于Alchemy 访问MySQL的类,要对其中的方法进行测试,使用pytest输出测试报告。写了三个单元测试文件,应用了夹具和参数进行测试,最终的结果如下:
测试代码如下:
# hanzi_test.py
import os
import sys
# 添加当前文件所在目录到Python路径中
current_dir = os.path.dirname(os.path.abspath(__file__))
sys.path.append(current_dir)
# 添加包的父目录到Python路径中
parent_dir = os.path.dirname(current_dir)
sys.path.append(parent_dir)
from interface.mysql.db_dictation.service.HanziService import HanziService
from interface.mysql.db_dictation.entity.Hanzi import Hanzi
def test_hanzi():
obj = HanziService()
res = obj.getByHanzi('好')
for itm in res:
assert itm.f_hanzi == '好'
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
def test_hanzi_pinyin():
obj = HanziService()
res = obj.getByHanziAndPinyin('好', 'hào')
assert res.f_hanzi == '好'
assert res.f_pinyin == 'hào'
itm = res
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
def test_pinyin():
obj = HanziService()
res = obj.getByPinyin('hào')
for itm in res:
assert itm.f_pinyin == 'hào'
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
# fixture_test.py
import os
import sys
# 添加当前文件所在目录到Python路径中
current_dir = os.path.dirname(os.path.abspath(__file__))
sys.path.append(current_dir)
# 添加包的父目录到Python路径中
parent_dir = os.path.dirname(current_dir)
sys.path.append(parent_dir)
import pytest
@pytest.fixture
def getObj():
from interface.mysql.db_dictation.service.HanziService import HanziService
from interface.mysql.db_dictation.entity.Hanzi import Hanzi
return HanziService()
def test_fixture_hanzi(getObj):
res = getObj.getByHanzi('好')
for itm in res:
assert itm.f_hanzi == '好'
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
def test_fixture_hanzi_pinyin(getObj):
res = getObj.getByHanziAndPinyin('好', 'hào')
assert res.f_hanzi == '好'
assert res.f_pinyin == 'hào'
itm = res
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
def test_fixture_pinyin(getObj):
res = getObj.getByPinyin('hào')
for itm in res:
assert itm.f_pinyin == 'hào'
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
# parametrize_test.py
import os
import sys
# 添加当前文件所在目录到Python路径中
current_dir = os.path.dirname(os.path.abspath(__file__))
sys.path.append(current_dir)
# 添加包的父目录到Python路径中
parent_dir = os.path.dirname(current_dir)
sys.path.append(parent_dir)
from interface.mysql.db_dictation.service.HanziService import HanziService
from interface.mysql.db_dictation.entity.Hanzi import Hanzi
import pytest
@pytest.mark.parametrize("hanzi, pinyin, expected", [
('好', 'hào','好'),
('耗', 'hào','耗'),
('浩', 'hào','浩'),
('颢', 'hào','颢'),
])
def test_parametrize_hanzi(hanzi,pinyin,expected):
obj = HanziService()
res = obj.getByHanzi(hanzi)
for itm in res:
assert itm.f_hanzi == expected
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
@pytest.mark.parametrize("hanzi, pinyin, expected", [
('好', 'hào','好'),
('耗', 'hào','耗'),
('浩', 'hào','浩'),
('颢', 'hào','颢'),
])
def test_parametrize_hanzi_pinyin(hanzi,pinyin,expected):
obj = HanziService()
res = obj.getByHanziAndPinyin(hanzi, pinyin)
assert res.f_hanzi == hanzi
assert res.f_pinyin == pinyin
itm = res
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
@pytest.mark.parametrize("hanzi, pinyin, expected", [
('好', 'hào','好'),
('耗', 'hào','耗'),
('浩', 'hào','浩'),
('颢', 'hào','颢'),
])
def test_parametrize_pinyin(hanzi,pinyin,expected):
obj = HanziService()
res = obj.getByPinyin(pinyin)
for itm in res:
assert itm.f_pinyin == pinyin
print(f"{itm.f_hanzi} {itm.f_pinyin} {itm.f_meaning} {itm.f_sound_url} {itm.f_writing_url}")
参考文章:
- Python技术架构 https://www.toutiao.com/article/7422119050685334054/
- PyTest : https://docs.pytest.org/en/stable/index.html
相关推荐
- DevExpress使用教程:GridView经验小结
-
下面是笔者自己总结的使用DevExpressGridview的一些经验小结,分享给大家:1、去除GridView头上的"Dragacolumnheaderheretogroup...
- ComponentOne 新版本发布,新增 .NET 6 和 Blazor 平台控件支持
-
ComponentOneEnterprise是葡萄城推出的一款内置300多种开发控件的.NET控件集,可满足WinForm、WPF、Blazor、ASP.NETMVC等平台下的系统开发...
- Wijmo5 Flexgrid基础教程:数据绑定
-
WijmoEnterprise下载>FlexGrid在JavaScript程序中启动添加Wijmo引用;添加wijmo控件的扩展;在JavaScript中初始化wijmo控件;(可选)添加cs...
- Wijmo5 Flexgrid基础教程:InlineEdit
-
WijmoEnterprise下载>对于flexgrid,可以直接在单元格内进行编辑。但另外还有一种编辑方式,即在一行添加按钮,统一的编辑和提交数据。本文主要介绍给flexgrid添加编辑按钮...
- WinForms Data Grid控件升级(winform devexpress控件)
-
告诉大家一个好消息:慧都将于近期隆重推出“DevExpress14.2新版发布会”。心动不如行动,赶快报名吧!我们期待与您相约DevExpress14.2新版发布会。>>新增Wind...
- XAML控件宽度为另一控件的一半、静态属性绑定
-
控件上当某些数据需要根据其他数据的变化而变化很多时候,想让某个控件的宽度或者高度是另一个已有控件的一半,一开始打算使用ObjectDataProvider来实现,因为在控件上当某些数据需要根据其他数据...
- 用 CSS Grid 布局制作一个响应式柱状图
-
最新一段时间比较喜欢玩弄图表,出于好奇,我想找出比较好的用CSS制作图表的方案。开始学习网上开源图表库,它对我学习新的和不熟悉的前端技术很有帮助,比如这个:CSSGrid。今天和大家分享我学到的...
- Grid 移动端双列瀑布流(移动端瀑布流布局)
-
预览图:原理合理使用Grid的属性:display:设置为grid指明当前容器为Grid布局grid-template-columns:定义每一列的列宽(百分比或绝对单位)grid-templa...
- DevExpress导出GridControl控件数据
-
前言:使用C#做桌面应用时,我们会常常使用Winform作为我们的开发界面,但是windows自带的控件由于长时间不更新,已经不能够满足当前开发需要所以使用DevExpress控件作为Winform...
- css grid 布局的那些事儿(css grid布局和flex布局)
-
CSSGrid是一种为Web开发创建网站布局的方式。它已经存在了很多年,随着更多浏览器的支持,它终于变得越来越流行。接下来我们将了解下CSSGrid及其工作原理。了解下它如何使用。CSS...
- Grid.js - 跨框架的前端表格插件(前端table框架)
-
只想简简单单画个表格,但React,Vue,Angular,…,这么多前端框架,各自都有不同的表格渲染库。就没有表格库能“一次画表,到处运行”吗?来看看Grid.js这个跨框架的前端表格插件吧!...
- WPF开发教程01-布局控件(wpf tablecontrol控件)
-
布局控件是用于进行控件布局的容器类控件,其内部控件按照一定规律自动排列,且在父控件改变大小时,会自动适应。常用布局控件如下:1.一维布局控件(StackPanel)其内部控件按照某个维度自动排列,排...
- wxPython - 高级控件之表格Grid(wxpython grid刷新数据)
-
实战wxPython系列-043wx.grid.Grid及其相关类用于显示和编辑表格数据。它们提供了一组丰富的功能,用于显示、编辑和与各种数据源交互。wx.grid.Grid是一个功能强大的但是又稍微...
- 前端 BFC、IFC、GFC 和 FFC,这些你都知道吗?
-
如果觉得我的文章不错,可以关注我,想要看其他的进阶知识可以查看我发布过的文章!编辑搜图请点击输入图片描述BFC(Blockformattingcontexts):块级格式上下文页面上的一个隔离的...
- 20多个好用的 Vue 组件库,请查收
-
在本文中,我们将探讨一些最常见的vuejs组件。你可以收藏一波。VueTables-2地址:https://github.com/matfish2/vue-tables-2VueTables2...
- 一周热门
- 最近发表
-
- DevExpress使用教程:GridView经验小结
- ComponentOne 新版本发布,新增 .NET 6 和 Blazor 平台控件支持
- Wijmo5 Flexgrid基础教程:数据绑定
- Wijmo5 Flexgrid基础教程:InlineEdit
- WinForms Data Grid控件升级(winform devexpress控件)
- XAML控件宽度为另一控件的一半、静态属性绑定
- 用 CSS Grid 布局制作一个响应式柱状图
- Grid 移动端双列瀑布流(移动端瀑布流布局)
- DevExpress导出GridControl控件数据
- css grid 布局的那些事儿(css grid布局和flex布局)
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML常用标签 (29)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- HTML button formtarget 属性 (30)
- CSS 水平对齐 (Horizontal Align) (30)