注:关于pytest的基础要点个人已经总结好了,

一. 启动:

  在主函数main下启动:pytest.main(['-q','test_demo.py'])

  在命令行启动:pytest ./test_demo.py

  按标签启动:pytest -m demo(前提是在pytest.ini里配上了标签)

  在命令行启动多个:pytest test_demo1.py test_demo2.py

  指定目录启动:pytest.main("d:/pyse/pytest/")

  运行模块中指定用例:pytest.main("-v -s spec_001_modul_test.py::test_001_spec")

  运行类中指定用例:pytest.main("-v -s spec_001_modul_test.py::Test_Class::test_003_spec")

  运行模块中包含demo名称的用例:pytest.main("-v -s -k demo test_demo.py")

  运行当前文件夹匹配Test_Class的用例:pytest.main('-s -v -k Test_Class')

  运行规则:pytest 目录/文件::类名::函数名 或者 pytest 目录/文件::函数名

二. 启动参数说明:

  -s: 显示程序中的print/logging输出

  -v: 丰富信息模式, 输出更详细的用例执行信息

  -q: 安静模式, 不输出环境信息,只给结果

  -k:关键字匹配,用and区分:匹配范围(文件名、类名、函数名)

三. setup/teardown:

  setup和teardown函数:运行在每个测试方法的始末

  setup_class和teardown_class函数:运行在类的始末

四. pytest.ini:

  参数最好都放配置文件里,不用再main里放。每个参数见名知意啦~。由于编码问题,配置文件里不要出现中文。

[pytest]

addopts = -v --html=report/report.html
# addopts = -v --html=report/report.html --rerun=1 --count=1
# addopts = -v --alluredir reports/raw_report testpaths = ./
python_files = test_*.py
python_classes = Test*
python_functions = test_*
norecursedirs = .venv log report common data .pytest_cache markers =
l1:level-1 # by priority
l2:level-2
l3:level-3 smoke:smoke test # by test type
integrate:integrate test demo:for demo # by logic
login:login module
upload:upload module
review:review module

五. pytest-html:

  安装它

  用法:配置文件里添加报告参数:addopts = -s --html=./report.html,若要生成xml文件改一下就行

六. pytest-ordering:

  安装它

  用法:函数上面加@pytest.mark.run(order=n)

  优先级:order值全为正数或全为负数时, 值越小,优先级越高;正数和负数同时存在,正数优先级高

七. pytest-rerunfailures:

  安装它

  用法:命令行格式,pytest --reruns n。n为重试的次数;或添加失败重试参数,即:addopts = -s --reruns 2 --html=./report.html

  记住命令行是reruns,最好配置参数

八. fixture:

  功能:通常会被用于完成预置处理和重复操作。如在测试网站的功能时,每个测试用例都要登录和退出,利用fixture就可以只做一次;完成setup和teardown操作,处理数据库或文件的打开、关闭操作;将数据提前写入数据库或通过params返回给测试用例。强大吧!

  pytest.fixture(scope='function', params=None, autouse=False, ids=None, name=None)

  参数解释:

  "scope": 被标记方法的作用域;

  "function": 默认值,表示每个测试方法都要执行一次

  "class": 作用于整个类, 表示每个类的所有测试方法只运行一次

  "module": 作用于整个模块, 每个module的所有测试方法只运行一次.

  "session": 作用于整个session, 每次session只运行一次. ️(此方法慎用!!)

  params: list类型,默认None, 接收参数值,对于param里面的每个值,fixture都会去遍历执行一次.

  autouse: 是否自动运行,默认为false, 为true时此session中的所有测试函数都会调用fixture

  以上的所有参数也可以不传。

  把返回值作为参数使用:某个功能用例上面放@pytest.fixture(),然后该函数名可以作为参数放别的函数里。

  直接使用:@pytest.mark.usefixtures("before")

九. skipif:

  @pytest.mark.skipif(condition, reason=None)

  参数解释:

  condition: 跳过的条件,必传参数

  eason: 标注原因,必传参数

十. xfail:

  @pytest.mark.xfail(condition=None, reason=None, raises=None, run=True, strict=False)

  常用参数:

  condition:预期失败的条件,必传参数

  reason:失败的原因,必传参数

十一. parametrize:

  @pytest.mark.parametrize(argnames,argvalues)

  参数值为N个,测试方法就会运行N次

  常用参数:

  argnames:参数名

  argvalues:

  参数对应值,类型必须为list

  当参数为一个时,参数格式:[value]

  当参数个数大于一个时,格式为:[(param_value1,param_value2.....),(param_value1,param_value2.....)]

十二. 其他:

  不需要在main里面写pytest.main,只要是符合命名,默认为pytest启动,都会自动调用pytest

  如果两个测试函数体里面的内容一样,只会输出一次结果。

  改了哪儿,直接运行后测的就是哪儿。需要重新定位鼠标,一般把改了的测试函数放最后。这条很重要,不然会以为pytest框架有bug,只是写这个框架的人脑回路很奇怪,但这样很方便。

十三. 断言

  即python的断言:

    assert xx:判断xx为真

    assert not xx:判断xx不为真

    assert a in b:判断b包含a

    assert a == b:判断a等于b

    assert a !=b,"判断a不等于b"(加上括号后面有说明)

