-1

我的烧瓶应用程序有一个最纯粹的套件,效果很好。但是,我想测试一些使用第三方库 (Qt) 发送 http 请求的代码。这怎么可能?我看到flask-testing有与live_server一起完成此操作的夹具flask.url_for(),但是在夹具中启动服务器需要太多时间。

有没有更快的方法将 http 请求从第三方 http 库发送到烧瓶应用程序?

谢谢!

4

1 回答 1

1

事实证明,您可以通过手动将第三方请求转换为请求来做到这一点FlaskClient,使用monkeypatch第三方库使用的任何“发送”方法,然后将flask.Response响应转换回第三方回复对象。所有这一切都发生在不使用 TCP 端口的情况下。

这是我为将 Qt http 请求连接到烧瓶应用程序而编写的夹具:

@pytest.fixture
def qnam(qApp, client, monkeypatch):

    def sendCustomRequest(request, verb, data):
        # Qt -> Flask
        headers = []
        for name in request.rawHeaderList():
            key = bytes(name).decode('utf-8')
            value = bytes(request.rawHeader(name)).decode('utf-8')
            headers.append((key, value))
        query_string = None
        if request.url().hasQuery():
            query_string = request.url().query()
        # method = request.attribute(QNetworkRequest.CustomVerbAttribute).decode('utf-8')
        # send
        response = FlaskClient.open(client,
                                    request.url().path(),
                                    method=verb.decode('utf-8'),
                                    headers=headers,
                                    data=data)
        # Flask -> Qt
        class NetworkReply(QNetworkReply):
            def abort(self):
                pass
        reply = NetworkReply()
        reply.setAttribute(QNetworkRequest.HttpStatusCodeAttribute, response.status_code)
        for key, value in response.headers:
            reply.setRawHeader(key.encode('utf-8'), value.encode('utf-8'))
        reply.open(QIODevice.ReadWrite)
        reply.write(response.data)
        QTimer.singleShot(10, reply.finished.emit) # after return
        return reply

    qnam = QNetworkAccessManager.instance() # or wherever you get your instance

    monkeypatch.setattr(qnam, 'sendCustomRequest', sendCustomRequest)
    return ret
于 2020-01-31T18:26:49.033 回答