一、相同测试数据存放优化

在讲 fixture 实现机制之前,插入一段内容

上次有个小伙伴问我说,类似下面的用例代码情况,每条测试用例的数据都一样的,我们可以怎么进行优化吗?

当然是可以的

其实我们可以把这些用例的数据全部拿出来用列表的形式存放在datas,里面,然后遍历每一条数据进行判断

import pytest
from Day18_pytest_fixture.login import login_check datas = [
{"user":'python37', "passwd": 'lemonban', "check": {"code": 0, "msg": "登录成功"} },
{"user":'python37', "passwd": 'lemonban666', "check": {"code": 1, "msg": "账号或密码不正确"} },
{"user": 'python370', "passwd": 'lemonban', "check": {"code": 1, "msg": "账号或密码不正确"}},
{"user": None, "passwd": 'lemonban', "check": {"code": 1, "msg": "所有的参数不能为空"}},
{"user": 'python37', "passwd": None, "check": {"code": 1, "msg": "所有的参数不能为空"}}
]

# 第二步遍历每一条数据然后进行判断:
# 这种方法不太友好——只会执行一条用例,而且用例失败了就不能往下继续执行
# ——解决方法:pytest 框架自带的解决方法:@pytest.mark.parametrize("参数名",列表数据)
# class TestLogin:
# def test_login_success(self):
# for data in datas:
# actual = login_check(data["user"],data["passwd"])
# assert actual == data["check"]
# 解决:第二步遍历每一条数据然后进行判断的问题 class TestLogin: @pytest.mark.parametrize("case",datas) # 解决:第二步遍历每一条数据然后进行判断的问题
def test_login(self,case): #这里的case 要与上面装饰器的case 保持一致
actual = login_check(case["user"], case["passwd"])
assert actual == case["check"]

  

二、fixture 实现机制

通过@pytest.fixture 装饰器来定义fixture 。一个函数被@pytest.fixture 装饰,那么这个函数就是fixture。

使用fixture 时,分为两个部分: fixture 定义、fixture 调用。

除此之外,还有fixture 的共享机制,嵌套调用机制。

1、定义fixture

(1)fixture 通过函数实现

(2)使用@pytest.fixture 进行装饰

import pytest

@pytest.fixture
def init():
pass

2、fixture 的调用

在fixture定义好之后,可以明确:

1)fixture 处理了哪些前置准备工作、哪些后置清理工作

2)fixture 作用域(是测试函数?还是测试类,还是测试回话,还是测试模块?)

但是,注意一般情况下我们不会放在类里面去使用,一般是放在模块或者类外面使用的

 # (2)函数前面,要用@pytest.fixture来声明它是一个fixture
# autouse=True ——》有表示类下面的每条用例都会执行,没有表示整个类只执行一次, scope="class" : 表示设置作用域
@pytest.fixture(scope="class", autouse=True)
# (1)自定义一个函数名
def hello(self):
# 前置准备工作的代码
print("一条测试用例开始执行")
yield # yield之前的代码为:前置工作,yield之后的代码为:后置工作
# 后置清理工作的代码
print("一条测试用例执行结束")

  import pytest

from Day18_pytest_fixture.login import login_check

datas = [
{"user":'python37', "passwd": 'lemonban', "check": {"code": 0, "msg": "登录成功"} },
{"user":'python37', "passwd": 'lemonban666', "check": {"code": 1, "msg": "账号或密码不正确"} },
{"user": 'python370', "passwd": 'lemonban', "check": {"code": 1, "msg": "账号或密码不正确"}},
{"user": None, "passwd": 'lemonban', "check": {"code": 1, "msg": "所有的参数不能为空"}},
{"user": 'python37', "passwd": None, "check": {"code": 1, "msg": "所有的参数不能为空"}}
] # @pytest.fixture(scope="class",autouse=True)
@pytest.fixture(scope="class")
# (1)自定义一个函数名
def hello():# self 可以不要了,因为我们不是放在类里面了
# 前置准备工作的代码
print("一条测试用例开始执行")
print("======================================")
yield # yield之前的代码为:前置工作,yield之后的代码为:后置工作
# 后置清理工作的代码
print("一条测试用例执行结束") #可以同时调用多个
# @pytest.fixture(scope="class")
# def class_fix():
# # 前置准备工作的代码
# print("-----测试类下的用例开始执行------")
# yield
# # 后置清理工作的代码
# print("-----测试类下的用例执行结束------") #函数名可以随便取
# @pytest.mark.usefixtures("class_fix") # 调用函数名为class_fix的fixture.

@pytest.mark.usefixtures("hello") # 调用函数名为hello的fixture.,注意函数名不要写错了,写错了就会报错,因为程序找不到

#我们来思考一个问题,
类怎么去调用这个前后置模块的代码逻辑呢?——用例执行之前执行前置,用例执行之前后执行后置?——》@pytest.mark.usefixtures()
#@pytest.mark.usefixtures("hello") #pytest.mark.usefixtures("hello") 表示在执行当前类下的测试用例之前,会自动去寻找函数名叫hello的fixture并执行
class TestLogin:

@pytest.mark.parametrize("case",datas) # 解决:第二步遍历每一条数据然后进行判断的问题
def test_login(self,case): #这里的case 要与上面装饰器的case 保持一致
actual = login_check(case["user"], case["passwd"])
assert actual == case["check"]

