一、接口
框架
?接口测试框架的结构说明:? ? ? - API 用于封装被测系统的接口? ? ? - TestCase 将一个或者多个接口封装成测试用例,并使用UnitTest管理测试用例 TestCase 可以调用数据库进行数据的校验? ? ? - 为了方便维护测试数据,可以把测试脚本和测试数据分离开? ? ? - 通过UnitTest断言接口返回的数据,并生成测试报告
1、接口介绍
接口可以分为:硬件接口(USB接口、投影仪接口等、键盘鼠标接口)
软件接口。这里只关注软件层面的接口
2、接口文档
接口地址:http://data.zgsfqxcx.cn/datahub/gateway/4pgmy3/ssjsjylyb
请求类型:get
支持格式: json
请求示例:http://data.zgsfqxcx.cn/datahub/gateway/4pgmy3/ssjsjylyb?lng=119.545023&callback=jQuery.Callbacks&lat=36.044254&appKey=您申请的KEY
header请求参数
?
参数 值
Content-Type application/json
query请求参数
?
公共请求参数
?
名称 类型 必填 示例值 参数说明
appkey string 必填 1 您申请的appkey
业务请求参数
?
名称 类型 必填 示例值 参数说明
lng string 必填 119.545023 经度
lat string 必填 36.044254 纬度
callback string 必填 jQuery.Callbacks jsonp参数
body请求参数
?
名称 类型 必填 示例值 参数说明
暂无数据
公共返回参数
?
名称 类型 示例值 参数说明
code string 10000 更多参数返回示例值请参看"错误参照码"
remain long 1305 数据剩余次数
msg string 查询成功 更多参数返回示例值请参看"错误参照码"
result object {...} 数据查询结果
业务返回参数
?
名称 类型 示例值 参数说明
请参考返回示例 string 请参考返回示例 请参考返回示例
返回示例
二、接口测试用例
1、接口测试点提取
从整体来进行划分,我们在分析接口测试的时候,可以大体分为
正向测试、 反向测试
?补充:参数化处理
1.参数化分析
?
?2.构建参数化数据
def build_data():
file = '../data/login.json'
test_data = []
with open(file, 'r', encoding='utf-8') as f:
json_data = json.load(f)
for case_data in json_data:
username = case_data.get('username')
password = case_data.get('password')
verify_code = case_Data.get('verify_code')
content_type = case_Data.get('content_type')
status_code = case_Data.get('status_code')
status = case_Data.get('status')
msg = case_Data.get('msg')
test_data.append((username, password, verify_code, content_type, status_code, status, msg))
return tst_data
3.对于测试用例实现参数化
class TestLogin(unittest.TestCase):
# 2.1 前置处理
def setUp(self):
self.login_api = LoginAPI() # 实例化接口类
self.session = requests.Session() # 创建session对象
# 2.2 后置处理
def tearDown(self):
if self.session:
self.session.close()
@parameterized.expand(build_data)
# 2.3.创建测试用例
def test01_login(self, username, password, verify_code, content_type, status_code, status, msg):
pass
4.对于db数据承载实现参数化
def build_data():
# 获取数据库的数据
sql = "select * from t_login"
db_data = DBUtil.exe_sql(sql)
test_data = []
for case_data in db_data:
username = case_data[2]
password = case_data[3]
verify_code = case_data[4]
status_code = case_data[5]
content_type = case_data[6]
status = case_data[7]
msg = case_data[8]
test_data.append((username, password, verify_code, content_type, status_code, status, msg))
print(test_data)
return test_data
注意:记得构建数据库数据,然后执行SQL脚本, 再将数据写入数据库中
|