前面一篇讲到用例加setup和teardown可以实现在测试用例之前或之后加入一些操作,但这种是整个脚本全局生效的,如果我想实现以下场景:
用例1需要先登录,用例2不需要登录,用例3需要先登录。很显然这就无法用setup和teardown来实现了。这就是本篇学习的目的,自定义测试用例的预置条件

fixture优势

1.firture相对于setup和teardown来说应该有以下几点优势

  • 命名方式灵活,不局限于setup和teardown这几个命名
  • conftest.py 配置里可以实现数据共享,不需要import就能自动找到一些配置
  • scope="module" 可以实现多个.py跨文件共享前置
  • scope="session" 以实现多个.py跨文件使用一个session来完成多个用例
  1. fixture(scope="function", params=None, autouse=False, ids=None, name=None):
  2. """使用装饰器标记fixture的功能
  3.  
  4. 可以使用此装饰器(带或不带参数)来定义fixture功能。 fixture功能的名称可以在以后使用
  5. 引用它会在运行测试之前调用它:test模块或类可以使用pytest.mark.usefixtures(fixturename标记。
  6. 测试功能可以直接使用fixture名称作为输入参数,在这种情况下,夹具实例从fixture返回功能将被注入。
  7.  
  8. :arg scope: scope 有四个级别参数 "function" (默认), "class", "module" or "session".
  9.  
  10. :arg params: 一个可选的参数列表,它将导致多个参数调用fixture功能和所有测试使用它
  11.  
  12. :arg autouse: 如果为True,则为所有测试激活fixture func 可以看到它。 如果为False(默认值)则显式需要参考来激活fixture
  13.  
  14. :arg ids: 每个字符串id的列表,每个字符串对应于params 这样他们就是测试ID的一部分。 如果没有提供ID它们将从params自动生成
  15.  
  16. :arg name: fixture的名称。 这默认为装饰函数的名称。 如果fixture在定义它的同一模块中使用,夹具的功能名称将被请求夹具的功能arg遮蔽; 解决这个问题的一种方法是将装饰函数命名
  17. “fixture_ <fixturename>”然后使用”@ pytest.fixture(name ='<fixturename>')“”。
  1.  

Fixtures可以选择使用yield语句为测试函数提供它们的值,而不是return。 在这种情况下,yield语句之后的代码块作为拆卸代码执行,而不管测试结果如何。fixture功能必须只产生一次

fixture参数传入(scope="function")

1.实现场景:用例1需要先登录,用例2不需要登录,用例3需要先登录

  1. # coding:utf-8
  2. import pytest, requests
  3.  
  4. # 不带参数时默认scope="function"
  5.  
  6. s = requests.session()
  7. @pytest.fixture()
  8. def login():
  9. url = "https://xxxxx/global/do-login.action"
  10. body = {
  11. 'loginName': '账号',
  12. 'password': 111111,
  13. 'pcCodeForFocusMedia': 0
  14. }
  15. data = s.post(url, data=body, verify=False)
  16. print(data.json())
  17.  
  18. def test_s1(login):
  19. url = "https://xxxxx/global/login-entry.action"
  20. body = {
  21. "tenantId": 337503,
  22. "passport.id": 833365,
  23. }
  24. data = s.post(url, data=body, verify=False)
  25. print(data.json())
  26.  
  27. def test_s2(): # 不传login
  28. print("用例2:不需要登录,操作222")
  29.  
  30. def test_s3(login):
  31. url = "https://xxxxx/global/login-entry.action"
  32. body = {
  33. "tenantId": 337504,
  34. "passport.id": 833366,
  35. }
  36. data = s.post(url, data=body, verify=False)
  37. print(data.json())
  38.  
  39. if __name__ == "__main__":
  40. pytest.main(["-s", "learn_04.py"])

运行结果:

  1. D:\Users\18630\AppData\Local\Programs\Python\Python36\python3.exe E:/Programs/ke4/pytest/learn_04.py
  2. ============================= test session starts =============================
  3. platform win32 -- Python 3.6.4, pytest-3.8.0, py-1.6.0, pluggy-0.7.1
  4. rootdir: E:\Programs\ke4\pytest, inifile:
  5. collected 3 items
  6.  
  7. learn_04.py {'status': 202, 'statusText': '成功', 'data': {'userid': 833365}} # login执行结果
  8. {'status': 0, 'focusMediaError': '', 'statusText_resourceKey': 'common.success', 'statusText_resourceKey_params': [], 'statusText': '成功', 'data': ''}
  9. .用例2:不需要登录,操作222
  10. .{'status': 202, 'statusText': '成功', 'data': {'userid': 833365}} # login执行结果
  11. {'status': 0, 'focusMediaError': '', 'statusText_resourceKey': 'common.success', 'statusText_resourceKey_params': [], 'statusText': '成功', 'data': ''}
  12.  
  13. ==================== 3 passed, 4 warnings in 3.07 seconds =====================
  14.  
  15. Process finished with exit code 0

2.如果@pytest.fixture()里面没有参数,那么默认scope="function",也就是此时的级别的function,针对函数有效

conftest.py配置

1.上面一个案例是在同一个.py文件中,多个用例调用一个登陆功能,如果有多个.py的文件都需要调用这个登陆功能的话,那就不能把登陆写到用例里面去了。
此时应该要有一个配置文件,单独管理一些预置的操作场景,pytest里面默认读取conftest.py里面的配置

conftest.py配置需要注意以下点:

  • conftest.py配置脚本名称是固定的,不能改名称
  • conftest.py与运行的用例要在同一个pakage下,并且有__init__.py文件
  • 不需要import导入 conftest.py,pytest用例会自动查找

2.参考脚本代码设计如下

  1. __init__.py
  2. conftest.py
  1. import pytest, requests
  2.  
  3. s = requests.session()
  4. @pytest.fixture()
  5. def login():
  1. url = "https://xxxxx/global/do-login.action"
  2. body = {
  3. 'loginName': '账号',
  4. 'password': 111111,
  5. 'pcCodeForFocusMedia': 0
  6. }
  7. data = s.post(url, data=body, verify=False)
  8. print(data.json())
  1. learn_06.py

  1. # coding:utf-8
  2. import pytest, requests
  3.  
  4. # 不带参数时默认scope="function"
  5. s = requests.session()
  6.  
  7. def test_s1(login):
  1. url = "https://xxxxx/global/login-entry.action"
  2. body = {
  3. "tenantId": 337503,
  4. "passport.id": 833365,
  5. }
  6. data = s.post(url, data=body, verify=False)
  7. print(data.json())
  1. def test_s2(): # 不传login
      print("用例2:不需要登录,操作222")
  2.  
  3. def test_s3(login):
       url = "https://xxxxx/global/login-entry.action"
       body = { "tenantId": 337504, "passport.id": 833366, }
       data = s.post(url, data=body, verify=False)
       print(data.json())
  4.  
  5. if __name__ == "__main__":
       pytest.main(["-s", "learn_06.py"])

运行结果:

  1. D:\Users\18630\AppData\Local\Programs\Python\Python36\python3.exe E:/Programs/ke4/pytest/learn_04.py
  2. ============================= test session starts =============================
  3. platform win32 -- Python 3.6.4, pytest-3.8.0, py-1.6.0, pluggy-0.7.1
  4. rootdir: E:\Programs\ke4\pytest, inifile:
  5. collected 3 items
  6.  
  7. learn_04.py {'status': 202, 'statusText': '成功', 'data': {'userid': 833365}} # login执行结果
  8. {'status': 0, 'focusMediaError': '', 'statusText_resourceKey': 'common.success', 'statusText_resourceKey_params': [], 'statusText': '成功', 'data': ''}
  9. .用例2:不需要登录,操作222
  10. .{'status': 202, 'statusText': '成功', 'data': {'userid': 833365}} # login执行结果
  11. {'status': 0, 'focusMediaError': '', 'statusText_resourceKey': 'common.success', 'statusText_resourceKey_params': [], 'statusText': '成功', 'data': ''}
  12.  
  13. ==================== 3 passed, 4 warnings in 3.07 seconds =====================
  14.  
  15. Process finished with exit code 0
  1.  

3.单独运行learn_06.py能调用到login()方法,这样就能实现一些公共的操作可以单独拿出来了

作者:含笑半步颠√

博客链接:https://www.cnblogs.com/lixy-88428977

声明:本文为博主学习感悟总结,水平有限,如果不当,欢迎指正。如果您认为还不错,欢迎转载。转载与引用请注明作者及出处。

pytest_05_fixture之conftest.py的更多相关文章

  1. pytest进阶之conftest.py

    前言 前面几篇随笔基本上已经了解了pytest 命令使用,收集用例,finxture使用及作用范围,今天简单介绍一下conftest.py文件的作用和实际项目中如是使用此文件! 实例场景 首先们思考这 ...

  2. pytest自动化3:fixture之conftest.py实现setup

    出处:https://www.cnblogs.com/yoyoketang/p/9390073.html 前言: 前面一篇讲到用例加setup和teardown可以实现在测试用例之前或之后加入一些操作 ...

  3. pytest 3.fixture介绍一 conftest.py

    前言: 前面一篇pytest2 讲到用例加setup和teardown可以实现在测试用例之前或之后加入一些操作,但这种是整个脚本全局生效的,如果我想实现以下场景: 用例1需要先登录,用例2不需要登录, ...

  4. pytest文档5-fixture之conftest.py

    前言 前面一篇讲到用例加setup和teardown可以实现在测试用例之前或之后加入一些操作,但这种是整个脚本全局生效的,如果我想实现以下场景: 用例1需要先登录,用例2不需要登录,用例3需要先登录. ...

  5. pytest5-使用conftest.py实现多文件共享fixture

    一个测试工程下是可以有多个conftest.py的文件,一般在工程根目录放一个conftest.py起到全局作用.在不同的测试子目录也可以放conftest.py,作用范围只在该层级以及以下目录生效. ...

  6. pytest执行用例时从conftest.py抛出ModuleNotFoundError:No module named 'XXX'异常的解决办法

    一.问题描述 在项目根目录下执行整个测试用例,直接从conftest.py模块中抛出了ModuleNotFoundError:No module named 'TestDatas'的异常: 二.解决方 ...

  7. conftest.py作用范围

    前言 一个测试工程下是可以有多个conftest.py的文件,一般在工程根目录放一个conftest.py起到全局作用.在不同的测试子目录也可以放conftest.py,作用范围只在该层级以及以下目录 ...

  8. pytest-fixture之conftest.py

    场景: 对于一个py文件中某些用例需要前置条件,某些用例不需要前置条件的情况,使用setup/teardown肯定是不方便的, 这时就需要自定义测试用例的前置条件. 1.fixture优点: 命名不局 ...

  9. Pytest系列(6) - conftest.py的详细讲解

    如果你还想从头学起Pytest,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1690628.html 什么是conftest.py 可以 ...

随机推荐

  1. Map、Set、List是否有序

    首先我们应该清楚这个概念:这里的有序和无序不是指集合中的排序,而是是否按照元素添加的顺序来存储对象. list是按照元素的添加顺序来存储对象的,因此是有序的.他的实现类ArrayList.Linked ...

  2. pytorch数据加载

    一.方法一数据组织形式dataset_name----train----val from torchvision import datasets, models, transforms # Data ...

  3. mysql(五)执行计划

    参考文档 http://blog.itpub.net/12679300/viewspace-1394985/

  4. JVM探究之 —— 垃圾回收(二)

    1. 垃圾收集算法 1.1 标记清除(Mark-Sweep)算法 标记—清除算法是第一种使用和比较完善的垃圾回收算法,后续的收集算法都是基于其设计思路并对其不足进行改进而得到的. 该算法分为“标记”和 ...

  5. Keras split train test set when using ImageDataGenerator

    Keras split train test set when using ImageDataGenerator I have a single directory which contains su ...

  6. 《自然语言理解(Natural Language Understanding)》(2016-03-17)阅读笔记

    原文链接:https://yq.aliyun.com/articles/8301 作者:李永彬 发布时间:2016-03-17 16:37:47 自然语言理解(Natural Language Und ...

  7. ImportError: this is MySQLdb version (1, 2, 5, 'final', 1), but _mysql is version (1, 4, 4, 'final', 0)

    (flask-demo) ➜ flask-demo git:(master) ✗ pip install mysqlclient==1.2.5 DEPRECATION: Python 2.7 will ...

  8. 巧用List.stream()方法对List做处理

    List.steam()的强大之处在此不做赘述. 直接进入主题: 1.过滤Bean List中,某些字段等于指定值的所有行 List<Member> list = itemsArray.t ...

  9. centos 6.8操作系统安装arcgis server 10.4-后续篇

    ./Setup //执行安装 (运行安装脚本后会进行安装环境检测,会检查检查软件包和主机名,检测通过才可以开始安装.)如果检查不通过,会提示和报错,并中断安装过程.(1) 解决 hostname 问题 ...

  10. CSAGAN:LinesToFacePhoto: Face Photo Generation from Lines with Conditional Self-Attention Generative Adversarial Network - 1 - 论文学习

    ABSTRACT 在本文中,我们探讨了从线条生成逼真的人脸图像的任务.先前的基于条件生成对抗网络(cGANs)的方法已经证明,当条件图像和输出图像共享对齐良好的结构时,它们能够生成视觉上可信的图像.然 ...