首页
学习
活动
专区
工具
TVP
发布

Python接口测试之数据驱动

在接口的自动化测试中,客户端发送请求给服务端,在客户端发送请求的时候,包含了请求地址,请求方法,以及请求参数等数据,那么在接口的自动化测试中如何来分离这些请求地址和请求参数了,最好的方式是以数据驱动的方式分离到excel中,这样在excel中直接维护,即使后期由于某些原因修改了请求参数,在excel中修改也是很快的。在下来的案例中,一个系统,请求登录成功后,服务端返回token给客户端,客户端再次请求的时候需要带着这个token。关于HTTP的请求流程,token,session这些的处理,在前面的文章中有很详细的介绍,这里就不再介绍,下面会直接引入代码实战这部分。

首先安装处理excel的库,这里使用的Python版本是3.6,所以先安装第三方库,安装的命令为(已安装的会提示已存在):

安装xlrd库好之后,创建excel文件,把请求地址和请求参数分离到excel中,见excel的数据:

现在来编写读取excel中的数据,主要思路为读取excel的数据后,把数据类型转为字典的数据类型,并且是按行的方式读取,实现的代码:

#!/usr/bin/env python

#-*-coding:utf-8-*-

#author:wuya

importos

importxlrd

importjson

defreadExcel(rowx,filePath='data.xlsx'):

'''

读取excel中数据并且返回

:parameterfilePath:xlsx文件名称

:parameterrowx:在excel中的行数

'''

book = xlrd.open_workbook(filePath)

sheet = book.sheet_by_index()

returnsheet.row_values(rowx)

来读取excel中的数据,并且查看它的数据类型是否是期望的字典类型,调用readExcel函数后,见执行的结果截图:

在截图中可以看到,数据类型是列表,并且返回了所有的数据,再次编写函数,返回XX行的请求地址和请求参数,在excel中,存在的共同点是不管数据是在那一行,第二列永远是请求地址,第三列是请求参数,编写获取请求地址和请求参数的函数,见源码:

#!/usr/bin/env python

#-*-coding:utf-8-*-

#author:wuya

importos

importxlrd

importjson

defreadExcel(rowx,filePath='data.xlsx'):

'''

读取excel中数据并且返回

:parameterfilePath:xlsx文件名称

:parameterrowx:在excel中的行数

'''

book = xlrd.open_workbook(filePath)

sheet = book.sheet_by_index()

returnsheet.row_values(rowx)

defgetUrl(rowx):

'''

获取请求URL

:parameterrowx:在excel中的行数

'''

returnreadExcel(rowx)[1]

defgetData(rowx):

'''

获取请求参数

:parameterrowx:在excel中的行数

'''

returnjson.loads(readExcel(rowx)[2])

在上面代码中,新增了获取获取请求地址和请求参数,因为请求参数数据类型是字典,所以进行了反序列化的处理。

下来编写接口用例,见数据未分离的接口用例,见实现的代码:

importunittest

importtimeast

importrequests

classApiTest(unittest.TestCase):

@classmethod

defsetUpClass(cls):

t.sleep(1)

@classmethod

deftearDownClass(cls):

pass

defgetHeaders(self):

return{

'Parkingwang-Client-Source':'ParkingWangAPIClientWeb',

'Content-Type':'application/json;charset=UTF-8'}

deftest_login_001(self):

'''登录业务:登录成功'''

r=requests.post(

url='http://180.97.80.42:9090/v5/login',

json={"username":"6666666666","password":"8144ed050cd8d053f24a1e179d7529e17c3a2ba9cfcfcd7d3bda9ec6a8156758"},

headers=self.getHeaders())

self.assertEqual(r.status_code,200)

self.assertEqual(r.json()['status'],)

withopen('token','w')asf:

f.write(r.json()['data']['token'])

defgetToken(self):

withopen('token','r')asf:

returnf.read()

deftest_login_002(self):

'''登录业务:查看用户信息'''

r=requests.post(

url='http://180.97.80.42:9090/v5/infoGet',

json={"token":self.getToken()},

headers=self.getHeaders())

self.assertEqual(r.status_code,200)

self.assertEqual(r.json()['status'],)

if__name__ =='__main__':

unittest.main(verbosity=2)

下来使用数据驱动的方式把请求地址和请求参数分离出来,见修改后的源码:

#!/usr/bin/env python

#-*-coding:utf-8-*-

#author:wuya

importos

importxlrd

importjson

defreadExcel(rowx,filePath='data.xlsx'):

'''

读取excel中数据并且返回

:parameterfilePath:xlsx文件名称

:parameterrowx:在excel中的行数

'''

