对python自动生成接口测试的示例讲解
作者:大大大大大石 发布时间:2022-06-14 03:24:43
标签:python,接口,测试
在python中Template可以将字符串的格式固定下来,重复利用。 同一套测试框架为了可以复用,所以我们可以将用例部分做参数化,然后运用到各个项目中。
代码如下:
coding=utf-8
'''
作者:大石
功能:自动生成pyunit框架下的接口测试用例
环境:python2.7.6
用法:将用户给的参数处理成对应格式,然后调用模块类生成函数,并将参数传入即可
'''
from string import Template
#动态生成单个测试用例函数字符串
def singleMethodCreate(MethodList,interfaceNamePara):
code=Template('''\n def test_${testcase}(self):
u"""${testcaseName}"""
headers = $headers
data = $data
re = requests.$method(url='$url',headers=headers,data=data)
status_code = re.status_code
s = str(status_code)
json = re.text
logging.info('-'*5+'返回状态码是'+s+'-'*5)
logging.info('-'*5+'返回结果集是'+json+'-'*5)
assert status_code == 200
assert json['status'] == 'ok'
''')
string = code.substitute(testcase=MethodList["testcase"],testcaseName=MethodList["TestcaseName"],
method=MethodList['method'],url=MethodList['url'],headers=MethodList['headers'],data=MethodList['data'],
)
return string
#拼接单个的测试用例函数字符串为完整字符串并传回主函数
#MethodParaList获取测试用例部分list
def methodCreate(MethodParaList,interfaceNamePara):
string = ""
for MethodPara in MethodParaList:
string2=singleMethodCreate(MethodPara,interfaceNamePara)
string=string+string2
return string
#构造单个测试集
def singleTestsuitCreate(MethodList,parameters):
code = Template('''suite.addTest(${className}("test_${testcase}"))''')
string = code.substitute(testcase = MethodList["testcase"],className = parameters[0])
return string
#添加测试集
def addtestsuit(MethodParaList,interfaceNamePara):
string = ""
for MethodPara in MethodParaList:
string2 = singleTestsuitCreate(MethodPara,interfaceNamePara)
string=string+string2
return string
#生成测试用例类函数字符串
def modelClassCreate(parameters):
modelCode = methodCreate(parameters[2],parameters[1])
adtestsuit = addtestsuit(parameters[2],parameters)
code = Template('''#coding: utf-8
"""
作者:大石
功能:待执行的接口测试用例
环境:python2.7.6
用法:通过框架自动触发调用
"""
import unittest,requests,datetime,sys,logging,BSTestRunner,time,os
from Log import Log
class ${className}(unittest.TestCase):
u"""待测试接口:${interfaceName}"""
def setUp(self):
logging.info('-'*5+"begin test"+"-"*5)
def tearDown(self):
logging.info('-'*5+"end test"+'-'*5)
${model}
if __name__ == "__main__":
#解决UnicodeDecodeError: 'ascii' codec can't decode byte 0xe5 in position 97: ordinal not in range(128)
reload(sys)
sys.setdefaultencoding('utf8')
#构造测试集
suite = unittest.TestSuite()
${testsuite}
#定义date为日期,time为时间
date=time.strftime("%Y%m%d")
time1=time.strftime("%H%M%S")
now=time.strftime("%Y-%m-%d-%H_%M_%S",time.localtime(time.time()))
#创建路径
path='F:/test/study/yaml/test_log/'+now+"/"
#解决多次执行时报路径已存在的错误
try:
os.makedirs(path)
except:
if path!= None:
logging.error(u'当前路径已经存在')
filename=path+'Report.html'
fp=file(filename,'wb')
#日志记录
Log.log()
#执行测试
runner =BSTestRunner.BSTestRunner(stream=fp,title=u'下单平台接口测试用例',description=u'接口用例列表:')
runner.run(suite)
fp.close()
''')
fileStr = code.substitute(className=parameters[0],interfaceName=parameters[1],testsuite=adtestsuit,model=modelCode)
f=open(parameters[0]+".py",'w')
f.write(fileStr)
f.close()
然后测试用例部分如下:
parameters=["Testcase_Orders",
"/login",
[
{"TestcaseName":"测试登录","method":"post","url":"http://www.senbaba.cn/login","headers":{'content-type': 'application/json',
'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko',
'Accept':'application/x-ms-application, image/jpeg, application/xaml+xml, image/gif, image/pjpeg, application/x-ms-xbap, */*',
'Accept-Language':'zh-CN'},"data":{"uname":"187071484771","pwd":"123456"},
"testcase":"login"},
{"TestcaseName":"测试登录","method":"post","url":"http://www.senbaba.cn/login1","headers":{'content-type': 'application/json',
'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko',
'Accept':'application/x-ms-application, image/jpeg, application/xaml+xml, image/gif, image/pjpeg, application/x-ms-xbap, */*',
'Accept-Language':'zh-CN'},"data":{"uname":"187071484771","pwd":"123457"},
"testcase":"login_failed"}
]
]
自动生成的测试用例如下:
#coding: utf-8
"""
作者:大石
功能:待执行的接口测试用例
环境:python2.7.6
用法:通过框架自动触发调用
"""
import unittest,requests,datetime,sys,logging,BSTestRunner,time,os
from Log import Log
class Testcase_Orders(unittest.TestCase):
u"""待测试接口:/login"""
def setUp(self):
logging.info('-'*5+"begin test"+"-"*5)
def tearDown(self):
logging.info('-'*5+"end test"+'-'*5)
def test_login(self):
u"""测试登录"""
headers = {'Accept-Language': 'zh-CN', 'content-type': 'application/json', 'Accept': 'application/x-ms-application, image/jpeg, application/xaml+xml, image/gif, image/pjpeg, application/x-ms-xbap, */*', 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko'}
data = {'uname': '187071484771', 'pwd': '123456'}
re = requests.post(url='http://www.senbaba.cn/login',headers=headers,data=data)
status_code = re.status_code
s = str(status_code)
json = re.text
logging.info('-'*5+'返回状态码是'+s+'-'*5)
logging.info('-'*5+'返回结果集是'+json+'-'*5)
assert status_code == 200
assert json['status'] == 'ok'
def test_login_failed(self):
u"""测试登录"""
headers = {'Accept-Language': 'zh-CN', 'content-type': 'application/json', 'Accept': 'application/x-ms-application, image/jpeg, application/xaml+xml, image/gif, image/pjpeg, application/x-ms-xbap, */*', 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko'}
data = {'uname': '187071484771', 'pwd': '123457'}
re = requests.post(url='http://www.senbaba.cn/login1',headers=headers,data=data)
status_code = re.status_code
s = str(status_code)
json = re.text
logging.info('-'*5+'返回状态码是'+s+'-'*5)
logging.info('-'*5+'返回结果集是'+json+'-'*5)
assert status_code == 200
assert json['status'] == 'ok'
if __name__ == "__main__":
#解决UnicodeDecodeError: 'ascii' codec can't decode byte 0xe5 in position 97: ordinal not in range(128)
reload(sys)
sys.setdefaultencoding('utf8')
#构造测试集
suite = unittest.TestSuite()
suite.addTest(Testcase_Orders("test_login"))
suite.addTest(Testcase_Orders("test_login_failed"))
#定义date为日期,time为时间
date=time.strftime("%Y%m%d")
time1=time.strftime("%H%M%S")
now=time.strftime("%Y-%m-%d-%H_%M_%S",time.localtime(time.time()))
#创建路径
path='F:/test/study/yaml/test_log/'+now+"/"
#解决多次执行时报路径已存在的错误
try:
os.makedirs(path)
except:
if path!= None:
logging.error(u'当前路径已经存在')
filename=path+'Report.html'
fp=file(filename,'wb')
#日志记录
Log.log()
#执行测试
runner =BSTestRunner.BSTestRunner(stream=fp,title=u'下单平台接口测试用例',description=u'接口用例列表:')
runner.run(suite)
fp.close()
20171019添加测试集的一个简单方法:
#添加测试集
def addtestsuit(parameters):
string = ""
temp = Template('''\n suite.addTest(${className}("test_${testcase}"))
''')
l = len(parameters[2])
for i in range(0,l):
testcase1 = parameters[2][i]['testcase']
string2 = temp.substitute(className = parameters[0],testcase = testcase1)
string=string+string2
print string
return string
来源:https://blog.csdn.net/smj811504083/article/details/78250002


猜你喜欢
- 随着互联网产业的飞速发展和电子产业的飞速发展,人们的社交似乎离不开网络,这就应运了SNS的飞速发展。从打开QQ空间关注朋友们的动态,最近心情
- 这种情况在Access下可以通过,但SQL则不行,在百度搜索解决方法,发现N多人出现同样问题却找不到解决办法: 代码如下:set
- Django模板使用两种模板标签,且语法格式与Python代码有些许不同。 为了使得模板访问到标签,需要将 {% load i18n %}
- 每个 batch 前清空梯度,否则会将不同 batch 的梯度累加在一块,导致模型参数错误。然后我们将输入和目标张量都移动到所需的设备上,并
- 快速高效用:SET SQL_SAFE_UPDATES = 0;下面的就不要看了!今日用MySQL Workbench进行数据库的管理更新时,
- 以下各种方式仅供参考,本人亲测只有官方提供的方式比较靠谱。1. 使用多个进程启动多个Tornado实例import tornado.http
- 如下所示:# 计算面积函数def area(width, height): return width * heightdef print_w
- 基本思路1、创建vueRouter,用公共路由实例化2、创建需要根据权限筛选的路由对象(在路由对象,添加必要的权限判断字段)3、登录完成,由
- 在Python里面,使用Pandas里面的DataFrame来存放数据的时候想要把数据集进行shuffle会许多的方法,本文介绍两种比较常用
- 需要安装的python库使用python编写程序进行测试MQTT的发布和订阅功能。首先要安装:pip install paho-mqtt测试
- 误区 #21:数据库损坏可以通过重启SQL Server或是Windows,或是附加和分离数据库解决 错误 SQL Server中没有任何一
- Python的全局变量:int string, list, dic(map) 如果存在global就能够修改它的值。而不管这个global是
- 今天在日常维护一个网站时,发现该网站的留言程序没有经过严格的验证过滤,导致了将近十万条垃圾数据。而其中又不乏重要信息,需要清理数据,以及增加
- 最近有一个需求:将日志以json格式输出, 并且有些字段是logging模块没有的.看了很多源码和资料, 终于搞定, 抽取精华分享出来, 一
- 如果你有过Web编程的经验,那么或多或少都听说过或者使用过模板。简而言之,模板是可用于创建动态内容的文本文件。例如,你有一个网站导航栏的模板
- 在查询凭证、审核凭证时出现“列前缀tempdb.无效: 未指定表名”的错误提示,怎么解决?原因:是因为SQL2000无法识别计算机名称中”-
- 本文实例讲述了Python多线程原理与用法。分享给大家供大家参考,具体如下:先来看个栗子:下面来看一下I/O秘籍型的线程,举个栗子——爬虫,
- numpy中有一个掩码数组的概念,需要通过子模块numpy.ma来创建,基本的创建方式如下>>> import numpy
- 一、原型模式原型是相对于复制、克隆而言的,但是不同于模板,模板创造出的东西是一模一样,而原型创造出的东西是允许存在差异化和个性化的。原型模式
- NULL值的概念是造成SQL的新手的混淆的普遍原因,他们经常认为NULL是和一个空字符串''的一样的东西。不是这样的!例如,