# @pytest.mark.usefixtures("hello") #像这个是调用不了的,因为设置了作用域,只能类下面去调用

def test_hello_world():
print("我是模块下的测试用例")
 

pytest之 fixture 实现机制的更多相关文章

  1. pytest.4.Fixture

    From: http://www.testclass.net/pytest/fixture/ 我们可以简单的把Fixture理解为准备测试数据和初始化测试对象的阶段. 一般我们对测试数据和测试对象的管 ...

  2. pytest(6)-Fixture(固件)

    什么是固件 Fixture 翻译成中文即是固件的意思.它其实就是一些函数,会在执行测试方法/测试函数之前(或之后)加载运行它们,常见的如接口用例在请求接口前数据库的初始连接,和请求之后关闭数据库的操作 ...

  3. 『德不孤』Pytest框架 — 12、Pytest中Fixture装饰器(二)

    目录 5.addfinalizer关键字 6.带返回值的Fixture 7.Fixture实现参数化 (1)params参数的使用 (2)进阶使用 8.@pytest.mark.usefixtures ...

  4. unittest的前置后置,pytest的fixture和共享机制conftest.py

    Unittest setUp/tearDown setUp当中得到的变量,用self.xxx = value传递给测试用例 setUpClass/tearDownClass setupClass当中得 ...

  5. 『德不孤』Pytest框架 — 11、Pytest中Fixture装饰器(一)

    目录 1.Fixture装饰器的用途 2.Fixture参数说明 3.Fixture装饰器简单应用 4.yield执行后置函数 1.Fixture装饰器的用途 做测试前后的初始化设置,如测试数据准备, ...

  6. pytest 15 fixture之autouse=True

    前言 平常写自动化用例会写一些前置的fixture操作,用例需要用到就直接传该函数的参数名称就行了.当用例很多的时候,每次都传这个参数,会比较麻烦.fixture里面有个参数autouse,默认是Fa ...

  7. pytest 5. fixture之yield实现teardown

    前言: 1.前面讲的是在用例前加前置条件,相当于setup,既然有setup那就有teardown,fixture里面的teardown用yield来唤醒teardown的执行 看以下的代码: #!/ ...

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

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

  9. pytest的fixture和conftest

    解决问题:用例1需要先登录,用例2不需要登录,用例3需要先登录.很显然这就无法用setup和teardown来实现了,这个时候就可以自定义测试用例的预置条件,比setup灵活很多. 1.fixture ...

随机推荐

  1. 大数据学习day18----第三阶段spark01--------0.前言(分布式运算框架的核心思想,MR与Spark的比较,spark可以怎么运行,spark提交到spark集群的方式)1. spark(standalone模式)的安装 2. Spark各个角色的功能 3.SparkShell的使用,spark编程入门(wordcount案例)

    0.前言 0.1  分布式运算框架的核心思想(此处以MR运行在yarn上为例)  提交job时,resourcemanager(图中写成了master)会根据数据的量以及工作的复杂度,解析工作量,从而 ...

  2. nodejs-npm模块管理器

    JavaScript 标准参考教程(alpha) 草稿二:Node.js npm模块管理器 GitHub TOP npm模块管理器 来自<JavaScript 标准参考教程(alpha)> ...

  3. 一起手写吧!ES5和ES6的继承机制!

    原型 执行代码var o = new Object(); 此时o对象内部会存储一个指针,这个指针指向了Object.prototype,当执行o.toString()等方法(或访问其他属性)时,o会首 ...

  4. Kotlin 学习(2)

    属性和字段 1.声明属性 Kotlin中可以使用var关键字声明可变属性,或者用val关键字声明只读属性,属性的类型在后面,变量名在前面,中间加冒号和空格. public class Address ...

  5. 转 序列化Serializable和Parcelable的区别详解

    什么是序列化,为什么要进行序列化 答:对象要进行传输(如:activity 与activity间 ,网络间 进程间等等).存储到本地就必须进行序列化 . 这种可传输的状态就是序列化. 怎么序列化??两 ...

  6. ehcache详解

    Ehcache是现在最流行的纯Java开 源缓存框架,配置简单.结构清晰.功能强大,最初知道它,是从Hibernate的缓存开始的.网上中文的EhCache材料以简单介绍和配置方法居多, 如果你有这方 ...

  7. linux如何安装缺失依赖

    这里要提到一个网站https://pkgs.org/,他是linux系统的一个相关网站,里面都是相关内容 Warning: RPMDB altered outside of yum. ** Found ...

  8. 【Java基础】JAVA中优先队列详解

    总体介绍 优先队列的作用是能保证每次取出的元素都是队列中权值最小的(Java的优先队列每次取最小元素,C++的优先队列每次取最大元素).这里牵涉到了大小关系,元素大小的评判可以通过元素本身的自然顺序( ...

  9. FastJson简介

    FastJson简介 首先,介绍一下fastjson.fastjson是由alibaba开源的一套json处理器.与其他json处理器(如Gson,Jackson等)和其他的Java对象序列化反序列化 ...

  10. 【科研】科研【合同】盖章流程/横向&#183;非涉密/电子科技大学

    [前置手续] 一.在科研管理系统里填单子,立项. 二.科研管理系统审核通过后,对于对面给好的合同,在合同系统里选择[合同业务发起-发起非标准合同],填单子. 三.会有一系列的审核,审核完成后打印合同备 ...