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();
|
|
|
|
}
|