软件测试之使用fixture固件实现前后置条件

前置条件:是在执行某个测试用例之前必须要满足的一些条件,例如预先输入一些数据,配置一些环境等。如果前置条件不正确,测试用例可能不能执行。最简单的例子例如对数据库进行操作

后置条件:在执行某个测试用例之后的一些操作例如清理测试用例等,如果后置条件没有被这行的话,可能会影响后续的测试用例的执行

装饰器:用于修改函数或者类的行为,在不改变类或者函数的定义的情况下进行扩展,实现代码的复用。

装饰器本质上是一个函数,接受一个函数或者类作为参数,然后返回一个新的函数或者类

本次用的装饰器就是fixture

@pytest.fixture(scope="function",autouse=True)
def excut_sql():
    print("打开数据库")

@pytest.fixture(scope="作用范围",autouse="是否自动调用",params=“参数化”,ids=“参数别名”,

name=“固件别名”)

params传递参数主要针对场景:对某一个用例进行数据库连接,并且数据库里的数据在用例里面

进行遍历

(使用数据驱动同样可以实现)

name:一般用于简化固件的名字

scope:function 按函数执行

scope:class 按执行

scope:module 按照模块执行

scope:session 按照每一个会话执行

ps:如果前置条件作用在函数上并且自动开启,那么需要前置条件的函数多传入一个参数

如下例就是test_user_login(self,excut_sql):

@pytest.fixture(scope="function",autouse=False)
def excut_sql():
    print("打开数据库")


#Personal API
class   Test_API:
#测试登录用户信息接口
    access_token=''
    sess=requests.session()
    @pytest.mark.smoke
    def test_user_login(self,excut_sql):
        url='http://localhost:8080/api/v1/user/login'
        data={
              "loginName": "18922301826",
              "passwordMd5": "e10adc3949ba59abbe56e057f20f883e"
        }

        #res=requests.post(url,json=data)
        res=Test_API.sess.request(method='post',url=url,json=data)
        reslut=res.json()
        print(res.json())
        Test_API.access_token=jsonpath.jsonpath(reslut,"$.data")[0]
        print(Test_API.access_token)

注意:在一个文件中设置的固件,只能在当前文件起作用

比如只在test——phpwind文件写了固件,那么test_api文件是不会执行前置条件无论修改什么样的参数。

如果需要对所有的py文件起作用,需要结合conftest文件

好处:分层前后置

分模块管理前置条件

比如所有模块都先需要“登录”,其中有些模块需要“进入xxx框架”

最外层的conftest先执行,其次才是内部的conftest执行

使用extract.yaml文件保存中间变量

1.读取 2.写入 3.清空

原因:

1.类变量不可以跨py文件使用

2.统一的管理中间变量

在什么时候选择清空yaml文件之中保存的中间变量?(前置条件)

在请求之前清空yaml文件内容

如果在请求之后清空会发生看不到中间变量的现象

assert断言(判断结果是否正确)

每一个测试用例的断言都不一样


requirments.txt 中base_url这个参数当作一个需要手动调用的固件使用(基础路径)

例如:test_user_login(self,base_url);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值