基于代码驱动:处理有依赖关系接口

Posted bendouyao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于代码驱动:处理有依赖关系接口相关的知识,希望对你有一定的参考价值。

数据驱动和代码驱动的区别:

  使用数据驱动好处:

    - 代码复用率高。同一测试逻辑编写一次,可以被多条测试数据复用,提高了测试代码的复用率,同时可以提高测试脚本的编写效率。

    - 异常排查效率高。测试框架依据测试数据,每条数据生成一条测试用例,用例执行过程相互隔离,在其中一条失败的情况下,不会影响其他的测试用例。
  缺点:但是数据驱动无法做到依赖,比如后续操作依赖登录产生的cookie,这样的很难实现

代码驱动:
测试用例全是用代码实现的
继续完善utp,让utp变成一个数据驱动和代码驱动都支持的框架
适合接口之间互相依赖,需要操作数据库,参数加密,操作redis
数据驱动:适合有大量的接口需要测试,接口之间互相不依赖
代码驱动:适合接口之间互相依赖,需要操作数据库,参数加密,操作redis

通常在测接口时,有些接口之间有依赖关系,并不是各自独立的。比如有些接口可能在访问的时候,首先要保证用户已登录,要用到用户的cookie信息。

像这样的接口在测试的时候,就要先进行登录接口的操作,获取到需要的cookie或session值,然后再进行测试。

举例:

比如现在测试一个抽奖接口。需要先登录,获取到登录接口返回的userid和sign字段的值。可以这样操作:

1、先写个登录函数,用来获取到登录接口返回的内容

    def login(self):
        url=/api/user/login
        real_url=parse.urljoin(BASE_URL,url)
        username,password=self.register()#获取到注册时的用户名和密码
        data={username:username,passwd:password}
        res=MyRequest.post(real_url,data)
        self.assertEqual(0, res.get(error_code), msg=登录失败)
        sign=res.get(login_info).get(sign)
        userid=res.get(login_info).get(userId)
        return userid,sign

2、在测试抽奖的时候,先调用登录函数login,获取到userid和sign,然后在作为参数传入抽奖接口

    def testchoice(self):
        ‘‘‘测试抽奖‘‘‘
        url = /api/product/choice
        real_url = parse.urljoin(BASE_URL, url)
        user_id, sign = self.login()#获取到userid和sign,需注意的是,因为此处会有调用登录的操作,所以上面的登录函数不需要加test前缀作为用例执行。要不然就会重复执行
        data = {userid: user_id, sign: sign}
        res = MyRequest.get(real_url, data)
        self.assertEqual(0, res.get(error_code), msg=抽奖接口调用失败)

因为在unittest中,只要类继承了unittest,类中的函数名以test开头,就会被执行。所以如果login前也加了test,就会被作为用例执行一次。然后再下面抽奖用例中,调用登录接口的时候又会被执行一次。所以避免重复执行,login函数就不需要再加test了






以上是关于基于代码驱动:处理有依赖关系接口的主要内容,如果未能解决你的问题,请参考以下文章

处理大量微依赖关系

utp

jmeter之有依赖关系的接口处理

spring练习,在Eclipse搭建的Spring开发环境中,使用set注入方式,实现对象的依赖关系,通过ClassPathXmlApplicationContext实体类获取Bean对象(代码片段

Android片段和依赖注入

接口自动化---简单的数据驱动框架ATP(基于excel)