book = xlrd.open_workbook(filePath)

sheet = book.sheet_by_index()

returnsheet.row_values(rowx)

defgetUrl(rowx):

'''

获取请求URL

:parameterrowx:在excel中的行数

'''

returnreadExcel(rowx)[1]

defgetData(rowx):

'''

获取请求参数

:parameterrowx:在excel中的行数

'''

returnjson.loads(readExcel(rowx)[2])

importunittest

importtimeast

importrequests

classApiTest(unittest.TestCase):

@classmethod

defsetUpClass(cls):

t.sleep(1)

@classmethod

deftearDownClass(cls):

pass

defgetHeaders(self):

return{

'Parkingwang-Client-Source':'ParkingWangAPIClientWeb',

'Content-Type':'application/json;charset=UTF-8'}

deftest_login_001(self):

'''登录业务:登录成功'''

r=requests.post(

url=getUrl(1),

json=getData(1),

headers=self.getHeaders())

self.assertEqual(r.status_code,200)

self.assertEqual(r.json()['status'],)

withopen('token','w')asf:

f.write(r.json()['data']['token'])

defgetToken(self):

withopen('token','r')asf:

returnf.read()

deftest_login_002(self):

'''登录业务:查看用户信息'''

r=requests.post(

url=getUrl(2),

json=getData(2),

headers=self.getHeaders())

print(r.text)

self.assertEqual(r.status_code,200)

self.assertEqual(r.json()['status'],)

if__name__ =='__main__':

unittest.main(verbosity=2)

数据分离后,维护数据统一是在excel中,第二个接口这些成功后,直接失败,见失败信息:

问题在于数据分离后,test_login_002的测试用例请求数据与登录成功后的token不一致,导致了错误,那么如何对这些动态参数进行处理了,处理的思路是:

从excel中读取数据

对如token这些动态参数再次进行赋值

返回赋值后的数据

调用赋值后的数据

依据如上的思路,对getToken方法进行修改,对token再次进行赋值,新增setToken方法,见修改后的该方法代码:

defgetToken(self):

'''读取token文件里面的内容'''

withopen('token','r')asf:

returnf.read()

defsetToken(self,rowx):

'''

对动态参数token进行赋值

:parameterrowx:在excel中的行数

'''

dict1=getData(rowx)

#对tokek赋值

dict1['token']=self.getToken()

returndict1

在test_login_002的接口用例中,调用请求参数直接调用setToken方法,这样就不会出现错误了,见完整的代码:

#!/usr/bin/env python

#-*-coding:utf-8-*-

#author:wuya

importos

importxlrd

importjson

importunittest

importtimeast

importrequests

defreadExcel(rowx,filePath='data.xlsx'):

'''

读取excel中数据并且返回

:parameterfilePath:xlsx文件名称

:parameterrowx:在excel中的行数

'''

book = xlrd.open_workbook(filePath)

sheet = book.sheet_by_index()

returnsheet.row_values(rowx)

defgetUrl(rowx):

'''

获取请求URL

:parameterrowx:在excel中的行数

'''

returnreadExcel(rowx)[1]

defgetData(rowx):

'''

获取请求参数

:parameterrowx:在excel中的行数

'''

returnjson.loads(readExcel(rowx)[2])

classApiTest(unittest.TestCase):

@classmethod

defsetUpClass(cls):

t.sleep(1)

@classmethod

deftearDownClass(cls):

pass

defgetHeaders(self):

return{

'Parkingwang-Client-Source':'ParkingWangAPIClientWeb',

'Content-Type':'application/json;charset=UTF-8'}

deftest_login_001(self):

'''登录业务:登录成功'''

r=requests.post(

url=getUrl(1),

json=getData(1),

headers=self.getHeaders())

self.assertEqual(r.status_code,200)

self.assertEqual(r.json()['status'],)

withopen('token','w')asf:

f.write(r.json()['data']['token'])

defgetToken(self):

'''读取token文件里面的内容'''

withopen('token','r')asf:

returnf.read()

defsetToken(self,rowx):

'''

对动态参数token进行赋值

:parameterrowx:在excel中的行数

'''

dict1=getData(rowx)

#对tokek赋值

dict1['token']=self.getToken()

returndict1

deftest_login_002(self):

'''登录业务:查看用户信息'''

r=requests.post(

url=getUrl(2),json=self.setToken(2),headers=self.getHeaders())

self.assertEqual(r.status_code,200)

self.assertEqual(r.json()['status'],)

if__name__ =='__main__':

unittest.main(verbosity=2)

如您对我写的内容感兴趣,扫描如下二维码关注本人的微信公众号:

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180619G1ZDRJ00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券