专栏首页测试游记pytest的一个demo

pytest的一个demo

pytest的一个demo

上周看了元类的实现方式后,对「代码块」的理解好像有了不一样的认知。

  • 函数是一段代码块
  • 类也是一段代码块

根据现在的工作中使用的pytest写一个demo

demo:

import pytest
import requests

@pytest.fixture(scope='module')
def get_request():
    request_list = []

    def _get_request(data, flag=True):
        if flag:
            x = requests.post('http://httpbin.org/post', data=data)
            request_list.append(x.json().get('data'))
        return request_list

    yield _get_request

@pytest.mark.parametrize("i", [1, 2, 3])
def test_customer_records(i, get_request):
    print('\n')
    print(f'第{i}次测试')
    customer = get_request(f'{{"a{i}", "b{i}"}}')
    print(customer)

结果:

第1次测试
['{"a1", "b1"}']
.

第2次测试
['{"a1", "b1"}', '{"a2", "b2"}']
.

第3次测试
['{"a1", "b1"}', '{"a2", "b2"}', '{"a3", "b3"}']

解释:

  1. 使用module级别的fixture可以定义一个存放多次数据的空的列表request_list
  2. 在fixture中写一个函数,并用yield将它返回以供调用
  3. 测试的时候使用参数化构建case会执行三次
  4. 从测试结果可以看出,列表内容持续增多

写的时候感觉好像很神奇,后来想想其实和以下方式实现一样:

request_list = []
def _get_request2(request_list, data, flag=True):
    if flag:
        x = requests.post('http://httpbin.org/post', data=data)
        request_list.append(x.json().get('data'))
    return request_list

@pytest.fixture(scope='module')
def get_request2():
    yield _get_request2

@pytest.mark.parametrize("i", [1, 2, 3])
def test_customer_records(i, get_request2):
    print('\n')
    print(f'第{i}次测试')
    customer = get_request2(request_list, f'{{"a{i}", "b{i}"}}')
    print(customer)

也不就是:

request_list = []
def _get_request2(request_list, data, flag=True):
    if flag:
        x = requests.post('http://httpbin.org/post', data=data)
        request_list.append(x.json().get('data'))
    return request_list

@pytest.mark.parametrize("i", [1, 2, 3])
def test_customer_records(i):
    print('\n')
    print(f'第{i}次测试')
    customer = _get_request2(request_list, f'{{"a{i}", "b{i}"}}')
    print(customer)

额,好Low

不过其实也不是毫无用处,当scope等级改变之后

  • session:项目级传递数据相当于global
  • class:class级别传递数据,并可以使用pytest的turndown机制
  • function:函数级别,没啥用

本文分享自微信公众号 - 测试游记(zx94_11),作者:zx钟

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-04-16

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 测试开发进阶(三)

    zx钟
  • Java自动化测试(基础知识/基本数据类型)

    先下载并安装JDK:https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads....

    zx钟
  • Django学习_简易博客(三)

    zx钟
  • 【Python 第2课】print

    今天早上醒来,发现咱们的同学人数一夜之间多了50,后来又陆陆续续来了很多,于是我坚持下去的信心又增加了不少。在这里感谢连客官微的宣传,表示今晚将用加班写代码来表...

    Crossin先生
  • Python 基础(六):列表与元组

    Python 中没有数组,而是加入了功能更强大的列表(list),列表可以存储任何类型的数据,同一个列表中的数据类型还可以不同;列表是序列结构,可以进行序列结构...

    Python小二
  • Python标准库学习之urllib

    本系列以python3.4为基础 urllib是Python3的标准网络请求库。包含了网络数据请求,处理cookie,改变请求头和用户代理,重定向,认证等的函数...

    py3study
  • Photodiode的结构类型

    先前的笔记中介绍过光电探测器,这一篇主要就光电二极管(Photodiode)的结构类型展开更详细地调研。光电二极管的基本结构是PN结,但为了获得更好的性能参数,...

    光学小豆芽
  • Laravel 7 新特性-路由的趟坑之路(自定义键名以及作用域)

    Laravel 7 开始新增了一些新特性,今天我们来讲解下 路由绑定的新用法,自定义键名(slug)以及作用域(范围限定)

    hedeqiang
  • python入门demo

    py3study
  • 谈谈 Java 中自定义注解及使用场景

    Java自定义注解一般使用场景为:自定义注解+拦截器或者AOP,使用自定义注解来自己设计框架,使得代码看起来非常优雅。本文将先从自定义注解的基础概念说起,然后开...

    好好学java

扫码关注云+社区

领取腾讯云代金券