分析

接口是基于HTTP协议的,那么说白了,就是发起HTTP请求就行了,对于Python来说比较简单。直接使用requests就可以很轻松的完成任务。

架构

整个框架是比较小的,涉及的东西也比较少,只要分清楚几个模块的功能就行了。

上面是一个接口测试的完整流程。只要一步一步的走下来就行了,并不是很难。

数据源

数据源我使用的是JSON来保存,当然,比较广泛的是使用Excel来保存,用JSON来保存是因为JSON用起来比较方便,懒得去读取Excel了,Python对JSON的支持是非常友好的。当然这个就看个人喜好了。

{    "TestId": "testcase004",    "Method": "post",    "Title": "单独推送消息",    "Desc": "单独推送消息",    "Url": "http://xxx.xxx.xxx.xx",    "InputArg": {      "action": "44803",      "account": "1865998xxxx",      "uniqueid": "00D7C889-06A0-426E-BAB1-5741A1192038",      "title": "测试测试",      "summary": "豆豆豆",      "message": "12345",      "msgtype": "25",      "menuid": "203"    },    "Result": {      "errorno": "0"    }  }

示例如上面代码所示,可以根据个人的业务需要进行调整。

发送请求

发送请求就很简单了,用requests模块,然后从JSON中读取发送的参数,post、get或者其他。由于要生成测试报告,那么发送的数据需要做一下记录,我选择用txt文本来作为记录的容器。

f = file("case.json")testData = json.load(f)f.close()def sendData(testData, num):    payload = {}    # 从json中获取发送参数    for x in testData[num]['InputArg'].items():        payload[x[0]] = x[1]    with open('leftside.txt', 'a+') as f:        f.write(testData[num]['TestId'])        f.write('-')        f.write(testData[num]['Title'])        f.write('/n')    # 发送请求    data = requests.get(testData[num]['Url'], params=payload)    r = data.json()

接受返回

由于我们是需要生成测试报告的,那么返回的数据我们先需要进行一次存储,可以选择用数据库存储,但是我觉得数据库存储太麻烦了,只要用txt文本作为存储容器即可。

with open('rightside.txt', 'a+') as rs:        rs.write('发送数据')        rs.write('|')        rs.write('标题:'+testData[num]['Title'])        rs.write('|')        rs.write('发送方式:'+testData[num]['Method'])        rs.write('|')        rs.write('案例描述:'+testData[num]['Desc'])        rs.write('|')        rs.write('发送地址:'+testData[num]['Url'])        rs.write('|')        rs.write('发送参数:'+str(payload).decode("unicode-escape").encode("utf-8").replace("u/'","/'"))        rs.write('|')        rs.write(testData[num]['TestId'])        rs.write('/n')

结果判定

结果判定我使用的是全等于判定。因为我们的接口只需要这样处理就行了,如果有需要,可以写成正则判定。

with open('result.txt', 'a+') as rst:        rst.write('返回数据')        rst.write('|')        for x, y in r.items():            rst.write(' : '.join([x, y]))            rst.write('|')        # 写测试结果        try:            if cmp(r, testData[num]['Result']) == 0:                rst.write('pass')            else:                rst.write('fail')        except Exception:            rst.write('no except result')        rst.write('/n')

我这里结果有3种,成功、失败或者没结果。结果的设置就看自己的定义了。

生成测试报告

测试报告是一个重头戏,由于我发送数据、返回数据和结果都是用txt文本存储,那么每次使用a+模式新增,会让结果越来越多,而且检查起来非常蛋疼。

我的处理方式是每次测试完毕之后,用Python读取txt文本中的数据,然后使用Django动态生成一个结果,然后再使用requests抓取这个网页,保存在Report文件夹中。

网页报告

Django的方法我就不多说了,博客中已经有一整个系列文章了。我们需要在views文件中打开之前记录的3个txt文件,然后做一些数据处理,返回给前端,前端用Bootstrap来渲染,就能生成一个比较漂亮的测试报告。

