项目背景
公司内部产品,大都采用B/S架构。由于大部分项目都在开发阶段,版本迭代快,界面不稳定,故而使用UI自动化不太现实。针对此种情况,接口测试较为有效,所以就使用RobotFramework搭建了一个简单的接口测试框架。
RobotFramework简介
RobotFramework是一个款关键字驱动的开源自动化测试框架。测试用例位于HTML或者TSV(以tab分隔值)文件,在使用测试库中实现的关键字来测试运行的程序。因为RobotFramework是灵活可扩展的,所以它很适合于测试具有多种接口的复杂软件:用户接口,命令行,web service,编程接口等等。当然接口只是一部分,web UI,移动端,该框架都游刃有余。接口测试工具,框架比较多,为何选择了rf,是因为有助于测试人员快速上手,学习成本较低,统一语法便于管理。
封装的公共库
基于robotframework实现接口自动化,使用requestlibrary库,该库基于python的requests库实现,由于在接口数量太多的时候,使用该库的关键字编写用例时影响速度,故而我又对requests封装了一下,以至于更高效的编写测试用例。先看一下我自己封装的库:
#!/usr/bin/env python# -*- coding: utf-8 -*-"""
__author__ = 'LiBin'
__mtime__ = '16/6/13'
┏┓ ┏┓
┏┛┻━━━┛┻┓
┃ ┃
┃ ┳┛ ┗┳ ┃
┃ ┻ ┃
┗━┓ ┏━┛
┃ ┗━━━┓
┃ 神兽保佑 ┣┓
┃ 永无BUG! ┏┛
┗┓┓┏━┳┓┏┛
┃┫┫ ┃┫┫
┗┻┛ ┗┻┛
"""import jsonimport requestsimport timeimport hashlibimport randomimport pymysql
__version__ = '0.1'class PublicLibrary(object):
def __int__(self):
pass
def getCoding(self, strInput):
u"""
获取编码格式
"""
if isinstance(strInput, unicode): return "unicode"
try:
strInput.decode("utf8") return 'utf8'
except: pass
try:
strInput.decode("gbk") return 'gbk'
except: pass
def tran2UTF8(self, strInput):
"""
转化为utf8格式
"""
strCodingFmt = self.getCoding(strInput) if strCodingFmt == "utf8": return strInput elif strCodingFmt == "unicode": return strInput.encode("utf8") elif strCodingFmt == "gbk": return strInput.decode("gbk").encode("utf8") def tran2GBK(self, strInput):
"""
转化为gbk格式
"""
strCodingFmt = self.getCoding(strInput) if strCodingFmt == "gbk": return strInput elif strCodingFmt == "unicode": return strInput.encode("gbk") elif strCodingFmt == "utf8": return strInput.decode("utf8").encode("gbk") def md5(self, init_str):
"""
md5加密
"""
m = hashlib.md5()
m.update(init_str) return m.hexdigest() def eval_dict(self, strInput):
u"""接收字符串直接转成需要类型,例
| eval dict | str |
"""
strInput = eval(strInput) return strInput def random_num(self, num):
"""
随机出给出数字位数的数字
"""
number = ''
for i in random.sample(range(10), int(num)):
number += ''.join(str(i)) return number def req(
self,
login_msg,
url,
method,
data=None,
headers=None):
u"""专用,有登录状态,例
| run interface test tenant | login_msg,url,method,data,headers
"""
session = requests.Session()
url = self.tran2UTF8(url)
method = self.tran2UTF8(method) if login_msg:
login_msg = self.eval_dict(login_msg)
md5_pwd = self.md5(login_msg['passwd'])
login_msg['passwd'] = md5_pwd if data:
data = self.eval_dict(data) if headers:
headers = self.eval_dict(headers) else:
headers = { 'Content-Type': 'application/json', 'Accept': 'application/json'
}
results = 'connection error'
# 先登录
r = session.post('https://xxxxxx.cn/login',
data=json.dumps(login_msg), headers=headers) print "*******************************"
print u"登录状态信息"
print r.status_code print r.content print "*******************************"
try: if method == "post": if isinstance(data, dict):
data = json.dumps(data)
results = session.post(
url, data=data, headers=headers, verify=False) elif method == "get":
results = session.get(
url, params=data, headers=headers, verify=False) elif method == 'delete':
results = session.delete(url, headers=headers, verify=False) return results except requests.ConnectionError as e: return e def con_db(self, sql):
db = pymysql.connect(
host="1.1.5.2",
user="xxx",
passwd="xxx",
db="xxx",
charset='utf8')
cursor = db.cursor()
cursor.execute(sql)
data = cursor.fetchone()
db.close() return data其中的req函数即是对request的一层简单封装,省掉了接口的每次登录状态。
如何编写用例
用例的内容一般是发起请求,拿到结果,结果验证。

上述用例中即为发起请求、拿到结果、与数据库的数据进行对比。
如何跑
我们的用例使用git管理,项目在Jenkins每次构建后会自动跑一次,当然如果希望多次跑,就自己在Jenkins上添加时间调度吧。每次构建完成后,相关人员会收到测试结果,如果发现问题可以及时修改。

以上就是使用RobotFramework做的一个简单的接口自动化测试框架(肯定还有一些地不完善)希望帮助到有需要的人。
作者:海尔兄弟_
链接:https://www.jianshu.com/p/469b199e7e11

随时随地看视频