189 lines
6.6 KiB
C++
189 lines
6.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.
|
|
*/
|
|
|
|
#ifndef SCHEMA_TEST_UTILS_H_
|
|
#define SCHEMA_TEST_UTILS_H_
|
|
|
|
#define private public
|
|
#include "share/ob_define.h"
|
|
#include "lib/oblog/ob_log.h"
|
|
#include "share/schema/ob_schema_struct.h"
|
|
#include "share/schema/ob_table_schema.h"
|
|
|
|
|
|
namespace oceanbase
|
|
{
|
|
using namespace common;
|
|
namespace common
|
|
{
|
|
}
|
|
namespace share
|
|
{
|
|
namespace schema
|
|
{
|
|
|
|
#define GEN_TENANT_SCHEMA(tenant_schema, tenant_id, tenant_name, schema_version) \
|
|
tenant_schema.set_tenant_id(tenant_id); \
|
|
tenant_schema.set_tenant_name(tenant_name); \
|
|
tenant_schema.set_schema_version(schema_version);
|
|
|
|
#define GEN_USER_SCHEMA(user_schema, tenant_id, user_id, user_name, schema_version) \
|
|
user_schema.set_tenant_id(tenant_id); \
|
|
user_schema.set_user_id(user_id); \
|
|
user_schema.set_user_name(user_name); \
|
|
user_schema.set_host(OB_DEFAULT_HOST_NAME); \
|
|
user_schema.set_schema_version(schema_version);
|
|
|
|
#define GEN_DATABASE_SCHEMA(database_schema, tenant_id, database_id, database_name, schema_version) \
|
|
database_schema.set_tenant_id(tenant_id); \
|
|
database_schema.set_database_id(database_id); \
|
|
database_schema.set_database_name(database_name); \
|
|
database_schema.set_schema_version(schema_version); \
|
|
database_schema.set_name_case_mode(OB_ORIGIN_AND_INSENSITIVE);
|
|
|
|
#define GEN_TABLEGROUP_SCHEMA(tablegroup_schema, tenant_id, tablegroup_id, tablegroup_name, schema_version) \
|
|
tablegroup_schema.set_tenant_id(tenant_id); \
|
|
tablegroup_schema.set_tablegroup_id(tablegroup_id); \
|
|
tablegroup_schema.set_tablegroup_name(tablegroup_name); \
|
|
tablegroup_schema.set_schema_version(schema_version);
|
|
|
|
#define GEN_TABLE_SCHEMA(table_schema, tenant_id, database_id, table_id, table_name, table_type, schema_version) \
|
|
table_schema.reset(); \
|
|
table_schema.set_tenant_id(tenant_id); \
|
|
table_schema.set_database_id(database_id); \
|
|
table_schema.set_table_id(table_id); \
|
|
table_schema.set_table_name(table_name); \
|
|
table_schema.set_table_type(table_type); \
|
|
table_schema.set_schema_version(schema_version); \
|
|
table_schema.set_name_case_mode(OB_ORIGIN_AND_INSENSITIVE);
|
|
|
|
#define GEN_OUTLINE_SCHEMA(outline_schema, tenant_id, database_id, outline_id, name, sig, schema_version) \
|
|
outline_schema.reset(); \
|
|
outline_schema.set_tenant_id(tenant_id); \
|
|
outline_schema.set_database_id(database_id); \
|
|
outline_schema.set_outline_id(outline_id); \
|
|
outline_schema.set_name(name); \
|
|
outline_schema.set_signature(sig); \
|
|
outline_schema.set_schema_version(schema_version);
|
|
|
|
#define GEN_DB_PRIV(db_priv, tenant_id, user_id, database_name, priv_set, schema_version) \
|
|
db_priv.reset(); \
|
|
db_priv.set_tenant_id(tenant_id); \
|
|
db_priv.set_user_id(user_id); \
|
|
db_priv.set_database_name(database_name); \
|
|
db_priv.set_priv_set(priv_set); \
|
|
db_priv.set_schema_version(schema_version);
|
|
|
|
#define GEN_TABLE_PRIV(table_priv, tenant_id, user_id, database_name, table_name, priv_set, schema_version) \
|
|
table_priv.reset(); \
|
|
table_priv.set_tenant_id(tenant_id); \
|
|
table_priv.set_user_id(user_id); \
|
|
table_priv.set_database_name(database_name); \
|
|
table_priv.set_table_name(table_name); \
|
|
table_priv.set_priv_set(priv_set); \
|
|
table_priv.set_schema_version(schema_version);
|
|
|
|
class SchemaTestUtils
|
|
{
|
|
public:
|
|
SchemaTestUtils() {}
|
|
virtual ~SchemaTestUtils() {}
|
|
|
|
static bool equal_tenant_schema(
|
|
const ObTenantSchema &a,
|
|
const ObTenantSchema &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_tenant_name_str() == b.get_tenant_name_str() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
static bool equal_user_schema(
|
|
const ObUserInfo &a,
|
|
const ObUserInfo &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_user_id() == b.get_user_id() &&
|
|
a.get_user_name_str() == b.get_user_name_str() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
static bool equal_database_schema(
|
|
const ObDatabaseSchema &a,
|
|
const ObDatabaseSchema &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_database_id() == b.get_database_id() &&
|
|
a.get_database_name_str() == b.get_database_name_str() &&
|
|
a.get_name_case_mode() == b.get_name_case_mode() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
static bool equal_tablegroup_schema(
|
|
const ObTablegroupSchema &a,
|
|
const ObTablegroupSchema &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_tablegroup_id() == b.get_tablegroup_id() &&
|
|
a.get_tablegroup_name_str() == b.get_tablegroup_name_str() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
static bool equal_table_schema(
|
|
const ObTableSchema &a,
|
|
const ObTableSchema &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_database_id() == b.get_database_id() &&
|
|
a.get_table_id() == b.get_table_id() &&
|
|
a.get_table_name_str() == b.get_table_name_str() &&
|
|
a.get_name_case_mode() == b.get_name_case_mode() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
static bool equal_outline_schema(
|
|
const ObOutlineInfo &a,
|
|
const ObOutlineInfo &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_database_id() == b.get_database_id() &&
|
|
a.get_outline_id() == b.get_outline_id() &&
|
|
a.get_name_str() == b.get_name_str() &&
|
|
a.get_signature_str() == b.get_signature_str() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
static bool equal_db_priv(
|
|
const ObDBPriv &a,
|
|
const ObDBPriv &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_user_id() == b.get_user_id() &&
|
|
a.get_database_name_str() == b.get_database_name_str() &&
|
|
a.get_priv_set() == b.get_priv_set() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
static bool equal_table_priv(
|
|
const ObTablePriv &a,
|
|
const ObTablePriv &b)
|
|
{
|
|
return a.get_tenant_id() == b.get_tenant_id() &&
|
|
a.get_user_id() == b.get_user_id() &&
|
|
a.get_database_name_str() == b.get_database_name_str() &&
|
|
a.get_table_name_str() == b.get_table_name_str() &&
|
|
a.get_priv_set() == b.get_priv_set() &&
|
|
a.get_schema_version() == b.get_schema_version();
|
|
}
|
|
|
|
private:
|
|
};
|
|
|
|
} // schema
|
|
} // share
|
|
} // oceanbase
|
|
|
|
#endif /* SCHEMA_TEST_UTILS_H_ */
|