51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1727|回复: 0
打印 上一主题 下一主题

我所理解的接口测试-接口自动化测试

[复制链接]
  • TA的每日心情

    3 天前
  • 签到天数: 76 天

    连续签到: 1 天

    [LV.6]测试旅长

    跳转到指定楼层
    1#
    发表于 2018-6-15 14:43:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    一、问题:如何两眼一抹黑的利用python做接口自动化测试

    理解:这个问题,当初我在开始学python,并尝试用python写接口自动化测试时也许遇到,后来我发现
    以结果为导向,反推需要实现的功能是个很好的方法,先不管实现的好不好,脚本效率高不高,先做出
    能实现效果的版本。

    二、问题:如何以结果为导向,反推需要实现的功能

    理解:任务是“python+mysql实现http协议的接口测试”,目标是能自动比较结果(包括code和返回包参数
    完整性)

    分析:要实现这个效果,涉及到的功能点有以下几点:

    1.python对mysql数据库的操作,包括增、删、改、查数据;

    2.python发送http请求;

    3.python处理返回包的结果;

    4.mysql数据库操作,包含sql语句;

    具体实现过程:
    1.mysql数据库表的新建:

    (1).我们需要一类表,存储每个接口的测试用例数据和执行结果的记录,包括的字段有用例级别(BVT,1,
    2,3)、请求类型(get/post)、接口地址、请求头文件、请求参数、返回包、实际code结果、预期code结
    果,实际参数集、预期参数集,code对比结果、参数集对比结果、用例状态、创建时间、更新时间、请
    求时长;

    图1 接口用例case表设计
    (2).配置表,存储一些比较常用、且变化小的参数,比如默认用例级别、接口超时时间等;

    图2 配置表设计
    (3).结果统计表,存储每次执行后,每个接口的结果情况;

    2.python对mysql数据库的操作:

    (1).此处需要预先封装好python对mysql的基本操作类型,网上一招一大堆,可以直接拿来修改使用;

    (2).根据实际情况,在定制一些操作类型,方便外部调用;

    图3 python对mysql数据库操作封装
    3.python发送http请求:

    (1).此处需要封装python本身对http请求的方法,等于再套一个壳子,而这个壳子里面包含了get方法、
    post方法、url链接有效性方法;

    图4 http请求外层壳

    图5 http请求类型方法
    3.python处理http返回包

    (1).此处可以根据配置来决定对返回包的测试程度,比如有以下3个级别(0-只测试code值,1-返回包参
    数完整性;2-返回包功能),通过配置值决定需要进行哪些程度的测试

    图6 针对不同的测试程度定义测试
    (2).将不同的测试程度分装到一个类中,分别以方法来定义不同的测试程度

    图7 定义不同测试程度的方法
    (3).将不同程度的测试结果写入数据库测试用例表,即完成一条完整的测试用例数据

    4.测试结果的统计

    (1).配置不同的统计维度,其对应的不同的统计sql,这样修改起来也比较方便,此处涉及到sql语句的参数化

    (2).可以配合django使用web页面来展示数据,页面选择不同的展示维度,后台调用不同的统计sql,再
    将数据展示在页面,或者以表格形式导出。



    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏3
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-9-21 22:57 , Processed in 0.082588 second(s), 25 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表