drogon/examples/simple_example_test/HttpPipeliningTest.cc

49 lines
1.4 KiB
C++
Raw Normal View History

2019-04-07 04:15:02 +00:00
#include <drogon/HttpClient.h>
#include <drogon/HttpAppFramework.h>
#include <string>
#include <iostream>
#include <atomic>
using namespace drogon;
int main()
{
trantor::Logger::setLogLevel(trantor::Logger::TRACE);
auto client = HttpClient::newHttpClient("127.0.0.1", 8848);
client->setPipeliningDepth(64);
auto request = HttpRequest::newHttpRequest();
request->setPath("/pipe");
int counter = -1;
int n = 0;
for (int i = 0; i < 20; i++)
{
2019-05-18 12:39:57 +00:00
client->sendRequest(
request, [&counter, &n](ReqResult r, const HttpResponsePtr &resp) {
if (r == ReqResult::Ok)
2019-04-07 04:15:02 +00:00
{
2019-05-18 12:39:57 +00:00
auto counterHeader = resp->getHeader("counter");
int c = atoi(counterHeader.data());
if (c <= counter)
{
LOG_ERROR
<< "The response was received in the wrong order!";
exit(-1);
}
else
{
counter = c;
n++;
if (n == 20)
{
LOG_DEBUG << "Good!";
app().getLoop()->quit();
}
}
2019-04-07 04:15:02 +00:00
}
else
{
2019-05-18 12:39:57 +00:00
exit(-1);
2019-04-07 04:15:02 +00:00
}
2019-05-18 12:39:57 +00:00
});
2019-04-07 04:15:02 +00:00
}
app().run();
}