一、接口
框架
接口测试框架的结构说明:
- 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脚本, 再将数据写入数据库中