首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
28 篇文章
1
一篇文章让你入门API测试
2
[接口测试 - 基础篇] 01 你应该了解的协议基础
3
[接口测试 - 基础篇] 02 你应该掌握的Python3接口测试内功
4
[接口测试 - 基础篇] 03 unittest测试框架了解多少才够?
5
[接口测试 - 基础篇] 04 无法绕过的json解析
6
[接口测试 - 基础篇] 05 好讨厌的xml解析
7
[接口测试 - 基础篇] 06 好吧也来解析下html
8
[接口测试 - 基础篇] 07 来来来,一起读写excel玩玩之一
9
[接口测试 - 基础篇] 08 封装个基本的excel解析类
10
[接口测试 - 基础篇] 09 其实吧,读写csv格式也是要掌握的
11
[接口测试 - 基础篇] 10 别啊,还有INI格式呢,别忘记我
12
[接口测试 - 基础篇] 11 掌握下python解析YAML格式也是需要的
13
[接口测试 - 基础篇] 12 还是要掌握python日志管理模块的
14
[接口测试 - 基础篇] 13 写在接口测试基础篇完结时
15
[接口测试 - http.client篇] 14 源码初探及其工作机制分析
16
[接口测试 - http.client篇] 15 常用API说明及基本的示例
17
[接口测试 - http.client篇] 16 基于http.client之POM实战一下
18
[接口测试 - http.client篇] 17 http.client之入门级接口测试框架
19
接口测试 | urllib篇 18 urllib介绍
20
接口测试 | urllib篇 19 urllib基本示例
21
[接口测试 -基础篇] 20 用flask写一个简单server用于接口测试
22
接口测试 | 21 基于flask弄个restful API服务出来
23
接口测试 | 22 requests基础入门
24
接口测试 23 requests基础入门二
25
接口测试 | 24 requests + unittest集成你的接口测试
26
接口测试 | 25 requests + pytest测试实例
27
接口测试 | 26 基础及简要验证清单
28
接口测试 | 27 HTTP接口详细验证清单

[接口测试 -基础篇] 20 用flask写一个简单server用于接口测试

概述

近期在写接口测试系列时,总感觉很不对劲,主要是缺乏一个比较完整的用于API测试的环境,四处找公开的API真心不靠谱,尝试了不少公开的,总觉得少了些什么,所以决定自己搭建一个,后续所有的实例都会基于本文所构建的mock server进行API实例演示。

选型

为了让大家了解python的强大,我们flask来做一个简单的server

如果你需要更多的了解flask请参见官方中文文档:

http://docs.jinkan.org/docs/flask

安装

安装flaask

pip install flask

支持

支持GET, POST, PUT, PATCH, DELETE 等http方法

看一个简单的flask代码

代码语言:javascript
复制
#-*- coding:utf-8 -*-

__author__ = "苦叶子"

from flask import Flask

app = Flask(__name__)

@app.route('/api')
def index():
    return "Hello, World!"

if __name__ == '__main__':
    app.run()

将上述代码保存至run.py, 使用一下命令运行

python run.py runserver

打开浏览器输入http://localhost:5000 即可在浏览器看到Hello, World几个单词的输出。

基本示例

这里我们构建一个简单的server,后续我们的接口测试分享实战都会基于这个server来进行交互实战。

为了让大家显得简洁,我不会添加异常等容错处理。

下面我们基于flask实现HTTP的GET\POST\HEAD等方法,用于后续的测试,然后也可以基于这个代码进一步扩展成restful风格的API。

我们先简单的实现,大家根据需要自行学习扩展.

代码语言:javascript
复制
#-*- coding:utf-8 -*-

__author__ = "苦叶子"

from flask import Flask
from flask import jsonify
from flask import request, Response
import randomimport time

app = Flask(__name__)

"""
    这里所有的接口我们才去返回json串
    所有的json传对应的value值都为随机的
"""

# 生成随机字符串
def random_str():
    # 待选随机数据
    data = "1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()_+=-"

    # 用时间来做随机播种
    random.seed(time.time())    

    # 随机选取数据
    sa = []    
    for i in range(8):
        sa.append(random.choice(data))
    salt = ''.join(sa)    
    
    return salt
    
# 构建response
def make_response():
    content = '{"result": "%s", "data": "%s"}' % 
        (random_str(), random_str())
    resp = Response(content)
    resp.headers["Access-Control-Origin"] = '*'

    return resp

# http GET
@app.route("/query", methods=["GET"])
def query():
    return jsonify(
        username=random_str(),
        password=random_str()
        )

# http POST
@app.route("/update", methods=["POST"])
def update():
    
    return make_response()

# http delete
@app.route("/delete", methods=["DELETE"])
def delete():
    
    return make_response()

# http head
@app.route("/head", methods=["HEAD"])
def head():
    
    return make_response()    if __name__ == "__main__":

    app.run(debug=True)

说明:

  1. 注意POST\HEAD\DELETE方法,响应头均被加入了Access-Control-Origin属性,其值为:*
  2. 注意即便给HEAD方法添加了响应内容,但你在实际接收到的内容是木有响应内容的,请思考为什么
  3. 上述仅用于简单的测试,不讨论其优雅、靠谱、高大上等等可能性

对应的flask代码及jmeter测试代码请参见:

链接: https://pan.baidu.com/s/1pLv7Mo7

密码: iha4

下一篇
举报
领券