Python测试框架pytest入门基础(pytest框架搭建)
itomcoil 2025-07-01 20:21 2 浏览
Pytest简介
Pytest is a mature full-featured Python testing tool that helps you write better programs.
The pytest framework makes it easy to write small tests, yet scales to support complex functional testing for applications and libraries.
通过官方网站介绍我们可以了解到,pytest是一个非常成熟的全功能的python测试框架,主要有
以下几个特点:
- 简单灵活易上手
- 支持参数化
- 支持简单的单元测试和复杂的功能测试,还可以用来做自动化测试
- 具有很多第三方插件,并且可以自定义扩展
- 测试用例的skip和xfail处理
- 可以很好的和Jenkins集成
- 支持运行 bynose, unittest编写的测试用例
Pytest安装
1.直接使用pip命令安装
pip install -U pytest # -U是如果已安装会自动升级最新版本
2.验证安装结果
pytest --version # 展示当前安装版本
C:\Users\edison>pytest --version
pytest 6.2.5
3.在pytest测试框架中,要遵循以下约束:
- 测试文件名要符合test_*.py或*_test.py 格式(例如test_min.py)
- 测试类要以Test开头,且不能带有init方法
- 在单个测试类中,可以包含一个或多个test_开头的函数
Pytest测试执行
pytest进行测试比较简单,我们来看一个实例:
import pytest # 导入pytest包
def test_001(): # 函数以test_开头
print("test_01")
def test_002():
print("test_02")
if __name__ == '__main__':
pytest.main(["-v","test_1214.py"]) # 调用pytest的main函数执行测试
这里我们定义了了两个测试函数,直接打印出结果,下面执行测试:
============================= test session starts =============================
platform win32 -- Python 3.8.0, pytest-6.2.5, py-1.11.0, pluggy-1.0.0 -- D:\Code\venv\Scripts\python.exe
cachedir: .pytest_cache
rootdir: D:\Code
collecting ... collected 2 items
test_1214.py::test_001 PASSED [ 50%]
test_1214.py::test_002 PASSED [100%]
============================== 2 passed in 0.11s ==============================
Process finished with exit code 0
输出结果中显示执行了多少条案例、对应的测试模块、通过条数以及执行耗时。
测试类主函数
pytest.main(["-v","test_1214.py"])
通过python代码执行 pytest.main()
1.直接执行pytest.main() 【自动查找当前目录下,以test_开头的文件或者以_test结尾的py文件】
2.设置pytest的执行参数 pytest.main(['--html=./report.html','test_login.py'])【执行test_login.py文件,并生成html格式的报告】
main()括号内可传入执行参数和插件参数,通过[]进行分割,[]内的多个参数通过‘逗号,’进行分割
运行目录及子包下的所有用例 pytest.main(['目录名'])
运行指定模块所有用例 pytest.main(['test_reg.py'])
运行指定模块指定类指定用例 pytest.main(['test_reg.py::TestClass::test_method']) 冒号分割
-m=xxx: 运行打标签的用例
-reruns=xxx:失败重新运行
-q: 安静模式, 不输出环境信息
-v: 丰富信息模式, 输出更详细的用例执行信息
-s: 显示程序中的print/logging输出
--resultlog=./log.txt 生成log
--junitxml=./log.xml 生成xml报告
断言方法
pytest断言主要使用Python原生断言方法,主要有以下几种:
- == 内容和类型必须同时满足相等
- in 实际结果包含预期结果
- is 断言前后两个值相等
import pytest # 导入pytest包
def add(x,y): # 定义以test_开头函数
return x + y
def test_add():
assert add(1,2) == 3 # 断言成功
str1 = "Python,Java,Ruby"
def test_in():
assert "PHP" in str1 # 断言失败
if __name__ == '__main__':
pytest.main(["-v","test_pytest.py"]) # 调用main函数执行测试
============================= test session starts =============================
platform win32 -- Python 3.8.0, pytest-6.2.5, py-1.11.0, pluggy-1.0.0 -- D:\Code\venv\Scripts\python.exe
cachedir: .pytest_cache
rootdir: D:\Code
collecting ... collected 2 items
test_pytest.py::test_add PASSED [ 50%]
test_pytest.py::test_in FAILED [100%]
================================== FAILURES ===================================
___________________________________ test_in ___________________________________
def test_in():
> assert "PHP" in str1
E AssertionError: assert 'PHP' in 'Python,Java,Ruby'
test_pytest.py:11: AssertionError
=========================== short test summary info ===========================
FAILED test_pytest.py::test_in - AssertionError: assert 'PHP' in 'Python,Java...
========================= 1 failed, 1 passed in 0.18s =========================
Process finished with exit code 0
可以看到运行结果中明确指出了错误原因是"AssertionError",因为PHP不在str1中。
常用命令详解
1.运行指定案例
if __name__ == '__main__':
pytest.main(["-v","-s","test_1214.py"])
2.运行当前文件夹包括子文件夹所有用例
if __name__ == '__main__':
pytest.main(["-v","-s","./"])
3.运行指定文件夹(code目录下所有用例)
if __name__ == '__main__':
pytest.main(["-v","-s","code/"])
4.运行模块中指定用例(运行模块中test_add用例)
if __name__ == '__main__':
pytest.main(["-v","-s","test_pytest.py::test_add"])
5.执行失败的最大次数
使用表达式"--maxfail=num"来实现(注意:表达式中间不能存在空格),表示用例失败总数等于num 时停止运行。
6.错误信息在一行展示
在实际项目中如果有很多用例执行失败,查看报错信息将会很麻烦。使用"--tb=line"命令,可以很好解决这个问题。
接口调用
本地写一个查询用户信息的接口,通过pytest来调用,并进行接口断言。
1 # -*- coding: utf-8 -*-
2 import pytest
3 import requests
4
5 def test_agent():
6 r = requests.post(
7 url="http://127.0.0.1:9000/get_user",
8 data={
9 "name": "吴磊",
10 "sex": 1
11 },
12 headers={"Content-Type": "application/json"}
13 )
14 print(r.text)
15 assert r.json()['data']['retCode'] == "00" and r.json()['data']['retMsg'] == "调用成功"
16
17 if __name__ == "__main__":
18 pytest.main(["-v","test_api.py"])
相关推荐
- CentOS7服务器,这样搭建Tensorflow很快!我可以提前去吃饭了
-
CentOS7搭建Tensorflow框架凡是我相信的,我都做了;凡是我做了的事,都是全身心地投入去做的。WhateverIbelieved,Idid;andwhateverIdid,...
- python2.0和python3.0的区别(python2.7和3.7哪个好)
-
Python3.0是Python语言的一次重大升级,与Python2.x系列存在许多不兼容的改动。以下是两者核心区别的全面总结,按重要性和使用频率排序:一、最关键的破坏性变更特性Pyth...
- 体验无GIL的自由线程Python:Python 3.13 新特征之一
-
全局解释器锁(GIL,GlobalInterpreterLock)是Python中备受争议的特性之一。它的主要作用是确保Python是一种线程安全的编程语言,防止多个线程同时访问和修改同一...
- Python 3.8异步并发编程指南(python异步调用)
-
有效的提高程序执行效率的两种方法是异步和并发,Golang,node.js之所以可以有很高执行效率主要是他们的协程和异步并发机制。实际上异步和并发是每一种现代语言都在追求的特性,当然Python也不例...
- Python测试框架pytest入门基础(pytest框架搭建)
-
Pytest简介Pytestisamaturefull-featuredPythontestingtoolthathelpsyouwritebetterprograms.T...
- Python学不会来打我(8)字符串string类型深度解析
-
2025年全球开发者调查显示,90%的Python项目涉及字符串处理,而高效使用字符串可提升代码效率40%。本文系统拆解字符串核心操作,涵盖文本处理、数据清洗、模板生成等八大场景,助你掌握字符串编程精...
- windows使用pyenv安装多python版本环境
-
官方的介绍。pyenvletsyoueasilyswitchbetweenmultipleversionsofPython.It’ssimple,unobtrusive,an...
- Python 中 base64 编码与解码(Python 中 base64 编码与解码生成)
-
base64是经常使用的一种加密方式,在Python中有专门的库支持。本文主要介绍在Python2和Python3中的使用区别:在Python2环境:Python2.7.16(d...
- Python项目整洁的秘诀:深入理解__init__.py文件
-
当你发现项目中import语句越来越混乱时,问题可能出在缺少这个关键文件上作为一名Python开发者,我曾深陷项目结构混乱的困境。直到真正理解了__init__.py文件的价值,我的代码世界才变得井然...
- 如何把一个Python应用程序装进Docker
-
准备容器无处不在,但是如何在Docker容器中运行Python应用程序呢?这篇文章将告诉你怎么做!如果您想知道,这些示例需要Python3.x。在深入讨论容器之前,让我们进一步讨论一下我们想要封装的...
- python中数值比较大小的8种经典比较方法,不允许你还不知道
-
在Python中比较数值大小是基础但重要的操作。以下是8种经典比较方法及其应用场景,从基础到进阶的完整指南:1.基础比较运算符Python提供6种基础比较运算符:a,b=5,3...
- Python程序员必看3分钟掌握if语句10个神技,第5个99%的人不知道
-
同事因为写错一个if被开除?全网疯传的Python避坑指南,看完我连夜改了代码!一、新手必踩的3大天坑(附救命代码)技巧1:缩进踩坑事件ifTrue:print("这样写必报错!...
- 为什么Python里遍历字符串比列表慢?3个底层原因揭秘
-
用字符串处理文本时,你可能正悄悄浪费性能。在日常Python开发中,我们经常需要遍历字符串和列表。但你是否注意过,当处理海量数据时,遍历字符串的速度明显比列表慢?这背后隐藏着Python设计的深层逻辑...
- 记录Python3.7.4更新到Python.3.7.8
-
Python官网Python安装包下载下载文件名称运行后选择升级选项等待安装安装完毕打开IDLE使用Python...
- Python3中最常用的5种线程锁你会用吗
-
前言本章节将继续围绕threading模块讲解,基本上是纯理论偏多。对于日常开发者来讲很少会使用到本章节的内容,但是对框架作者等是必备知识,同时也是高频的面试常见问题。私信小编01即可获取大量Pyth...
- 一周热门
- 最近发表
-
- CentOS7服务器,这样搭建Tensorflow很快!我可以提前去吃饭了
- python2.0和python3.0的区别(python2.7和3.7哪个好)
- 体验无GIL的自由线程Python:Python 3.13 新特征之一
- Python 3.8异步并发编程指南(python异步调用)
- Python测试框架pytest入门基础(pytest框架搭建)
- Python学不会来打我(8)字符串string类型深度解析
- windows使用pyenv安装多python版本环境
- Python 中 base64 编码与解码(Python 中 base64 编码与解码生成)
- Python项目整洁的秘诀:深入理解__init__.py文件
- 如何把一个Python应用程序装进Docker
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)