489 lines
20 KiB
C++
489 lines
20 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.
|
|
*/
|
|
|
|
#define USING_LOG_PREFIX RS
|
|
|
|
#include <gtest/gtest.h>
|
|
#include <gmock/gmock.h>
|
|
#include <time.h>
|
|
#include "share/ob_errno.h"
|
|
#include "share/restore/ob_import_arg.h"
|
|
#include "share/restore/ob_import_util.h"
|
|
|
|
|
|
using namespace oceanbase;
|
|
using namespace common;
|
|
using namespace share;
|
|
|
|
class ImportTableTest : public testing::Test
|
|
{
|
|
public:
|
|
ImportTableTest() {}
|
|
virtual ~ImportTableTest(){}
|
|
virtual void SetUp() {};
|
|
virtual void TearDown() {}
|
|
virtual void TestBody() {}
|
|
};
|
|
|
|
TEST_F(ImportTableTest, test_import_database)
|
|
{
|
|
ObImportDatabaseArray import_db_array;
|
|
ObImportDatabaseItem db1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem db2(OB_ORIGIN_AND_SENSITIVE, "db2", strlen("db2"));
|
|
ObImportDatabaseItem db3(OB_ORIGIN_AND_SENSITIVE, "db3", strlen("db3"));
|
|
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.add_item(db1));
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.add_item(db2));
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.add_item(db3));
|
|
|
|
const char *format_str = "`db1`,`db2`,`db3`";
|
|
char format_buff[1024];
|
|
memset(format_buff, 0, 1024);
|
|
int64_t pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
char hex_format_buff[1024];
|
|
pos = 0;
|
|
memset(hex_format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.hex_format_serialize(hex_format_buff, 1024, pos));
|
|
ASSERT_EQ(pos, import_db_array.get_hex_format_serialize_size());
|
|
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.hex_format_deserialize(hex_format_buff, import_db_array.get_hex_format_serialize_size(), pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
pos = 0;
|
|
char buff[1024];
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array.serialize(buff, 1024, pos));
|
|
ASSERT_EQ(import_db_array.get_serialize_size(), pos);
|
|
|
|
pos = 0;
|
|
ObImportDatabaseArray import_db_array_bak;
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array_bak.deserialize(buff, 1024, pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_db_array_bak.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
}
|
|
|
|
TEST_F(ImportTableTest, test_import_table)
|
|
{
|
|
ObImportTableArray import_table_array;
|
|
ObImportTableItem tb1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb1", strlen("tb1"));
|
|
ObImportTableItem tb2(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb2", strlen("tb2"));
|
|
ObImportTableItem tb3(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb,3", strlen("tb,3"));
|
|
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.add_item(tb1));
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.add_item(tb2));
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.add_item(tb3));
|
|
|
|
const char *format_str = "`db1`.`tb1`,`db1`.`tb2`,`db1`.`tb,3`";
|
|
char format_buff[1024];
|
|
int64_t pos = 0;
|
|
memset(format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
char hex_format_buff[1024];
|
|
pos = 0;
|
|
memset(hex_format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.hex_format_serialize(hex_format_buff, 1024, pos));
|
|
ASSERT_EQ(pos, import_table_array.get_hex_format_serialize_size());
|
|
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.hex_format_deserialize(hex_format_buff, import_table_array.get_hex_format_serialize_size(), pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
pos = 0;
|
|
char buff[1024];
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array.serialize(buff, 1024, pos));
|
|
ASSERT_EQ(import_table_array.get_serialize_size(), pos);
|
|
|
|
pos = 0;
|
|
ObImportTableArray import_table_array_bak;
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array_bak.deserialize(buff, 1024, pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_table_array_bak.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
}
|
|
|
|
|
|
TEST_F(ImportTableTest, test_import_partition)
|
|
{
|
|
ObImportPartitionArray import_part_array;
|
|
ObImportPartitionItem p1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb1", strlen("tb1"), "p1", strlen("p1"));
|
|
ObImportPartitionItem p2(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb2", strlen("tb2"), "p1", strlen("p1"));
|
|
ObImportPartitionItem p3(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb,3", strlen("tb,3"), "p1", strlen("p1"));
|
|
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.add_item(p1));
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.add_item(p2));
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.add_item(p3));
|
|
|
|
const char *format_str = "`db1`.`tb1`:`p1`,`db1`.`tb2`:`p1`,`db1`.`tb,3`:`p1`";
|
|
char format_buff[1024];
|
|
int64_t pos = 0;
|
|
memset(format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
char hex_format_buff[1024];
|
|
pos = 0;
|
|
memset(hex_format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.hex_format_serialize(hex_format_buff, 1024, pos));
|
|
ASSERT_EQ(pos, import_part_array.get_hex_format_serialize_size());
|
|
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.hex_format_deserialize(hex_format_buff, import_part_array.get_hex_format_serialize_size(), pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
pos = 0;
|
|
char buff[1024];
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array.serialize(buff, 1024, pos));
|
|
ASSERT_EQ(import_part_array.get_serialize_size(), pos);
|
|
|
|
pos = 0;
|
|
ObImportPartitionArray import_part_array_bak;
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array_bak.deserialize(buff, 1024, pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, import_part_array_bak.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
}
|
|
|
|
|
|
TEST_F(ImportTableTest, test_remap_database)
|
|
{
|
|
ObRemapDatabaseArray remap_db_array;
|
|
ObImportDatabaseItem src_db1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem target_db1(OB_ORIGIN_AND_SENSITIVE, "db1_bak", strlen("db1_bak"));
|
|
ObImportDatabaseItem src_db2(OB_ORIGIN_AND_SENSITIVE, "db2", strlen("db2"));
|
|
ObImportDatabaseItem target_db2(OB_ORIGIN_AND_SENSITIVE, "db2_bak", strlen("db2_bak"));
|
|
ObImportDatabaseItem src_db3(OB_ORIGIN_AND_SENSITIVE, "db3", strlen("db3"));
|
|
ObImportDatabaseItem target_db3(OB_ORIGIN_AND_SENSITIVE, "db3_bak", strlen("db3_bak"));
|
|
|
|
ObRemapDatabaseItem remap_db1;
|
|
remap_db1.src_ = src_db1;
|
|
remap_db1.target_ = target_db1;
|
|
|
|
ObRemapDatabaseItem remap_db2;
|
|
remap_db2.src_ = src_db2;
|
|
remap_db2.target_ = target_db2;
|
|
|
|
ObRemapDatabaseItem remap_db3;
|
|
remap_db3.src_ = src_db3;
|
|
remap_db3.target_ = target_db3;
|
|
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.add_item(remap_db1));
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.add_item(remap_db2));
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.add_item(remap_db3));
|
|
|
|
const char *format_str = "`db1`:`db1_bak`,`db2`:`db2_bak`,`db3`:`db3_bak`";
|
|
char format_buff[1024];
|
|
memset(format_buff, 0, 1024);
|
|
int64_t pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
char hex_format_buff[1024];
|
|
memset(hex_format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.hex_format_serialize(hex_format_buff, 1024, pos));
|
|
ASSERT_EQ(pos, remap_db_array.get_hex_format_serialize_size());
|
|
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.hex_format_deserialize(hex_format_buff, remap_db_array.get_hex_format_serialize_size(), pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
pos = 0;
|
|
char buff[1024];
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array.serialize(buff, 1024, pos));
|
|
|
|
pos = 0;
|
|
ObRemapDatabaseArray remap_db_array_bak;
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array_bak.deserialize(buff, 1024, pos));
|
|
pos = 0;
|
|
memset(format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, remap_db_array_bak.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_buff));
|
|
}
|
|
|
|
|
|
TEST_F(ImportTableTest, test_remap_table)
|
|
{
|
|
ObRemapTableArray remap_table_array;
|
|
ObImportTableItem src_tb1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb1", strlen("tb1"));
|
|
ObImportTableItem target_tb1(OB_ORIGIN_AND_SENSITIVE, "db1_bak", strlen("db1_bak"), "tb1_bak", strlen("tb1_bak"));
|
|
ObImportTableItem src_tb2(OB_ORIGIN_AND_SENSITIVE, "db2", strlen("db2"), "tb1", strlen("tb1"));
|
|
ObImportTableItem target_tb2(OB_ORIGIN_AND_SENSITIVE, "db2_bak", strlen("db2_bak"), "tb1_bak", strlen("tb1_bak"));
|
|
ObImportTableItem src_tb3(OB_ORIGIN_AND_SENSITIVE, "db3", strlen("db3"), "tb1,", strlen("tb1,"));
|
|
ObImportTableItem target_tb3(OB_ORIGIN_AND_SENSITIVE, "db3_bak", strlen("db3_bak"), "tb1,_bak", strlen("tb1,_bak"));
|
|
|
|
ObRemapTableItem remap_tb1;
|
|
remap_tb1.src_ = src_tb1;
|
|
remap_tb1.target_ = target_tb1;
|
|
|
|
ObRemapTableItem remap_tb2;
|
|
remap_tb2.src_ = src_tb2;
|
|
remap_tb2.target_ = target_tb2;
|
|
|
|
ObRemapTableItem remap_tb3;
|
|
remap_tb3.src_ = src_tb3;
|
|
remap_tb3.target_ = target_tb3;
|
|
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.add_item(remap_tb1));
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.add_item(remap_tb2));
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.add_item(remap_tb3));
|
|
|
|
const char *format_str = "`db1`.`tb1`:`db1_bak`.`tb1_bak`,`db2`.`tb1`:`db2_bak`.`tb1_bak`,`db3`.`tb1,`:`db3_bak`.`tb1,_bak`";
|
|
char format_buff[1024];
|
|
memset(format_buff, 0, 1024);
|
|
int64_t pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
char hex_format_buff[1024];
|
|
memset(hex_format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.hex_format_serialize(hex_format_buff, 1024, pos));
|
|
ASSERT_EQ(pos, remap_table_array.get_hex_format_serialize_size());
|
|
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.hex_format_deserialize(hex_format_buff, remap_table_array.get_hex_format_serialize_size(), pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
pos = 0;
|
|
char buff[1024];
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array.serialize(buff, 1024, pos));
|
|
|
|
pos = 0;
|
|
ObRemapTableArray remap_table_array_bak;
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array_bak.deserialize(buff, 1024, pos));
|
|
pos = 0;
|
|
memset(format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, remap_table_array_bak.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_buff));
|
|
}
|
|
|
|
|
|
|
|
TEST_F(ImportTableTest, test_remap_partition)
|
|
{
|
|
ObRemapPartitionArray remap_part_array;
|
|
ObImportPartitionItem src_part1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb1", strlen("tb1"), "p1", strlen("p1"));
|
|
ObImportTableItem target_tb1(OB_ORIGIN_AND_SENSITIVE, "db1_bak", strlen("db1_bak"), "tb1_p1", strlen("tb1_p1"));
|
|
ObImportPartitionItem src_part2(OB_ORIGIN_AND_SENSITIVE, "db2", strlen("db2"), "tb1", strlen("tb1"), "p1", strlen("p1"));
|
|
ObImportTableItem target_tb2(OB_ORIGIN_AND_SENSITIVE, "db2_bak", strlen("db2_bak"), "tb1_p1", strlen("tb1_p1"));
|
|
ObImportPartitionItem src_part3(OB_ORIGIN_AND_SENSITIVE, "db3", strlen("db3"), "tb1,", strlen("tb1,"), "p1", strlen("p1"));
|
|
ObImportTableItem target_tb3(OB_ORIGIN_AND_SENSITIVE, "db3_bak", strlen("db3_bak"), "tb1,_p1", strlen("tb1,_p1"));
|
|
|
|
ObRemapPartitionItem remap_p1;
|
|
remap_p1.src_ = src_part1;
|
|
remap_p1.target_ = target_tb1;
|
|
|
|
ObRemapPartitionItem remap_p2;
|
|
remap_p2.src_ = src_part2;
|
|
remap_p2.target_ = target_tb2;
|
|
|
|
ObRemapPartitionItem remap_p3;
|
|
remap_p3.src_ = src_part3;
|
|
remap_p3.target_ = target_tb3;
|
|
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.add_item(remap_p1));
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.add_item(remap_p2));
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.add_item(remap_p3));
|
|
|
|
const char *format_str = "`db1`.`tb1`:`p1`:`db1_bak`.`tb1_p1`,`db2`.`tb1`:`p1`:`db2_bak`.`tb1_p1`,`db3`.`tb1,`:`p1`:`db3_bak`.`tb1,_p1`";
|
|
char format_buff[1024];
|
|
memset(format_buff, 0, 1024);
|
|
int64_t pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
char hex_format_buff[1024];
|
|
memset(hex_format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.hex_format_serialize(hex_format_buff, 1024, pos));
|
|
ASSERT_EQ(pos, remap_part_array.get_hex_format_serialize_size());
|
|
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.hex_format_deserialize(hex_format_buff, remap_part_array.get_hex_format_serialize_size(), pos));
|
|
memset(format_buff, 0, 1024);
|
|
pos = 0;
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_str));
|
|
|
|
pos = 0;
|
|
char buff[1024];
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array.serialize(buff, 1024, pos));
|
|
|
|
pos = 0;
|
|
ObRemapPartitionArray remap_part_array_bak;
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array_bak.deserialize(buff, 1024, pos));
|
|
pos = 0;
|
|
memset(format_buff, 0, 1024);
|
|
ASSERT_EQ(OB_SUCCESS, remap_part_array_bak.format_serialize(format_buff, 1024, pos));
|
|
ASSERT_EQ(0, strcmp(format_buff, format_buff));
|
|
}
|
|
|
|
|
|
TEST_F(ImportTableTest, test_import_conflict)
|
|
{
|
|
ObImportArg arg;
|
|
ObImportDatabaseItem db1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem db2(OB_ORIGIN_AND_SENSITIVE, "db2", strlen("db2"));
|
|
ObImportDatabaseItem db3(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"));
|
|
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_import_database(db1));
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_import_database(db2));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_import_database(db3));
|
|
|
|
ObImportTableItem tb1(OB_ORIGIN_AND_SENSITIVE, "db3", strlen("db3"), "tb1", strlen("tb1"));
|
|
ObImportTableItem tb2(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb2", strlen("tb2"));
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_import_table(tb1));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_import_table(tb2));
|
|
}
|
|
|
|
TEST_F(ImportTableTest, test_remap_conflict)
|
|
{
|
|
ObImportArg arg;
|
|
ObImportDatabaseItem src_db1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem target_db1(OB_ORIGIN_AND_SENSITIVE, "db1_bak", strlen("db1_bak"));
|
|
ObImportDatabaseItem src_db2(OB_ORIGIN_AND_SENSITIVE, "db2", strlen("db2"));
|
|
ObImportDatabaseItem target_db2(OB_ORIGIN_AND_SENSITIVE, "db2_bak", strlen("db2_bak"));
|
|
ObImportDatabaseItem src_db3(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem target_db3(OB_ORIGIN_AND_SENSITIVE, "db3_bak", strlen("db3_bak"));
|
|
ObImportDatabaseItem src_db4(OB_ORIGIN_AND_SENSITIVE, "db4", strlen("db4"));
|
|
ObImportDatabaseItem target_db4(OB_ORIGIN_AND_SENSITIVE, "db2_bak", strlen("db2_bak"));
|
|
|
|
ObRemapDatabaseItem remap_db1;
|
|
remap_db1.src_ = src_db1;
|
|
remap_db1.target_ = target_db1;
|
|
|
|
ObRemapDatabaseItem remap_db2;
|
|
remap_db2.src_ = src_db2;
|
|
remap_db2.target_ = target_db2;
|
|
|
|
ObRemapDatabaseItem remap_db3;
|
|
remap_db3.src_ = src_db3;
|
|
remap_db3.target_ = target_db3;
|
|
|
|
ObRemapDatabaseItem remap_db4;
|
|
remap_db4.src_ = src_db4;
|
|
remap_db4.target_ = target_db4;
|
|
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_remap_database(remap_db1));
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_remap_database(remap_db2));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_remap_database(remap_db3));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_remap_database(remap_db4));
|
|
|
|
|
|
ObImportTableItem src_tb1(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb1", strlen("tb1"));
|
|
ObImportTableItem target_tb1(OB_ORIGIN_AND_SENSITIVE, "db1_bak", strlen("db1_bak"), "tb1_bak", strlen("tb1_bak"));
|
|
ObImportTableItem src_tb2(OB_ORIGIN_AND_SENSITIVE, "db1", strlen("db1"), "tb1", strlen("tb1"));
|
|
ObImportTableItem target_tb2(OB_ORIGIN_AND_SENSITIVE, "db2_bak", strlen("db2_bak"), "tb1_bak", strlen("tb1_bak"));
|
|
ObImportTableItem src_tb3(OB_ORIGIN_AND_SENSITIVE, "db3", strlen("db3"), "tb1", strlen("tb1"));
|
|
ObImportTableItem target_tb3(OB_ORIGIN_AND_SENSITIVE, "db1_bak", strlen("db1_bak"), "tb1_bak", strlen("tb1_bak"));
|
|
|
|
ObRemapTableItem remap_tb1;
|
|
remap_tb1.src_ = src_tb1;
|
|
remap_tb1.target_ = target_tb1;
|
|
|
|
ObRemapTableItem remap_tb2;
|
|
remap_tb2.src_ = src_tb2;
|
|
remap_tb2.target_ = target_tb2;
|
|
|
|
ObRemapTableItem remap_tb3;
|
|
remap_tb3.src_ = src_tb3;
|
|
remap_tb3.target_ = target_tb3;
|
|
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_remap_table(remap_tb1));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_remap_table(remap_tb2));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_remap_table(remap_tb3));
|
|
}
|
|
|
|
TEST_F(ImportTableTest, test_namecase_mode)
|
|
{
|
|
ObImportArg arg;
|
|
ObImportDatabaseItem db1(OB_LOWERCASE_AND_INSENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem db2(OB_LOWERCASE_AND_INSENSITIVE, "db2", strlen("db2"));
|
|
ObImportDatabaseItem db3(OB_LOWERCASE_AND_INSENSITIVE, "DB1", strlen("DB1"));
|
|
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_import_database(db1));
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_import_database(db2));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_import_database(db3));
|
|
|
|
ObImportTableItem tb1(OB_LOWERCASE_AND_INSENSITIVE, "Db1", strlen("Db1"), "tb1", strlen("tb1"));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_import_table(tb1));
|
|
|
|
|
|
ObImportDatabaseItem src_db1(OB_LOWERCASE_AND_INSENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem target_db1(OB_LOWERCASE_AND_INSENSITIVE, "db1_bak", strlen("db1_bak"));
|
|
ObImportDatabaseItem src_db2(OB_LOWERCASE_AND_INSENSITIVE, "db1", strlen("db1"));
|
|
ObImportDatabaseItem target_db2(OB_LOWERCASE_AND_INSENSITIVE, "db1_Bak", strlen("db1_Bak"));
|
|
|
|
ObRemapDatabaseItem remap_db1;
|
|
remap_db1.src_ = src_db1;
|
|
remap_db1.target_ = target_db1;
|
|
|
|
ObRemapDatabaseItem remap_db2;
|
|
remap_db2.src_ = src_db2;
|
|
remap_db2.target_ = target_db2;
|
|
|
|
ASSERT_EQ(OB_SUCCESS, arg.add_remap_database(remap_db1));
|
|
ASSERT_EQ(OB_BACKUP_CONFLICT_VALUE, arg.add_remap_database(remap_db2));
|
|
}
|
|
|
|
TEST_F(ImportTableTest, test_check_aux_tenant)
|
|
{
|
|
const ObString tenant_name_1("AUX_RECOVER$1694673215667468");
|
|
bool is_recover_table_aux_tenant = false;
|
|
ASSERT_EQ(OB_SUCCESS, ObImportTableUtil::check_is_recover_table_aux_tenant_name(tenant_name_1, is_recover_table_aux_tenant));
|
|
ASSERT_EQ(true, is_recover_table_aux_tenant);
|
|
const ObString tenant_name_2("AUX_RECOVER$1694673215667468aaa");
|
|
ASSERT_EQ(OB_SUCCESS, ObImportTableUtil::check_is_recover_table_aux_tenant_name(tenant_name_2, is_recover_table_aux_tenant));
|
|
ASSERT_EQ(false, is_recover_table_aux_tenant);
|
|
const ObString tenant_name_3("AUX_RECOVER1694673215667468aaa");
|
|
ASSERT_EQ(OB_SUCCESS, ObImportTableUtil::check_is_recover_table_aux_tenant_name(tenant_name_3, is_recover_table_aux_tenant));
|
|
ASSERT_EQ(false, is_recover_table_aux_tenant);
|
|
const ObString tenant_name_4("AUX_RECOVER$aaa");
|
|
ASSERT_EQ(OB_SUCCESS, ObImportTableUtil::check_is_recover_table_aux_tenant_name(tenant_name_4, is_recover_table_aux_tenant));
|
|
ASSERT_EQ(false, is_recover_table_aux_tenant);
|
|
}
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
system("rm -f test_import_table.log*");
|
|
ObLogger &logger = ObLogger::get_logger();
|
|
logger.set_file_name("test_import_table.log", true);
|
|
logger.set_log_level(OB_LOG_LEVEL_DEBUG);
|
|
|
|
testing::InitGoogleTest(&argc, argv);
|
|
return RUN_ALL_TESTS();
|
|
} |