2018-12-31 22:04:05 +03:00
|
|
|
//
|
2021-01-01 15:57:46 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2021
|
2018-12-31 22:04:05 +03:00
|
|
|
//
|
|
|
|
// 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/telegram/DialogId.h"
|
|
|
|
#include "td/telegram/MessageId.h"
|
|
|
|
#include "td/telegram/MessagesDb.h"
|
2018-11-28 20:18:50 +03:00
|
|
|
#include "td/telegram/NotificationId.h"
|
2019-11-26 19:33:18 +03:00
|
|
|
#include "td/telegram/ServerMessageId.h"
|
2018-12-31 22:04:05 +03:00
|
|
|
#include "td/telegram/UserId.h"
|
|
|
|
|
2019-01-07 03:17:11 +03:00
|
|
|
#include "td/db/SqliteConnectionSafe.h"
|
2019-04-26 01:47:25 +03:00
|
|
|
#include "td/db/SqliteDb.h"
|
2019-01-07 03:17:11 +03:00
|
|
|
|
2021-09-19 00:47:05 +03:00
|
|
|
#include "td/actor/ConcurrentScheduler.h"
|
|
|
|
#include "td/actor/PromiseFuture.h"
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
#include "td/utils/benchmark.h"
|
|
|
|
#include "td/utils/buffer.h"
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
#include "td/utils/logging.h"
|
|
|
|
#include "td/utils/Random.h"
|
|
|
|
#include "td/utils/Status.h"
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
|
|
|
static Status init_db(SqliteDb &db) {
|
|
|
|
TRY_STATUS(db.exec("PRAGMA encoding=\"UTF-8\""));
|
|
|
|
TRY_STATUS(db.exec("PRAGMA synchronous=NORMAL"));
|
|
|
|
TRY_STATUS(db.exec("PRAGMA journal_mode=WAL"));
|
|
|
|
TRY_STATUS(db.exec("PRAGMA temp_store=MEMORY"));
|
|
|
|
TRY_STATUS(db.exec("PRAGMA secure_delete=1"));
|
|
|
|
return Status::OK();
|
|
|
|
}
|
|
|
|
|
2021-07-04 05:58:54 +03:00
|
|
|
class MessagesDbBench final : public Benchmark {
|
2018-12-31 22:04:05 +03:00
|
|
|
public:
|
2021-07-03 23:51:36 +03:00
|
|
|
string get_description() const final {
|
2018-12-31 22:04:05 +03:00
|
|
|
return "MessagesDb";
|
|
|
|
}
|
2021-07-03 23:51:36 +03:00
|
|
|
void start_up() final {
|
2018-12-31 22:04:05 +03:00
|
|
|
LOG(ERROR) << "START UP";
|
|
|
|
do_start_up().ensure();
|
|
|
|
scheduler_->start();
|
|
|
|
}
|
2021-07-03 23:51:36 +03:00
|
|
|
void run(int n) final {
|
2018-09-18 16:43:16 +03:00
|
|
|
auto guard = scheduler_->get_main_guard();
|
2018-12-31 22:04:05 +03:00
|
|
|
for (int i = 0; i < n; i += 20) {
|
2021-09-03 12:27:59 +03:00
|
|
|
auto dialog_id = DialogId(UserId(static_cast<int64>(Random::fast(1, 100))));
|
2018-12-31 22:04:05 +03:00
|
|
|
auto message_id_raw = Random::fast(1, 100000);
|
|
|
|
for (int j = 0; j < 20; j++) {
|
|
|
|
auto message_id = MessageId{ServerMessageId{message_id_raw + j}};
|
|
|
|
auto unique_message_id = ServerMessageId{i + 1};
|
2021-09-03 12:27:59 +03:00
|
|
|
auto sender_user_id = UserId(static_cast<int64>(Random::fast(1, 1000)));
|
2018-12-31 22:04:05 +03:00
|
|
|
auto random_id = i + 1;
|
|
|
|
auto ttl_expires_at = 0;
|
|
|
|
auto data = BufferSlice(Random::fast(100, 299));
|
|
|
|
|
|
|
|
// use async on same thread.
|
|
|
|
messages_db_async_->add_message({dialog_id, message_id}, unique_message_id, sender_user_id, random_id,
|
2020-09-28 15:13:25 +03:00
|
|
|
ttl_expires_at, 0, 0, "", NotificationId(), MessageId(), std::move(data),
|
|
|
|
Promise<>());
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-07-03 23:51:36 +03:00
|
|
|
void tear_down() final {
|
2018-12-31 22:04:05 +03:00
|
|
|
scheduler_->run_main(0.1);
|
|
|
|
{
|
2018-09-18 16:43:16 +03:00
|
|
|
auto guard = scheduler_->get_main_guard();
|
2018-12-31 22:04:05 +03:00
|
|
|
sql_connection_.reset();
|
|
|
|
messages_db_sync_safe_.reset();
|
|
|
|
messages_db_async_.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
scheduler_->finish();
|
|
|
|
scheduler_.reset();
|
|
|
|
LOG(ERROR) << "TEAR DOWN";
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2019-01-07 03:17:11 +03:00
|
|
|
td::unique_ptr<ConcurrentScheduler> scheduler_;
|
2018-12-31 22:04:05 +03:00
|
|
|
std::shared_ptr<SqliteConnectionSafe> sql_connection_;
|
|
|
|
std::shared_ptr<MessagesDbSyncSafeInterface> messages_db_sync_safe_;
|
|
|
|
std::shared_ptr<MessagesDbAsyncInterface> messages_db_async_;
|
|
|
|
|
|
|
|
Status do_start_up() {
|
2018-09-27 04:19:03 +03:00
|
|
|
scheduler_ = make_unique<ConcurrentScheduler>();
|
2018-12-31 22:04:05 +03:00
|
|
|
scheduler_->init(1);
|
|
|
|
|
2018-09-18 16:43:16 +03:00
|
|
|
auto guard = scheduler_->get_main_guard();
|
2018-12-31 22:04:05 +03:00
|
|
|
|
|
|
|
string sql_db_name = "testdb.sqlite";
|
2021-09-22 17:20:10 +03:00
|
|
|
sql_connection_ = std::make_shared<SqliteConnectionSafe>(sql_db_name, DbKey::empty());
|
2018-12-31 22:04:05 +03:00
|
|
|
auto &db = sql_connection_->get();
|
|
|
|
TRY_STATUS(init_db(db));
|
|
|
|
|
|
|
|
db.exec("BEGIN TRANSACTION").ensure();
|
|
|
|
// version == 0 ==> db will be destroyed
|
|
|
|
TRY_STATUS(init_messages_db(db, 0));
|
|
|
|
db.exec("COMMIT TRANSACTION").ensure();
|
|
|
|
|
|
|
|
messages_db_sync_safe_ = create_messages_db_sync(sql_connection_);
|
|
|
|
messages_db_async_ = create_messages_db_async(messages_db_sync_safe_, 0);
|
|
|
|
return Status::OK();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} // namespace td
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
SET_VERBOSITY_LEVEL(VERBOSITY_NAME(WARNING));
|
|
|
|
bench(td::MessagesDbBench());
|
|
|
|
}
|