2019-04-07 04:15:02 +00:00
|
|
|
#include "PipeliningTest.h"
|
2019-03-12 10:21:35 +00:00
|
|
|
#include <trantor/net/EventLoop.h>
|
|
|
|
#include <atomic>
|
|
|
|
|
2019-05-18 12:39:57 +00:00
|
|
|
void PipeliningTest::asyncHandleHttpRequest(
|
|
|
|
const HttpRequestPtr &req,
|
|
|
|
std::function<void(const HttpResponsePtr &)> &&callback)
|
2019-03-12 10:21:35 +00:00
|
|
|
{
|
2019-03-20 03:46:27 +00:00
|
|
|
static std::atomic<int> counter{0};
|
2019-03-12 10:21:35 +00:00
|
|
|
int c = counter.fetch_add(1);
|
2019-08-24 05:12:04 +00:00
|
|
|
if (c % 3 == 1)
|
|
|
|
{
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
auto str = utils::formattedString("<P>the %dth response</P>", c);
|
|
|
|
resp->addHeader("counter", utils::formattedString("%d", c));
|
|
|
|
resp->setBody(std::move(str));
|
|
|
|
callback(resp);
|
|
|
|
return;
|
|
|
|
}
|
2019-03-12 10:21:35 +00:00
|
|
|
double delay = ((double)(10 - (c % 10))) / 10.0;
|
2019-08-24 05:12:04 +00:00
|
|
|
if (c % 3 == 2)
|
|
|
|
{
|
|
|
|
// call the callback in another thread.
|
|
|
|
drogon::app().getLoop()->runAfter(delay, [c, callback]() {
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
auto str = utils::formattedString("<P>the %dth response</P>", c);
|
|
|
|
resp->addHeader("counter", utils::formattedString("%d", c));
|
|
|
|
resp->setBody(std::move(str));
|
|
|
|
callback(resp);
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
2019-05-18 12:39:57 +00:00
|
|
|
trantor::EventLoop::getEventLoopOfCurrentThread()->runAfter(
|
|
|
|
delay, [c, callback]() {
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
auto str = utils::formattedString("<P>the %dth response</P>", c);
|
|
|
|
resp->addHeader("counter", utils::formattedString("%d", c));
|
|
|
|
resp->setBody(std::move(str));
|
|
|
|
callback(resp);
|
|
|
|
});
|
2019-03-20 03:46:27 +00:00
|
|
|
}
|