oceanbase/unittest/libobcdc/test_log_config.cpp
wangzelin.wzl 93a1074b0c patch 4.0
2022-10-24 17:57:12 +08:00

277 lines
9.6 KiB
C++

/**
* Copyright (c) 2021 OceanBase
* OceanBase CE is licensed under Mulan PubL v2.
* You can use this software according to the terms and conditions of the Mulan PubL v2.
* You may obtain a copy of Mulan PubL v2 at:
* http://license.coscl.org.cn/MulanPubL-2.0
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PubL v2 for more details.
*
* Test ObLogConfig
*/
#include <gtest/gtest.h>
#include "ob_log_config.h"
#define ADD_CONFIG_INT(var, value) \
do { \
std::string name_str = #var; \
std::string value_str = #value; \
var = value; \
databuff_printf(config_buf_, sizeof(config_buf_), config_buf_pos_, "%s=%ld\n", #var, var); \
config_map_.erase(name_str); \
config_map_.insert(std::pair<std::string, std::string>(name_str, value_str)); \
} while (0)
#define ADD_CONFIG_STR(var, value) \
do { \
std::string name_str = #var; \
std::string value_str = value; \
var = value; \
databuff_printf(config_buf_, sizeof(config_buf_), config_buf_pos_, "%s=%s\n", #var, var); \
config_map_.erase(name_str); \
config_map_.insert(std::pair<std::string, std::string>(name_str, value_str)); \
} while (0)
using namespace oceanbase::common;
namespace oceanbase
{
namespace libobcdc
{
class TestLogConfig : public ::testing::Test
{
static const int64_t MAX_CONFIG_BUFFER_SIZE = 1 << 10;
public:
TestLogConfig() {}
~TestLogConfig() {}
virtual void SetUp();
virtual void TearDown() {}
public:
int64_t dml_parser_thread_num;
int64_t sequencer_thread_num;
int64_t formatter_thread_num;
int64_t instance_num;
int64_t instance_index;
const char *log_level;
const char *cluster_url;
const char *cluster_user;
const char *cluster_password;
const char *config_fpath;
const char *cluster_appname;
const char *cluster_db_name;
const char *timezone;
const char *tb_white_list;
const char *tb_black_list;
int64_t sql_conn_timeout_us;
int64_t sql_query_timeout_us;
int64_t unknown_int_config;
const char *unknown_str_config;
char config_buf_[MAX_CONFIG_BUFFER_SIZE];
int64_t config_buf_pos_;
std::map<std::string, std::string> config_map_;
};
void TestLogConfig::SetUp()
{
config_buf_pos_ = 0;
ADD_CONFIG_INT(dml_parser_thread_num, 100);
ADD_CONFIG_INT(sequencer_thread_num, 200);
ADD_CONFIG_INT(formatter_thread_num, 300);
ADD_CONFIG_INT(instance_num, 1);
ADD_CONFIG_INT(instance_index, 0);
ADD_CONFIG_INT(sql_conn_timeout_us, 13000000000);
ADD_CONFIG_INT(sql_query_timeout_us, 12000000000);
ADD_CONFIG_STR(log_level, "INFO");
ADD_CONFIG_STR(cluster_url, "http:://www.test_url.com/abcdefg/");
ADD_CONFIG_STR(cluster_user, "中华人民共和国");
ADD_CONFIG_STR(cluster_password, "阿里巴巴");
ADD_CONFIG_STR(config_fpath, "/home/abcdefg/hijklmn");
ADD_CONFIG_STR(cluster_appname, "obtest");
ADD_CONFIG_STR(cluster_db_name, "oceanbase");
ADD_CONFIG_STR(timezone, "+8:00");
ADD_CONFIG_STR(tb_white_list, "*.*.*");
ADD_CONFIG_STR(tb_black_list, "|");
// test unknown config
ADD_CONFIG_INT(unknown_int_config, 1010);
ADD_CONFIG_STR(unknown_str_config, "unknown");
}
TEST_F(TestLogConfig, init)
{
ObLogConfig *config = new ObLogConfig();
EXPECT_EQ(OB_SUCCESS, config->init());
// After initialization, the configuration items are not detected by default
EXPECT_NE(OB_SUCCESS, config->check_all());
config->print();
if (NULL != config) {
delete config;
config = NULL;
}
}
TEST_F(TestLogConfig, load_from_buffer)
{
ObLogConfig *config = new ObLogConfig();
EXPECT_EQ(OB_SUCCESS, config->init());
EXPECT_EQ(OB_SUCCESS, config->load_from_buffer(config_buf_, strlen(config_buf_)));
EXPECT_EQ(OB_SUCCESS, config->check_all());
config->print();
EXPECT_EQ(dml_parser_thread_num, config->dml_parser_thread_num);
EXPECT_EQ(sequencer_thread_num, config->sequencer_thread_num);
EXPECT_EQ(formatter_thread_num, config->formatter_thread_num);
EXPECT_EQ(0, strcmp(cluster_url, config->cluster_url.str()));
EXPECT_EQ(0, strcmp(log_level, config->log_level.str()));
EXPECT_EQ(0, strcmp(cluster_user, config->cluster_user.str()));
EXPECT_EQ(0, strcmp(cluster_password, config->cluster_password.str()));
EXPECT_EQ(0, strcmp(config_fpath, config->config_fpath.str()));
bool check_name = true;
int64_t version = 0;
EXPECT_NE(OB_SUCCESS,
config->load_from_buffer(config_buf_, strlen(config_buf_), version, check_name));
if (NULL != config) {
delete config;
config = NULL;
}
}
TEST_F(TestLogConfig, load_from_map)
{
ObLogConfig *config = new ObLogConfig();
EXPECT_EQ(OB_SUCCESS, config->init());
EXPECT_EQ(OB_SUCCESS, config->load_from_map(config_map_));
EXPECT_EQ(OB_SUCCESS, config->check_all());
config->print();
EXPECT_EQ(dml_parser_thread_num, config->dml_parser_thread_num);
EXPECT_EQ(sequencer_thread_num, config->sequencer_thread_num);
EXPECT_EQ(formatter_thread_num, config->formatter_thread_num);
EXPECT_EQ(0, strcmp(cluster_url, config->cluster_url.str()));
EXPECT_EQ(0, strcmp(log_level, config->log_level.str()));
EXPECT_EQ(0, strcmp(cluster_user, config->cluster_user.str()));
EXPECT_EQ(0, strcmp(cluster_password, config->cluster_password.str()));
EXPECT_EQ(0, strcmp(config_fpath, config->config_fpath.str()));
bool check_name = true;
int64_t version = 0;
EXPECT_NE(OB_SUCCESS, config->load_from_map(config_map_, version, check_name));
if (NULL != config) {
delete config;
config = NULL;
}
}
TEST_F(TestLogConfig, load_from_file)
{
// The ObLogConfig class is larger than the local variable stack and would overflow if located
// Therefore, the dynamic construction method is used here
ObLogConfig *config_from_buffer_ptr = new ObLogConfig();
ObLogConfig *config_from_file_ptr = new ObLogConfig();
EXPECT_EQ(OB_SUCCESS, config_from_buffer_ptr->init());
EXPECT_EQ(OB_SUCCESS, config_from_file_ptr->init());
ObLogConfig &config_from_buffer = *config_from_buffer_ptr;
ObLogConfig &config_from_file = *config_from_file_ptr;
const char *config_file = "libobcdc.conf";
// Load configuration items from the Buffer and verify the accuracy of the configuration items
EXPECT_EQ(OB_SUCCESS, config_from_buffer.load_from_buffer(config_buf_, strlen(config_buf_)));
EXPECT_EQ(OB_SUCCESS, config_from_buffer.check_all());
config_from_buffer.print();
EXPECT_EQ(dml_parser_thread_num, config_from_buffer.dml_parser_thread_num);
EXPECT_EQ(sequencer_thread_num, config_from_buffer.sequencer_thread_num);
EXPECT_EQ(formatter_thread_num, config_from_buffer.formatter_thread_num);
EXPECT_EQ(0, strcmp(cluster_url, config_from_buffer.cluster_url.str()));
EXPECT_EQ(0, strcmp(log_level, config_from_buffer.log_level.str()));
EXPECT_EQ(0, strcmp(cluster_user, config_from_buffer.cluster_user.str()));
EXPECT_EQ(0, strcmp(cluster_password, config_from_buffer.cluster_password.str()));
EXPECT_EQ(0, strcmp(config_fpath, config_from_buffer.config_fpath.str()));
// Dump configuration items into a file
EXPECT_EQ(OB_SUCCESS, config_from_buffer.dump2file(config_file));
// Loading configuration items from a file
EXPECT_EQ(OB_SUCCESS, config_from_file.load_from_file(config_file));
// Verify the accuracy of configuration items
config_from_file.print();
EXPECT_EQ(dml_parser_thread_num, config_from_file.dml_parser_thread_num);
EXPECT_EQ(sequencer_thread_num, config_from_file.sequencer_thread_num);
EXPECT_EQ(formatter_thread_num, config_from_file.formatter_thread_num);
EXPECT_EQ(0, strcmp(cluster_url, config_from_file.cluster_url.str()));
EXPECT_EQ(0, strcmp(log_level, config_from_file.log_level.str()));
EXPECT_EQ(0, strcmp(cluster_user, config_from_file.cluster_user.str()));
EXPECT_EQ(0, strcmp(cluster_password, config_from_file.cluster_password.str()));
EXPECT_EQ(0, strcmp(config_fpath, config_from_file.config_fpath.str()));
if (NULL != config_from_buffer_ptr) {
delete config_from_buffer_ptr;
config_from_buffer_ptr = NULL;
}
if (NULL != config_from_file_ptr) {
delete config_from_file_ptr;
config_from_file_ptr = NULL;
}
}
// Check that the ObLogConfig::check_all() function actually formats the cluster_url
// default check_all() removes the double quotes from cluster_url
TEST_F(TestLogConfig, format_cluster_url)
{
ObLogConfig *config = new ObLogConfig();
EXPECT_EQ(OB_SUCCESS, config->init());
const char *URL = "http://abc.com/def/hijklmn";
char cluster_url[1024];
ASSERT_EQ(OB_SUCCESS, config->load_from_buffer(config_buf_, strlen(config_buf_)));
ASSERT_EQ(OB_SUCCESS, config->check_all());
snprintf(cluster_url, sizeof(cluster_url), "\"");
ASSERT_TRUE(config->cluster_url.set_value(cluster_url));
ASSERT_NE(OB_SUCCESS, config->format_cluster_url());
snprintf(cluster_url, sizeof(cluster_url), "\"\"");
ASSERT_TRUE(config->cluster_url.set_value(cluster_url));
ASSERT_NE(OB_SUCCESS, config->format_cluster_url());
snprintf(cluster_url, sizeof(cluster_url), "\"%s\"", URL);
ASSERT_TRUE(config->cluster_url.set_value(cluster_url));
ASSERT_EQ(OB_SUCCESS, config->format_cluster_url());
EXPECT_EQ(0, strcmp(URL, config->cluster_url.str()));
// No handling of single inverted commas
snprintf(cluster_url, sizeof(cluster_url), "\'\'");
ASSERT_TRUE(config->cluster_url.set_value(cluster_url));
ASSERT_EQ(OB_SUCCESS, config->format_cluster_url());
if (NULL != config) {
delete config;
config = NULL;
}
}
} // namespace libobcdc
} // namespace oceanbase
int main(int argc, char **argv)
{
oceanbase::common::ObLogger::get_logger().set_log_level("INFO");
OB_LOGGER.set_log_level("INFO");
testing::InitGoogleTest(&argc, argv);
return RUN_ALL_TESTS();
}