关于接口测试的一些总结

一、接口

框架

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对一个投影仪进行测试用例编写时,可以考虑以下几个方面: 1. 功能测试: - 测试投影仪的基本功能,如开关机、调整亮度、调整对比度等。 - 测试不同输入源的切换,如HDMI、VGA、USB等。 - 测试投影仪是否支持不同分辨率及画面比例的显示。 - 测试投影仪的色彩还原能力,如显示不同颜色、调整色彩饱和度等。 - 测试投影仪的焦距调整功能,如调整投影画面的大小和清晰度。 2. 显示效果测试: - 测试投影仪在不同环境光照条件下的显示效果。 - 测试投影仪在不同投影面材质上的显示效果,如墙壁、幕布等。 - 测试投影仪在不同投影距离下的显示效果,如近距离投影和远距离投影。 - 测试投影仪在不同角度投影时的显示效果,如正面投射、倒置投射等。 3. 连接与兼容性测试: - 测试投影仪与不同设备的连接兼容性,如笔记本电脑、台式电脑、手机等。 - 测试投影仪是否能够正常接收和显示来自不同设备的信号。 - 测试投影仪是否能够与其他外部设备进行联动,如音响、遥控器等。 4. 声音测试: - 测试投影仪内置扬声器的音质和音量调节功能。 - 测试投影仪与外部音响的连接和音质表现。 5. 长时间运行测试: - 测试投影仪在长时间使用后是否会出现过热、噪音等问题。 - 测试投影仪在长时间连续投影下的稳定性和可靠性。 以上是一些常见的测试用例,具体根据投影仪的特性和功能来编写更细化的测试用例。同时,还需要考虑不同用户的使用场景和需求,确保投影仪能够满足各种使用情况下的要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值