def index(request):    rightside = []    result = []    rst_data = []    leftside = []    passed = 0    fail = 0    noresult = 0    with open(os.getcwd() + '/PortTest/leftside.txt') as ls:        for x in ls.readlines():            lf_data = {                'code': x.strip().split('-')[0],                'title': x.strip().split('-')[1]            }            leftside.append(lf_data)    with open(os.getcwd() + '/PortTest/rightside.txt') as rs:        for x in rs.readlines():            row = x.strip().split('|')            rs_data = {                "fssj": row[0],                "csbt": row[1],                "fsfs": row[2],                "alms": row[3],                "fsdz": row[4],                "fscs": row[5],                'testid': row[6]            }            rightside.append(rs_data)    with open(os.getcwd() + '/PortTest/result.txt') as rst:        for x in rst.readlines():            row = x.strip().split('|')            if row[len(row)-1] == 'fail':                fail += 1            elif row[len(row)-1] == 'pass':                passed += 1            elif row[len(row)-1] == 'no except result':                noresult += 1            rs_data = []            for y in row:                rs_data.append(y)            result.append(rs_data)    for a, b in zip(rightside, result):        data = {            "sendData": a,            "dealData": b,            "result": b[len(b)-1]        }        rst_data.append(data)    return render(request, 'PortTest/index.html', {"leftside": leftside,                                                    "rst_data": rst_data,                                                    "pass": passed,                                                    "fail": fail,                                                    "noresult": noresult})

基本上都是一些很基础的知识,字符串分割等等。这里的数据处理为了方便,在获取数据存储的时候就要按照一定的格式来存储,views的方法就很容易做处理。

