基于py3从0到接口自动化测试应用系列(1)

基于py3从0到接口自动化测试应用系列(1)

写在前面的话

希望这些文章可以

  • 帮助有一点代码基础的测试伙伴独立动手搭建一套完整、高效、可读性好、便于维护的接口自动化系统
  • 帮助给出一些在自动化过程中因环境,业务,甚至人员配合等原因造成阻力的解决方案
  • 回顾总结整个项目过程,帮助自己更好的对它进行优化和扩展

自卖自夸

  • 目前这套系统已维护一家中大型互联网企业核心交易线服务1年半时间,累计用例数量2万条,覆盖率在85%以上,质量保障效果显著
  • 在业务项目中不断演进优化,在脚本输出效率,代码覆盖率以及应对常见的开发设计模式都有较好的表现(非平台)
  • 开发都觉得好才是真的好!!!

一套东西不可能应对所有情况,但也希望对大家有所帮助,废话不多数,开始。


准备篇

当我们做任何新产品测试时候,第一件事情就是要先认识被测体,接口测试也一样。

认识接口

什么是接口

接口的标准定义这里就不赘述了,那我们通常测试的接口是什么?举个例子,当我们点击打开一个商品页面时,客户端需要调用==商品详情接口==,目的是希望通过这个接口告诉服务端商品的ID(即唯一标识)并要求服务端返回这个商品的详细信息,这就是我们最长提到的接口

sequenceDiagram
客户端->>服务端: 商品A
服务端->>客户端: 商品A的详细信息
接口的组成

我们知道接口有很多概念包括:http接口、api接口、RPC接口、RMI、webservice、Restful等,下面以我们最常见的http接口为例,如果我们把一个接口看成一个对象那么它主要包含如下属性

class RequestUtil(object):
    """
    接口基础类
    """
    def __init__(self):
        self.host = None  # 域名:http://my-api-test.com
        self.uri = None  # /mydemo
        self.url = None  
        # url host+uri+param
        self.info = None  # 接口描述
        self.method = None  # 请求方式 post get put等等
        self.body = None 
        # 请求参数体 例如 
        {"product_id": 123456}
        self.param = None  
        # get请求参数 例如 product_id=123456
        self.resp = None  
        # 返回结果,例如 
        {"product_name":'abc',"price":5.11}
        self.is_sign = None  # 签名 
        self.key_token = None  # token
        self.headers = headers 
        # 请求头 例如 
        {'Content-Type': 'application/json'}
        self.status = 0  # 期望的接口返回结果中代表失败、成功状值
        self.success_status = 0  # 接口成功时的status值
        self.http_status = 200  # http返回码
        self.timeout = 15  # 最大超时时间
        self.mock_info = BaseObj()  # 如果接口中需要mock的话,存放mock信息
        
    def send_request():
        """发送请求,使用requests库来实现该功能"""
        pass

可以看到上面已经生成的我们接口最基础的类,包含了我们后续需要用到的所有属性,并且它还应该包含一个重要的功能就是组织好这些属性然后发送请求并记录请求的所有数据,这里使用的是requests库来实现这个功能。

如何获取接口结构

通常我们会根据每个公司不同的情况按照优先级从高到低排序有如下获取方式:

方式 推荐指数 推荐原因
swagger ⭐️⭐️⭐️ 更新及时;输出格式统一,适合和脚本结合动态生成测试数据;比较主流;
wiki ⭐️⭐️ 可规范输出格式;可对接口做更详细的描述;
抓包工具 ⭐️ 不推荐,看不到完整接口结构,不能作为测试标准;另外到能抓包的时候才去生成接口数据时间上太晚;

推动开发提供以上文档推荐直接接swagger,可以要求开发将参数是否必填和描述等信息写在会用到的参数后面,以此来弥补没有wiki的部分,这样我们解析拉出的脚本中参数就都有具体的描述信息了,非常方便,如下图中内容就是直接从swagger页面解析的脚本

# 以下代码从swagger拉取生成,可从swagger重新拉取更新

from common.objects import BaseObj
from ..__init__ import *


class MyServiceBaseDemoApi(BaseServiceDemo):
    """接口对象"""
    def __init__(self, **kwargs):
        super(MyServiceBaseDemoApi, self).__init__()
        self.info = "my demo接口例子"
        self.uri = "mydemo"
        self.method = "post"
        self.body = self.Body(**kwargs)
        self.resp = self.Resp()

    class Body(BaseObj):
        def __init__(self, **kwargs):
            self.name = None  # 必填,用户姓名
            self.age = None  # 非必填,用户年龄
            self.phone_num = None  # 必填,用户手机号码 必填,用户手机号码
            BaseObj.__init__(self, **kwargs)

    class Resp(object):
        def __init__(self):
            super(MyServiceBaseDemoApi.Resp, self).__init__()
            self.status = None  # None
            self.msg = None  # 公司ID
            self.data = self.Items()  # 公司ID

        class Items(object):
            def __init__(self):
                self.name = None
                self.age = None

