前后端知识库 前后端知识库
首页
    • JavaScript
    • React
    • Vue
  • Python
  • Sanic
  • Linux
  • Ansible
归档
GitHub (opens new window)
首页
    • JavaScript
    • React
    • Vue
  • Python
  • Sanic
  • Linux
  • Ansible
归档
GitHub (opens new window)
  • Sanic

    • 开始
    • Routing
    • 请求数据
    • 响应
    • 静态资源
    • 异常
    • 中间件 和 监听器
    • 蓝图
    • WebSocket
    • 配置
    • Cookies
    • 处理装饰器
    • 流
    • 基于类的视图
    • 自定义协议
    • SSL 例子
    • 日志
    • 测试
      • pytest-sanic
    • 部署
    • 扩展
    • 贡献
    • API Reference
  • Python

  • backend
  • Sanic
devin
2023-09-07

测试

# 测试

Sanic 端可以使用 test_client 对象进行本地测试,该对象基于额外的 aiohttp (opens new window) 库。

test_client 公开 get, post, put, delete, patch, head 和 options 方法供你针对你的应用程序运行。一个简单的例子 (using pytest) 如下:

# Import the Sanic app, usually created with Sanic(__name__)
from external_server import app

def test_index_returns_200():
    request, response = app.test_client.get('/')
    assert response.status == 200

def test_index_put_not_allowed():
    request, response = app.test_client.put('/')
    assert response.status == 405
1
2
3
4
5
6
7
8
9
10

在内部,每次你调用 test_client 方法的任一,Sanic 会在 127.0.0.1:42101 执行并且你的测试请求会使用 aiohttp 针对你的应用程序进行执行。

test_client 方法接收如下参数和关键字参数:

  • uri (默认 '/') 一个要测试的 URI 字符串。
  • gather_request (默认 True) 一个确定是否被函数返回原始请求的布尔值。如果设置为 True,返回值十一个 (request, response) 的元组,如果是 False 就只返回响应。
  • server_kwargs (默认 {}) 一个在测试请求执行之前传入 app.run 的额外参数的字典。
  • debug (默认 False) 一个确定是否在调试模式启动服务的布尔值。

程序进一步采用 *request_args 和 **request_kwargs,它们直接传递给 aiohttp ClientSession 请求。

例如,要提供数据给一个 GET 请求,你可以操作如下:

def test_get_request_includes_data():
    params = {'key1': 'value1', 'key2': 'value2'}
    request, response = app.test_client.get('/', params=params)
    assert request.args.get('key1') == 'value1'
1
2
3
4

要提供数据给一个 JSON POST 请求:

def test_post_json_request_includes_data():
    data = {'key1': 'value1', 'key2': 'value2'}
    request, response = app.test_client.post('/', data=json.dumps(data))
    assert request.json.get('key1') == 'value1'
1
2
3
4

更多关于 aiohttp 有效参数的信息可以在 in the documentation for ClientSession (opens new window) 找到。

# pytest-sanic

pytest-sanic (opens new window) 十一个 pytest 插件,它帮助你异步地测试你的代码。写法如下:

async def test_sanic_db_find_by_id(app):
    """
    Let's assume that, in db we have,
        {
            "id": "123",
            "name": "Kobe Bryant",
            "team": "Lakers",
        }
    """
    doc = await app.db["players"].find_by_id("123")
    assert doc.name == "Kobe Bryant"
    assert doc.team == "Lakers"
1
2
3
4
5
6
7
8
9
10
11
12

pytest-sanic (opens new window) 还提供了一些有用的装置,如 loop, unused_port, test_server, test_client。

@pytest.yield_fixture
def app():
    app = Sanic("test_sanic_app")

    @app.route("/test_get", methods=['GET'])
    async def test_get(request):
        return response.json({"GET": True})

    @app.route("/test_post", methods=['POST'])
    async def test_post(request):
        return response.json({"POST": True})

    yield app


@pytest.fixture
def test_cli(loop, app, test_client):
    return loop.run_until_complete(test_client(app, protocol=WebSocketProtocol))


#########
# Tests #
#########

async def test_fixture_test_client_get(test_cli):
    """
    GET request
    """
    resp = await test_cli.get('/test_get')
    assert resp.status == 200
    resp_json = await resp.json()
    assert resp_json == {"GET": True}

async def test_fixture_test_client_post(test_cli):
    """
    POST request
    """
    resp = await test_cli.post('/test_post')
    assert resp.status == 200
    resp_json = await resp.json()
    assert resp_json == {"POST": True}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
编辑 (opens new window)
上次更新: 2023/09/07, 12:09:00
日志
部署

← 日志 部署→

Theme by Vdoing | Copyright © 2023-2023 devin | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式