• 基于Python接口自动化测试框架(初级篇)附源码


    引言

      很多人都知道,目前市场上很多自动化测试工具,比如:Jmeter,Postman,TestLink等,还有一些自动化测试平台,那为啥还要开发接口自动化测试框架呢?

    相同之处就不说了,先说一下工具的局限性:

    1.测试数据不可控:

      接口虽然是对业务逻辑、程序代码的测试,而实际上是对数据的测试,调用接口输入一批数据,通过断言代码验证接口返回的数据,整个过程围绕数据测试。
        如果返回的数据不是固定的,是变化的,那么断言失败,就无法知道是接口程序错误引起的,还是数据变化引起的,所以就需要进行测试数据初始化。
        接口工具没有具备数据初始化的功能,从而无法真正做到接口自动化测试。

    举个例子来帮助理解:

         比如你要测试一个查询接口,在没有初始化测试数据的情况下,你入参是:id = 1,断言是: assert name = ‘测试’, 这个断言是你预先知道接口会返回什么。调用接口时候,接口返回结果是name = ‘测试’,断言成功,因为你知道数据库有一条id=1的数据。

         哪天这条id=1的数据被人删除,但是你维护的接口测试框架还在跑,并没有更新测试数据,结果断言失败,你上去debug,最后发现是测试数据的问题,这个过程是费时又费劲的,

    如果做了测试数据初始化的功能,完全是可以避免的。

         因为入参和出参都是固定的,是按自己需要初始化好的,不用担心数据变化引发断言失败,那么只关心接口程序代码的问题了。

    2.无法测试加密接口
     
      公司项目中,大部分接口是不供外部调用,会使用用户认证、签名、加密等手段,提供接口的安全性。而一般的测试工具无法做到模拟和生成这些加密算法。

    3.扩展能力不足
     
      工具始终是工具,有一定的局限性,无法生成自定义测试报告,无法定制化发送邮件,持续集成和定时任务。

    4.对业务的支持程度
     
      工具对业务支持程序相对比较低,无法根据不同业务定制化开发,而自动化测试框架可以做到这点,对业务支持比较灵活。

    框架设计思路

    1.大致处理流程:

    2.接口自动化测试框架处理过程:

    首先编写一份测试数据初始化的脚本,维护一批测试数据到数据库,并且每次初始化前,清空原来的数据,这样保证数据是最新和唯一的(避免重复)。
    调用被测系统的接口,传入参数,这个请求参数是字典,并且数据与数据库数据(数据是初始化时插入)中一致。
    系统接口会根据入参,向测试数据库查询。
    查询结果组装成一定格式(dict、json)的数据,返回给测试框架。
    测试框架断言接口返回的数据,并生成测试结果(测试报告)。

    框架结构

    框架介绍:

    各个目录的作用:

    common/: 报告、日志等公共模块存放文件夹
    config/: 文件路径、配置信息存放
    db_init/: 测试数据初始化处理程序
    logs/: 生成日志文件
    pies/: 饼图存放
    report/: 测试报告存放
    testcase/: 用于编写测试用例
    run_main.py 执行测试集的主程序
    主程序运行文件run_main.py:

    1. # -*- coding: utf-8 -*-
    2. '''
    3. @author: liudinglong
    4. @software: pycharm
    5. @file: run_main.py
    6. @time: 2020/2/23 0023 13:46
    7. '''
    8. import time ,sys
    9. # 引用模块路径
    10. sys.path.append('./testcase')
    11. sys.path.append('./db_fixture')
    12. from common.HTMLTestRunner3 import HTMLTestRunner
    13. from unittest import defaultTestLoader
    14. from db_init import data_init
    15. # 指定测试用例为当前文件夹下的 interface 目录
    16. test_dir = './testcase'
    17. # 自动获取interface 目录下的测试用例
    18. testsuit = defaultTestLoader.discover(test_dir,pattern='*test.py')
    19. if __name__ == '__main__':
    20. # 初始化接口测试数据
    21. data_init.init_data()
    22. # 获取当前时间
    23. now = time.strftime("%Y-%m-%d %H_%M_%S")
    24. # 定制报告名称
    25. filename = './report/' + now + '_result.html'
    26. # 向报告写入测试结果数据
    27. fp = open(filename, 'wb')
    28. runner = HTMLTestRunner(stream=fp,
    29. title='接口自动化测试报告',
    30. description='运行环境:环境:windows 10 浏览器:chrome 语言: Python3')
    31. # 运行测试集
    32. runner.run(testsuit)
    33. # 关闭报告文件
    34. fp.close()

    测试数据初始化data_init.py:

    1. # -*- coding: utf-8 -*-
    2. '''
    3. @author: liudinglong
    4. @software: pycharm
    5. @file: data_init.py
    6. @time: 2020/2/23 0023 13:37
    7. '''
    8. import sys, time,datetime
    9. sys.path.append('../db_init')
    10. try:
    11. from mysql_conn import DB
    12. except ImportError:
    13. from .mysql_conn import DB
    14. # 定义过去时间,time.localtime(time.time())格式化时间戳为本地时间
    15. past_time = time.strftime("%Y-%m-%d %H:%M:%S",time.localtime(time.time()-100000))
    16. # 定义将来时间
    17. future_time = time.strftime("%Y-%m-%d %H:%M:%S",time.localtime(time.time()+10000))
    18. # 获取当前时间
    19. now_time = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
    20. # create data
    21. datas = {
    22. 'django_web_event':[
    23. {'id':1,'name':'红米Pro发布会','`limit`':2000,'status':1,'address':'北京会展中心','start_time':future_time},
    24. {'id':2,'name':'可参加人数为0','`limit`':0,'status':1,'address':'北京会展中心','start_time':future_time},
    25. {'id':3,'name':'当前状态为0关闭','`limit`':2000,'status':0,'address':'北京会展中心','start_time':future_time},
    26. {'id':4,'name':'发布会已结束','`limit`':2000,'status':1,'address':'北京会展中心','start_time':past_time},
    27. {'id':5,'name':'小米5发布会','`limit`':2000,'status':1,'address':'北京国家会议中心','start_time':future_time},
    28. ],
    29. 'django_web_guest':[
    30. {'id':1,'realname':'alen','phone':13511001100,'email':'alen@mail.com','sign':0,'event_id':1},
    31. {'id':2,'realname':'has sign','phone':13511001101,'email':'sign@mail.com','sign':1,'event_id':1},
    32. {'id':3,'realname':'tom','phone':13511001102,'email':'tom@mail.com','sign':0,'event_id':5},
    33. ],
    34. }
    35. # Inster table datas
    36. def init_data():
    37. DB().init_data(datas)
    38. if __name__ == '__main__':
    39. init_data()

    运行程序

    运行结果:

    1

    2

    ......FFFFFF.................

    Time Elapsed: 0:00:00.208256

    测试日志:

    测试报告:

    有错误不要害怕,看看报错信息,再修改一下,运行后:

    总结

     在测试之前,要准备测试环境,如果是正式环境的接口,有条件的话,建议独立创建测试数据库,避免对正式数据造成影响。可以在本地创建或在正式库服务器是上创建db,本套仅作为项目测试环境使用。
       在数据库初始化时,连接测试环境的数据库,将自己需要的测试数据初始化进去,每次程序执行的时候,都初始化一遍,这样的作用防止数据与正式数据冲突,并且防止测试数据重复和累积在数据库中。
     

    最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

    在这里插入图片描述

    这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!   

  • 相关阅读:
    丁鹿学堂:自学前端怎么样才能进步快
    IceRPC之多路复用传输>快乐的RPC
    不会就坚持43天吧 反向遍历
    备战2023秋招,应届生应做好哪些准备
    全球化浪潮下的技术与安全
    C++所有容器的详细使用介绍
    jmeter压力测试指标解释
    [附源码]java毕业设计基于javaweb电影购票系统
    朴素贝叶斯——垃圾邮件过滤
    java毕业设计全套基于SSM的垃圾分类管理系统
  • 原文地址:https://blog.csdn.net/YLF123456789000/article/details/133790801