熟悉被测服务

除了认识单个的接口,我们还需要了解被测服务的架构以及该服务是如何和其他服务或客户端进行数据交换来完成产品的部分功能,举个例子:在交易流程中通常会包括以下几个服务


image

这快信息可以直接从开发那边获取,通常开发会有类似的业务架构图,只有了解了这快我们才可以比较准确的来制定相关项目的测试方案,避免漏测,错测。

熟悉一门语言

目前我使用的是python3,当然你们也可以选择java或者其他合适的语言,虽然语言不同,但很多思路和解决问题的方式都是互通的;以python为例,应用要求至少能熟悉到python对象的处理,具体语法这里就不赘述了,百度一下很多,自己比较推荐廖雪峰的python教程,因为比较容易入手。

了解相关依赖库

后面会主要用到以下依赖库,可以提前了解下基本的功能和调用方式

peewee>=2.10.2  # 数据库orm
peewee-mssql>=0.1.2
pymysql  # mysql
redis>=2.10.6  # mock部分的key会存储在redis中
requests>=2.18.4  # http请求的发送,也可以使用aiohttp或其他类似库替换
selenium>=3.8.0  # 接口和ui自动化结合时候可能会需要用到
threadpool>=1.3.2  # 业务并发
pytest=4.3.1  # 自动化测试框架,也可以选择其他类似框架
pytest-html  # pytest生成报告插件
parameterized  # 参数化用例需要使用到

常见接口测试方案

抛开业务,广义上我们主要用到两种测试方案

方向 方案
用例方向 1.单接口测试;2.多接口串流测试
断言部分 1.新老服务对比结果;2.根据业务逻辑计算期望结果和实际结果做对比;

用例方面:

  • 推荐大部分接口尽量都需要有单接口或短流程的测试用例;
  • 流程型较强的业务例如拼团等,必须要加入全流程串流测试;

结果检查:

  • 重构,分库分表等其他不改变业务逻辑的技术型项目非常适合新老服务接口对比测试。==优势==:脚本无需自行生成期望结果,只需对应新老结果即可,脚本量大幅度减少;期望结果可靠性非常高;
  • 根据实际的业务逻辑来自行生成接口返回结果or落库数据的期望结果,一个接口仅包含一个check方法。==优势==: 维护成本稳定,不会随着用例的大幅增多而激增;可实现数据的全量对比,大幅度提高代码覆盖率。

最后会对上面提到的没提到的做比较详细的说明,大概后面内容如下,可能会有微调:

  • 接口自动化准备篇
  • 基于nosetests or pytest搭建自动化测试 。 (基础 +现有框架的整体简单介绍图)
  • 测试数据:动静态测试数据的管理实践
  • 用例1:测试数据载入及实例化接口对象 (比较几个框架自带参数化及三方参数话库在实际应用的优劣等)
  • 用例2:利用装饰器来管理用例结构
  • 请求发送:SentRequest 模块介绍
  • 断言1: 利用装饰器来对比你的结果
  • 断言2:从部分到全量的演进;消息,redis等部分的检查
  • 如何加速你的脚本
  • 业务1:利用mock解决业务方依赖实践
  • 业务2强流程业务接口自动化该如何做才高效 (拼团 从用例到检查)
  • 业务3:业务场景并发测试 (抢优惠券等)
  • 其他:管理你的环境配置
  • 其他:自动化生成测试脚本(接口对象,数据库表对象, 常用用例等)
  • 其他:持续集成你的接口自动化
  • 其他:特殊项目接口自动化方案介绍(转java,订单分表等)

如果有任何问题可以留言或私聊~会尽量回复~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,094评论 1 32
  • 1.问:你在测试中发现了一个 bug ,但是开发经理认为这不是一个 bug ,你应该怎样解决。 首先,将问题提...
    qianyewhy阅读 9,237评论 4 123
  • 一:LoadRunner常见问题整理1.LR 脚本为空的解决方法:1.去掉ie设置中的第三方支持取消掉2.在系统属...
    0100阅读 4,105评论 0 11
  • 自从远嫁到这个城市,原来的朋友和亲戚似乎已经和我隔绝开来。刚嫁过来时,语言不通。公公婆婆也不会说普通话,而...
    天才玉米肠阅读 1,098评论 0 5
  • 刚看完《世界微尘里》这本小说,在这样一个下雨天的傍晚,心内蓦地就有些孤独和寂寞起来!小说中的曾鲤其实和自己有...
    我是林二阅读 212评论 0 2