我的烧瓶应用程序有一个最纯粹的套件,效果很好。但是,我想测试一些使用第三方库 (Qt) 发送 http 请求的代码。这怎么可能?我看到flask-testing
有与live_server
一起完成此操作的夹具flask.url_for()
,但是在夹具中启动服务器需要太多时间。
有没有更快的方法将 http 请求从第三方 http 库发送到烧瓶应用程序?
谢谢!
我的烧瓶应用程序有一个最纯粹的套件,效果很好。但是,我想测试一些使用第三方库 (Qt) 发送 http 请求的代码。这怎么可能?我看到flask-testing
有与live_server
一起完成此操作的夹具flask.url_for()
,但是在夹具中启动服务器需要太多时间。
有没有更快的方法将 http 请求从第三方 http 库发送到烧瓶应用程序?
谢谢!
事实证明,您可以通过手动将第三方请求转换为请求来做到这一点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