summaryrefslogtreecommitdiff
path: root/protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp
diff options
context:
space:
mode:
authorGeorge Hazan <ghazan@miranda.im>2022-11-30 17:48:47 +0300
committerGeorge Hazan <ghazan@miranda.im>2022-11-30 17:48:47 +0300
commit0ece30dc7c0e34b4c5911969b8fa99c33c6d023c (patch)
tree671325d3fec09b999411e4e3ab84ef8259261818 /protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp
parent46c53ffc6809c67e4607e99951a2846c382b63b2 (diff)
Telegram: update for TDLIB
Diffstat (limited to 'protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp')
-rw-r--r--protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp91
1 files changed, 42 insertions, 49 deletions
diff --git a/protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp b/protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp
index da6fbbd713..8bbd768b40 100644
--- a/protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp
+++ b/protocols/Telegram/tdlib/td/benchmark/bench_http_server_cheat.cpp
@@ -1,49 +1,46 @@
//
-// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
+// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2022
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
-#include "td/actor/actor.h"
-
#include "td/net/HttpHeaderCreator.h"
-#include "td/net/HttpInboundConnection.h"
#include "td/net/TcpListener.h"
+#include "td/actor/actor.h"
+#include "td/actor/ConcurrentScheduler.h"
+
#include "td/utils/buffer.h"
#include "td/utils/logging.h"
-#include "td/utils/port/Fd.h"
+#include "td/utils/port/detail/PollableFd.h"
#include "td/utils/port/SocketFd.h"
#include "td/utils/Slice.h"
#include "td/utils/Status.h"
#include <array>
-namespace td {
-
-// HttpInboundConnection header
static int cnt = 0;
-class HelloWorld : public Actor {
+
+class HelloWorld final : public td::Actor {
public:
- explicit HelloWorld(SocketFd socket_fd) : socket_fd_(std::move(socket_fd)) {
+ explicit HelloWorld(td::SocketFd socket_fd) : socket_fd_(std::move(socket_fd)) {
}
private:
- SocketFd socket_fd_;
+ td::SocketFd socket_fd_;
std::array<char, 1024> read_buf;
size_t read_new_lines{0};
- std::string hello_;
- std::string write_buf_;
+ td::string hello_;
+ td::string write_buf_;
size_t write_pos_{0};
- void start_up() override {
- socket_fd_.get_fd().set_observer(this);
- subscribe(socket_fd_.get_fd());
- HttpHeaderCreator hc;
- Slice content = "hello world";
- //auto content = BufferSlice("hello world");
+ void start_up() final {
+ td::Scheduler::subscribe(socket_fd_.get_poll_info().extract_pollable_fd(this));
+ td::HttpHeaderCreator hc;
+ td::Slice content = "hello world";
+ //auto content = td::BufferSlice("hello world");
hc.init_ok();
hc.set_keep_alive();
hc.set_content_size(content.size());
@@ -53,36 +50,37 @@ class HelloWorld : public Actor {
hello_ = hc.finish(content).ok().str();
}
- void loop() override {
+ void loop() final {
auto status = do_loop();
if (status.is_error()) {
- unsubscribe(socket_fd_.get_fd());
+ td::Scheduler::unsubscribe(socket_fd_.get_poll_info().get_pollable_fd_ref());
stop();
LOG(ERROR) << "CLOSE: " << status;
}
}
- Status do_loop() {
+ td::Status do_loop() {
+ sync_with_poll(socket_fd_);
TRY_STATUS(read_loop());
TRY_STATUS(write_loop());
- if (can_close(socket_fd_)) {
- return Status::Error("CLOSE");
+ if (can_close_local(socket_fd_)) {
+ return td::Status::Error("CLOSE");
}
- return Status::OK();
+ return td::Status::OK();
}
- Status write_loop() {
- while (can_write(socket_fd_) && write_pos_ < write_buf_.size()) {
- TRY_RESULT(written, socket_fd_.write(Slice(write_buf_).substr(write_pos_)));
+ td::Status write_loop() {
+ while (can_write_local(socket_fd_) && write_pos_ < write_buf_.size()) {
+ TRY_RESULT(written, socket_fd_.write(td::Slice(write_buf_).substr(write_pos_)));
write_pos_ += written;
if (write_pos_ == write_buf_.size()) {
write_pos_ = 0;
write_buf_.clear();
}
}
- return Status::OK();
+ return td::Status::OK();
}
- Status read_loop() {
- while (can_read(socket_fd_)) {
- TRY_RESULT(read_size, socket_fd_.read(MutableSlice(read_buf.data(), read_buf.size())));
+ td::Status read_loop() {
+ while (can_read_local(socket_fd_)) {
+ TRY_RESULT(read_size, socket_fd_.read(td::MutableSlice(read_buf.data(), read_buf.size())));
for (size_t i = 0; i < read_size; i++) {
if (read_buf[i] == '\n') {
read_new_lines++;
@@ -93,46 +91,41 @@ class HelloWorld : public Actor {
}
}
}
- return Status::OK();
+ return td::Status::OK();
}
};
+
const int N = 0;
-class Server : public TcpListener::Callback {
+class Server final : public td::TcpListener::Callback {
public:
- void start_up() override {
- listener_ = create_actor<TcpListener>("Listener", 8082, ActorOwn<TcpListener::Callback>(actor_id(this)));
+ void start_up() final {
+ listener_ =
+ td::create_actor<td::TcpListener>("Listener", 8082, td::ActorOwn<td::TcpListener::Callback>(actor_id(this)));
}
- void accept(SocketFd fd) override {
+ void accept(td::SocketFd fd) final {
LOG(ERROR) << "ACCEPT " << cnt++;
pos_++;
auto scheduler_id = pos_ % (N != 0 ? N : 1) + (N != 0);
- create_actor_on_scheduler<HelloWorld>("HttpInboundConnection", scheduler_id, std::move(fd)).release();
+ td::create_actor_on_scheduler<HelloWorld>("HelloWorld", scheduler_id, std::move(fd)).release();
}
- void hangup() override {
+ void hangup() final {
// may be it should be default?..
- LOG(ERROR) << "hangup..";
+ LOG(ERROR) << "Hanging up..";
stop();
}
private:
- ActorOwn<TcpListener> listener_;
+ td::ActorOwn<td::TcpListener> listener_;
int pos_{0};
};
int main() {
SET_VERBOSITY_LEVEL(VERBOSITY_NAME(ERROR));
- auto scheduler = make_unique<ConcurrentScheduler>();
- scheduler->init(N);
+ auto scheduler = td::make_unique<td::ConcurrentScheduler>(N, 0);
scheduler->create_actor_unsafe<Server>(0, "Server").release();
scheduler->start();
while (scheduler->run_main(10)) {
// empty
}
scheduler->finish();
- return 0;
-}
-} // namespace td
-
-int main() {
- return td::main();
}