【Python实践】_接口模拟器

真正的稳定,是自己不断成长,不断寻找新的空间。与其要稳定,不如开始拥抱这个变化的时代,让自己准备好。


python实践

【目录】Python实践

【写在前面】:
周一的时候看mock,就萌发了搭建个mock server的冲动,但是一时也没找到建mock server是要解决什么问题。后来发现其实有一类痛点是测试感触比较深的。
【材料】:
参考材料 《Python+Flask搭建API》

【Step1】:接口模拟器解决什么痛点?
测试过程中有一种情况是这样的:测试想看下页面某个值超长的时候显示情况(字段值是接口返回的),是换行还是溢出了。这个时候一般怎么办?
(1).方法1-利用fiddler截取和篡改数据;
(2).方法2-看接口数据获取逻辑,尝试修改源数据;
(3).方法3-和开发商量,写死这个返回值;
以上三种方法,其处理过程都是比较麻烦,而且时间会比较长,最关键的是每次遇到这种情况都要重复这种操作方法,婶可忍叔不可忍,所以接口模拟器就从这个痛点下手。
【Step2】:接口模拟器的构思
1、针对上面的痛点,假设有一个接口模拟器,其能实现下面的功能:调用接口文档中所有接口,传递任何参数, 返回想要的结果。对应关系是:

接口文档详例.png

2、测试的过程中可以配置接口模拟器,这样只要控制好接口-请求数据-返回数据的关系,接口便可定制自己想要的结果,而不需要调用实际的接口;
3、当调用正式接口的时候,一键切换,或者修改下配置就可以使用正式接口了
4、so,如果真的可以这样,那么是不是可以至少带来以下这些好处:
(1).不需要再去依赖后端实际的接口情况,可以自定义返回数据,想怎么测页面就怎么测;
(2).接口自动化测试用例可以快速编写,且通过接口模拟器去验证;
(3).一些注册、计费类的接口就不要在实际调用花自己钱了;
【step3】开始实现接口模拟器
1、技术架构:Python+Flask+MySQL
2、技术原理:db中定义好接口-请求数据-返回包的一对一的关系,Flask构建一个通用的方法处理任意接口请求,通过接口地址和请求数据匹配数据库数据,返回数据库数据。是不是很简单?下面是Flask部分源码,需要其他详细的源码可以访问我的git地址
【step4】Flask实现API源码

# -*- coding: utf-8 -*-
# @Time    : 2020/3/3 23:21
# @Author  : dashenN72
"""
自定义接口地址、请求参数和返回数据,可用于模拟接口文档中定义的接口数据
"""

from flask import abort, jsonify, Flask, request, Response
import ast
import db
import log
opt = db.OperationDbInterface()  # 实例化数据库
log = log.TestLog(logger='main').getlog()  # 实例化log

app = Flask(__name__)
# 增加配置,支持中文显示
app.config['JSON_AS_ASCII'] = False


@app.route('/<path:requirt>', methods=['GET', 'POST'])
def get_response_by_request(requirt):
    log.info("request params:%s" % requirt)
    if request.method == 'GET':
        param_request = request.full_path.split('?')[1]
    elif request.method == 'POST':
        # print(request.get_data(as_text=True))
        param_request = request.get_data(as_text=True).replace('"', "'")
    else:
        param_request = ''
    log.info("preprocess params:%s" % param_request)
    result = opt.select_one('SELECT param_response FROM relation WHERE url_interface="%s" AND param_request="%s" '
                            'AND status=1' % (str(requirt), str(param_request)))
    log.info("db result:%s" % result)
    if result['data'] and result['code'] == '0000':  # 从db中拿到数据
        return jsonify(ast.literal_eval(result['data']['param_response']))
    elif result['code'] != '0000':  # db查询数据失败
        return jsonify({'code': 9, 'message': 'unexpect error on get db data'})
    else:  # db中无数据
        return jsonify({'code': 0, 'message': 'db data is null'})


if __name__ == '__main__':
    app.run(
        host='0.0.0.0',
        port=6868,
        debug=True
        )

【step5】自测


db数据.png

模拟接口请求和返回值.png

【step6】后续可拓展
1.开发一个简单的页面,用于操作db,添加和修改数据,方便使用;
2.从数据库匹配数据可能存在问题,需要进一步优化,或者在填数据的时候注意;
3.还没想好......

推荐阅读更多精彩内容

  • 今天学习了四步简投法,如何选,如何投都讲啦,明天就是如何定制自己的策略,可惜券商APP开户不成功,又怕买在高点,一...
    蔷薇少女若阅读 54评论 0 0
  • 因为地域的原因,我说话中只要有带有“h”“f”的发音我都发音不准,为此,从我的师傅到赢家的伙伴们常常纠正我,而我从...
    勇敢去飞阅读 1,393评论 2 2
  • 我有一个温暖的家,我的家人有妈妈、姥姥、妹妹,我们家有两个房间,一个大房间是我妈妈和姥姥妹妹住的,那个小房间是我住...
    ff1da5291eb4阅读 80评论 0 1
  • 103节,亲人重逢 带着六个人原路返回,十字边走边说:“还没有问你贵姓?”​ “我叫生辰,那天路过崖边...
    畅想之心阅读 73评论 0 2
  • 昨天是母亲节,原计划是要回去看妈妈的,也许是出差刚回来,有些累,就跟妈妈打电话问好,并且说有些累了就不回去了。妈妈...
    乐活临在阅读 181评论 2 6