如果你还想从头学起Pytest,可以看看这个系列的文章哦!

https://www.cnblogs.com/poloyy/category/1690628.html

前言

  • pytest.mark.skip  可以标记无法在某些平台上运行的测试功能,戒者您希望失败的测试功能
  • 希望满足某些条件才执行某些测试用例,否则pytest会跳过运行该测试用例
  • 实际常见场景:跳过非Windows平台上的仅Windows测试,或者跳过依赖于当前不可用的外部资源(例如数据库)的测试

@pytest.mark.skip

跳过执行测试用例,有可选参数reason:跳过的原因,会在执行结果中打印

#!/usr/bin/env python
# -*- coding: utf-8 -*- """
__title__ =
__Time__ = 2020/4/9 13:49
__Author__ = 小菠萝测试笔记
__Blog__ = https://www.cnblogs.com/poloyy/
"""
import pytest @pytest.fixture(autouse=True)
def login():
print("====登录====") def test_case01():
print("我是测试用例11111") @pytest.mark.skip(reason="不执行该用例!!因为没写好!!")
def test_case02():
print("我是测试用例22222") class Test1: def test_1(self):
print("%% 我是类测试用例1111 %%") @pytest.mark.skip(reason="不想执行")
def test_2(self):
print("%% 我是类测试用例2222 %%") @pytest.mark.skip(reason="类也可以跳过不执行")
class TestSkip:
def test_1(self):
print("%% 不会执行 %%")

执行结果

知识点

  • @pytest.mark.skip 可以加在函数上,类上,类方法上
  • 如果加在类上面,类里面的所有测试用例都不会执行
  • 以上小案例都是针对:整个测试用例方法跳过执行,如果想在测试用例执行期间跳过不继续往下执行呢?

pytest.skip()函数基础使用

作用:在测试用例执行期间强制跳过不再执行剩余内容

类似:在Python的循环里面,满足某些条件则break 跳出循环

def test_function():
n = 1
while True:
print(f"这是我第{n}条用例")
n += 1
if n == 5:
pytest.skip("我跑五次了不跑了")

执行结果

pytest.skip(msg="",allow_module_level=False)

当 allow_module_level=True 时,可以设置在模块级别跳过整个模块

#!/usr/bin/env python
# -*- coding: utf-8 -*- """
__title__ =
__Time__ = 2020/4/9 13:49
__Author__ = 小菠萝测试笔记
__Blog__ = https://www.cnblogs.com/poloyy/
"""
import sys
import pytest if sys.platform.startswith("win"):
pytest.skip("skipping windows-only tests", allow_module_level=True) @pytest.fixture(autouse=True)
def login():
print("====登录====") def test_case01():
print("我是测试用例11111")

执行结果

collecting ...
Skipped: skipping windows-only tests
collected 0 items / 1 skipped ============================= 1 skipped in 0.15s ==============================

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

作用:希望有条件地跳过某些测试用例

注意:condition需要返回True才会跳过

@pytest.mark.skipif(sys.platform == 'win32', reason="does not run on windows")
class TestSkipIf(object):
def test_function(self):
print("不能在window上运行")

执行结果

collecting ... collected 1 item

07skip_sipif.py::TestSkipIf::test_function SKIPPED                       [100%]
Skipped: does not run on windows ============================= 1 skipped in 0.04s ==============================

跳过标记

  • 可以将 pytest.mark.skip 和 pytest.mark.skipif 赋值给一个标记变量
  • 在不同模块之间共享这个标记变量
  • 若有多个模块的测试用例需要用到相同的 skip 或 skipif ,可以用一个单独的文件去管理这些通用标记,然后适用于整个测试用例集
# 标记
skipmark = pytest.mark.skip(reason="不能在window上运行=====")
skipifmark = pytest.mark.skipif(sys.platform == 'win32', reason="不能在window上运行啦啦啦=====") @skipmark
class TestSkip_Mark(object): @skipifmark
def test_function(self):
print("测试标记") def test_def(self):
print("测试标记") @skipmark
def test_skip():
print("测试标记")

执行结果

collecting ... collected 3 items

07skip_sipif.py::TestSkip_Mark::test_function SKIPPED                    [ 33%]
Skipped: 不能在window上运行啦啦啦===== 07skip_sipif.py::TestSkip_Mark::test_def SKIPPED [ 66%]
Skipped: 不能在window上运行===== 07skip_sipif.py::test_skip SKIPPED [100%]
Skipped: 不能在window上运行===== ============================= 3 skipped in 0.04s ==============================

pytest.importorskip( modname: str, minversion: Optional[str] = None, reason: Optional[str] = None )

作用:如果缺少某些导入,则跳过模块中的所有测试

参数列表

  • modname:模块名
  • minversion:版本号
  • reasone:跳过原因,默认不给也行
pexpect = pytest.importorskip("pexpect", minversion="0.3")

@pexpect
def test_import():
print("test")

执行结果一:如果找不到module

Skipped: could not import 'pexpect': No module named 'pexpect'
collected 0 items / 1 skipped

执行结果一:如果版本对应不上

Skipped: module 'sys' has __version__ None, required is: '0.3'
collected 0 items / 1 skipped

最新文章

  1. python select网络编程详细介绍
  2. ABP源码分析三十五:ABP中动态WebAPI原理解析
  3. 如果没有Visual Studio 2015,我们如何创建.NET Core项目 ?
  4. js(function(){alert(‘’‘)})
  5. 用CSS变形创建圆形导航
  6. 转:struts标签之select详解
  7. Request.RequestContext.RouteData.Values获取不到参数值
  8. XML和JSON 序列化以及DataTable转JSON
  9. HADOOP都升级到2.5啦~~~
  10. MyEclipseアンロックの手順
  11. HPQC HP Quality Center windows 服务
  12. 浅谈redux-form在项目中的运用
  13. UML之协作图
  14. js分析 快速定位 js 代码, 还原被混淆压缩的 js 代码
  15. OSWatcher使用过程中小问题解决方法
  16. 007 使用SpringMVC开发restful API五--异常处理
  17. [原]eclipse + pydev :Error in sitecustomize; set PYTHONVERBOSE for tracaeback: KeyError: 'sitecustomize'
  18. 手游开发之lua的table 元表的运用
  19. openssl windows 生成公钥与私钥
  20. Excel 函数集(使用过的)

热门文章

  1. Windows环境下docker的安装与配置
  2. Unity 相机平移、旋转、缩放
  3. 在Tomcat上发布Web项目的方式
  4. C++类的详解
  5. Docker极简部署Kafka+Zookeeper+ElasticStack
  6. vs2017打包exe安装包
  7. Win2012+Nginx+IIS+xxfpm(服务版)
  8. ipadmini从9.3.5降级8.4.1并完美越狱
  9. 简单认识并使用JavaScript【供后端人员作为了解】
  10. Linux 应用领域