前端代码如下:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>Title</title>    <link href="http://libs.baidu.com/bootstrap/3.0.3/css/bootstrap.min.css" rel="stylesheet">    <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>    <script src="http://libs.baidu.com/bootstrap/3.0.3/js/bootstrap.min.js"></script></head><body><div class="container">    <div class="row">        <div class="page-header">            <h1>接口测试报告                <small>Design By Sven</small>            </h1>        </div>    </div>    <div class="row">        <div class="col-md-4">            <h3>测试通过 <span class="label label-success">{{ pass }}</span></h3>        </div>        <div class="col-md-4">            <h3>测试失败 <span class="label label-danger">{{ fail }}</span></h3>        </div>        <div class="col-md-4">            <h3>无结果 <span class="label label-warning">{{ noresult }}</span></h3>        </div>    </div>    <p></p>    <div class="row">        <div class="col-md-3">            <ul class="list-group">                {% for ls in leftside %}                    <li class="list-group-item"><a href="#{{ ls.code }}">{{ ls.code }} - {{ ls.title }}</a></li>                {% endfor %}            </ul>        </div>        <div class="col-md-9">            {{ x.result }}            {% for x in rst_data %}                <div class="panel-group" id="accordion">                {% if x.result == 'pass' %}                    <div class="panel panel-success">                {% elif x.result == 'fail' %}                    <div class="panel panel-danger">                {% elif x.result == 'no except result' %}                    <div class="panel panel-warning">                {% endif %}            <div class="panel-heading">                <h4 class="panel-title">                    <a data-toggle="collapse" href="#{{ x.sendData.testid }}">                        {{ x.sendData.testid }} - {{ x.sendData.csbt }}                    </a>                </h4>            </div>            <div id="{{ x.sendData.testid }}" class="panel-collapse collapse">                <div class="panel-body">                    <b>{{ x.sendData.fssj }}</b><br>                    {{ x.sendData.csbt }}<br>                    {{ x.sendData.fsfs }}<br>                    {{ x.sendData.alms }}<br>                    {{ x.sendData.fsdz }}<br>                    {{ x.sendData.fscs }}                    <hr>                    {% for v in x.dealData %}                        {{ v }}<br>                    {% endfor %}                </div>            </div>            </div>            </div>                <p></p>            {% endfor %}            </div>            </div>        </div>        <script>            $(function () {                $(window).scroll(function () {                    if ($(this).scrollTop() != 0) {                        $("#toTop").fadeIn();                    } else {                        $("#toTop").fadeOut();                    }                });                $("body").append("<div id=/"toTop/" style=/"border:1px solid #444;background:#333;color:#fff;text-align:center;padding:10px 13px 7px 13px;position:fixed;bottom:10px;right:10px;cursor:pointer;display:none;font-family:verdana;font-size:22px;/">^</div>");                $("#toTop").click(function () {                    $("body,html").animate({scrollTop: 0}, 800);                });            });        </script></body></html>

测试报告效果图



长按二维码识别关注,您的支持是我们最大的动力。

公众号:测试梦工厂

QQ一群:300897805

  

 

基于Python的接口测试框架的更多相关文章

  1. 【转】基于Python的接口测试框架实例

    下面小编就为大家带来一篇基于Python的接口测试框架实例.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧   背景 最近公司在做消息推送,那么自然就会产生很多接口,测试 ...

  2. 基于python的接口测试框架设计(三)接口测试的框架

    基于python的接口测试框架设计(三)接口测试的框架 其实我这里用到的是unittest单元测试框架,,这个框架好就好在比较清楚,,setup terdown都可以处理一些初始化及完成后的工作 主要 ...

  3. 基于python的接口测试框架设计(二)配置一些参数及文件

    基于python的接口测试框架设计(二)配置一些参数及文件 我这里需要基于我的项目配置的主要是登陆参数.以及baseURL ,把这些放在单独的文件里  毕竟导入的时候方便了一些 首先是url 图略 建 ...

  4. 基于python的接口测试框架设计(一)连接数据库

    基于python的接口测试框架设计(一)连接数据库 首先是连接数据库的操作,最好是单独写在一个模块里, 然后便于方便的调用,基于把connection连接放在__init__()方法里 然后分别定义D ...

  5. 基于Python的接口测试框架实例

    文章来源:http://www.jb51.net/article/96481.htm 下面小编就为大家带来一篇基于Python的接口测试框架实例.小编觉得挺不错的,现在就分享给大家,也给大家做个参考. ...

  6. [转]基于Python的接口测试框架

    http://blog.csdn.net/wyb199026/article/details/51485322 背景 最近公司在做消息推送,那么自然就会产生很多接口,测试的过程中需要调用接口,我就突然 ...

  7. 基于 python 的接口测试框架

    项目背景 公司内部的软件采用B/S架构,管理实验室数据,实现数据的存储和分析统计.大部分是数据的增删改查,由于还在开发阶段,所以UI界面的变化非常快,之前尝试过用python+selenium进行UI ...

  8. 基于Python接口自动化测试框架+数据与代码分离(进阶篇)附源码

    引言 在上一篇<基于Python接口自动化测试框架(初级篇)附源码>讲过了接口自动化测试框架的搭建,最核心的模块功能就是测试数据库初始化,再来看看之前的框架结构: 可以看出testcase ...

  9. 基于LoadRunner构建接口测试框架

    基于LoadRunner构建接口测试框架 http://www.docin.com/p-775544153.html

随机推荐

  1. AngularJS事件绑定的使用详解

    本文和大家分享的主要是AngularJS中事件绑定相关知识点,希望通过本文的分享,对大家学习和使用AngularJS有所帮助. 1.绑定事件:表达式.事件方法名: 2.绑定点击事件实例:显示.隐藏页面 ...

  2. Android之垂直显示TextView

    Android之垂直显示TextView 1因为界面需求原因,需要TextView垂直显示,话不多说,看代码,我也是搜的例子,在此感谢写这个例子的大神,在此做个笔记和分享给大家 2.用到了自定义控件的 ...

  3. Python之路 day2 购物车小程序1

    #Author:ersa ''' 程序:购物车程序 需求: 启动程序后,让用户输入工资,然后打印商品列表 允许用户根据商品编号购买商品 用户选择商品后,检测余额是否够,够就直接扣款,不够就提醒 可随时 ...

  4. 超级迷宫 nabc

    特点之一:益智模式 N  我们的游戏需要一点点益智答题使其精彩 A 在走迷宫的过程中,会遇到某一个点,出现一个益智小问题,答对即可通过 B 增加游戏的趣味性,吸引用户 C 答题游戏不少,前不久腾讯的手 ...

  5. Android性能优化篇

    很多App都会遇到以下几个常见的性能问题: 启动速度慢:界面跳转慢:事件响应慢:滑动和动画卡顿. 一.启动速度优化. 优化初始化任务: 1. 把一些初始化任务懒加载初始化 2. 把初始化任务并行化(异 ...

  6. Django1.9开发博客(6)- 模板继承

    模板继承就是网站的多个页面可以共享同一个页面布局或者是页面的某几个部分的内容.通过这种方式你就需要在每个页面复制粘贴同样的代码了. 如果你想改变页面某个公共部分,你不需要每个页面的去修改,只需要修改一 ...

  7. 【转】数据预处理之独热编码(One-Hot Encoding)

    原文链接:http://blog.csdn.net/dulingtingzi/article/details/51374487 问题由来 在很多机器学习任务中,特征并不总是连续值,而有可能是分类值. ...

  8. C++ const、volatile、mutable的用法 (转)

      const.volatile.mutable的用法 鸣谢作者: http://blog.csdn.net/wuliming_sc/article/details/3717017 const修饰普通 ...

  9. PHP自动发邮件

    自动发邮件 使用了这个类http://bbs.php100.com/read-htm-tid-121431.html 因他用的php版本较老,用到了函数ereg_replace() 和 ereg() ...

  10. $.post 请求一直转圈圈,谷歌浏览器状态一直为canceled

    最开始写的是 $.post("url",{},function(){},"json") 用火狐浏览器 测试发现请求一直在转圈圈 ,就在action输出 发现也进 ...