作者留言

  测试行业里不思进取的人太多了,哪怕整理好他们也不会用,可能觉得没多大用处吧~,此篇花费很长时间整理的,禁止转载否则见底部声明哈!

  原创不易,如果觉得本文对你有帮助,记得打赏噢O(∩_∩)O,您的支持是我创作路上最大的动力~

 

pytest基本使用指南的更多相关文章

  1. ApacheCN Python 译文集 20211108 更新

    Think Python 中文第二版 第一章 编程之路 第二章 变量,表达式,语句 第三章 函数 第四章 案例学习:交互设计 第五章 条件循环 第六章 有返回值的函数 第七章 迭代 第八章 字符串 第 ...

  2. pytest 10 skip跳过测试用例

    pytest.mark.skip可以标记无法在某些平台上运行的测试功能,或者你希望失败的测试功能 skip意味着只有在满足某些条件时才希望测试通过,否则pytest应该跳过运行测试.常见事例时非win ...

  3. pytest八:skip 跳过用例

    这是一个快速指南,介绍如何在不同情况下跳过模块中的测试1.无条件地跳过模块中的所有测试:pytestmark = pytest.mark.skip("all tests still WIP& ...

  4. pytest文档12-skip跳过用例

    前言 pytest.mark.skip可以标记无法在某些平台上运行的测试功能,或者您希望失败的测试功能 skip意味着只有在满足某些条件时才希望测试通过,否则pytest应该跳过运行测试. 常见示例是 ...

  5. Python 最强 IDE 详细使用指南!-PyCharm

    PyCharm 是一种 Python IDE,可以帮助程序员节约时间,提高生产效率.那么具体如何使用呢?本文从 PyCharm 安装到插件.外部工具.专业版功能等进行了一一介绍,希望能够帮助到大家. ...

  6. Pytest权威教程12-跳过(Skip)及预期失败(xFail): 处理不能成功的测试用例

    目录 跳过(Skip)及预期失败(xFail): 处理不能成功的测试用例 Skip跳过用例 xFail:将测试函数标记为预期失败 Skip/xFail参数设置 返回: Pytest权威教程 跳过(Sk ...

  7. 【转载】Python 最强编辑器PyCharm详细使用指南!

    PyCharm 是一种 Python IDE,可以帮助程序员节约时间,提高生产效率.那么具体如何使用呢?本文从 PyCharm 安装到插件.外部工具.专业版功能等进行了一一介绍,希望能够帮助到大家.机 ...

  8. Python 最强 IDE 详细使用指南!

    PyCharm 是一种 Python IDE,可以帮助程序员节约时间,提高生产效率.那么具体如何使用呢?本文从 PyCharm 安装到插件.外部工具.专业版功能等进行了一一介绍,希望能够帮助到大家.作 ...

  9. pytest学习纪要123-针对经常用到的内容详实记录

    pytest123 本文主要参考:https://www.cnblogs.com/yoyoketang/tag/pytest 如有侵权,请站内联系我 目录 pytest123 1.setup和tear ...

  10. Sentry 开发者贡献指南 - 配置 PyCharm

    概述 如果您使用 PyCharm 进行开发,则需要配置一些内容才能运行和调试. 本文档描述了一些对 sentry 开发有用的配置 配置 Python 解释器:(确保它是 venv 解释器)例如 ~/v ...

随机推荐

  1. Django基础笔记2(分页)

    Django Django自带的分页功能 from django.core.paginator import Paginator # 用于分页 curPage = request.GET.get('p ...

  2. Linux 下的输入输出和重定向示例

    Linux 下的输入输出和重定向示例 作者:Grey 原文地址: 博客园:Linux 下的输入输出和重定向示例 CSDN:Linux 下的输入输出和重定向示例 说明 Linux 下的输入输出有如下三种 ...

  3. pycharm恢复删除文档与查询修改前数据

    1.pycharm恢复删除文档 第一步: 第二步: 2.pycharm查询修改前文档数据 第一步: 第二步:

  4. 数据库MySQL(完结)

    SQL注入问题 简介 针对SQL注入的攻击行为可描述为通过用户可控参数中注入SQL语法,破坏原有SQL结构,达到编写程序意料之外结果的攻击行为. 其成因可归结为以下两个原理叠加造成: 程序编写者在处理 ...

  5. 搭建漏洞环境及实战——在Windows系统中安装WAMP

    安装成功之后,打开显示 链接:https://pan.baidu.com/s/1NpU7fUYOO_CSM8dNXKdnCw 提取码:mxvw

  6. css images图片铺满 不变型 以及头像裁剪 属性

    一,图片的引入 background:url(img_flwr.gif); background-repeat:no-repeat; //平铺 二,图片的大小不不变形 background-size: ...

  7. vue 原生js-实现下拉框

    <template> <div class="por"> <div class="selectBox" style="w ...

  8. 8、ThreadPoolTaskExecutor线程并发

    一.线程池的优点: 1.降低资源消耗.通过重复利用自己创建的线程降低线程创建和销毁造成的消耗. 2.提高响应速度.当任务到达时,任务可以不需要等到线程创建就能立即执行. 3.提高线程的可管理性.线程是 ...

  9. vue3学习第一天

    第一章 Options API与Composition API 重写双向绑定 vue2 基于Object.defineProperty()实现 vue3 基于Proxy proxy与Object.de ...

  10. 个别编程语言在OJ平台上的输入输出方式

    OJ 平台输入输出 一. C/ C++ 输入 scanf() gets() getchar() 输出 printf() puts() putchar() C++ cin >> cout & ...