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

162 lines
5.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.
*/
#define USING_LOG_PREFIX SHARE
#include "lib/stat/ob_session_stat.h"
#include "share/ob_dml_sql_splicer.h"
#include <gtest/gtest.h>
#include "schema/db_initializer.h"
namespace oceanbase
{
namespace share
{
using namespace common;
using namespace share::schema;
TEST(ObDMLSqlSplicer, splice)
{
ObDMLSqlSplicer splicer;
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("col1", 1));
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("col2", 2));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("col3", "str3"));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("col4", 4));
ObSqlString sql;
const char *out = "INSERT INTO tname (col1, col2, col3, col4) VALUES (1, 2, 'str3', 4)";
int ret = splicer.splice_insert_sql("tname", sql);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_STREQ(out, sql.ptr());
out = "INSERT IGNORE INTO tname (col1, col2, col3, col4) VALUES (1, 2, 'str3', 4)";
ret = splicer.splice_insert_ignore_sql("tname", sql);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_STREQ(out, sql.ptr());
out = "INSERT INTO tname (col1, col2, col3, col4) VALUES (1, 2, 'str3', 4)"
" ON DUPLICATE KEY UPDATE col3 = 'str3', col4 = 4";
ret = splicer.splice_insert_update_sql("tname", sql);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_STREQ(out, sql.ptr());
out = "REPLACE INTO tname (col1, col2, col3, col4) VALUES (1, 2, 'str3', 4)";
ret = splicer.splice_replace_sql("tname", sql);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_STREQ(out, sql.ptr());
out = "UPDATE tname SET col3 = 'str3', col4 = 4 WHERE col1 = 1 AND col2 = 2";
ret = splicer.splice_update_sql("tname", sql);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_STREQ(out, sql.ptr());
out = "SELECT 1 FROM tname WHERE col1 = 1 AND col2 = 2";
ret = splicer.splice_select_1_sql("tname", sql);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_STREQ(out, sql.ptr());
ret = splicer.splice_insert_sql(NULL, sql);
ASSERT_EQ(OB_INVALID_ARGUMENT, ret);
splicer.reset();
ret = splicer.splice_insert_sql("tname", sql);
ASSERT_NE(OB_SUCCESS, ret);
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("c1", 1));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("c2", 2));
ASSERT_NE(OB_SUCCESS, splicer.add_column(NULL, 3));
ret = splicer.splice_insert_sql("tname", sql);
ASSERT_EQ(OB_SUCCESS, ret);
};
TEST(ObDMLExecHelper, execute)
{
DBInitializer db_initer;
int ret = db_initer.init();
ASSERT_EQ(OB_SUCCESS, ret);
const bool only_core_tables = false;
ret = db_initer.create_system_table(only_core_tables);
ASSERT_EQ(OB_SUCCESS, ret);
ObDMLExecHelper exec(db_initer.get_sql_proxy(), OB_SYS_TENANT_ID);
ObDMLSqlSplicer splicer;
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("zone", "HZ.BIG"));
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("name", "item1"));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("value", 1));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("info", "info"));
ASSERT_EQ(OB_SUCCESS, splicer.add_gmt_modified());
const char *tname = "__all_zone";
int64_t affected_rows = 0;
ret = exec.exec_insert(tname, splicer, affected_rows);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_EQ(1, affected_rows);
ret = exec.exec_insert(tname, splicer, affected_rows);
ASSERT_NE(OB_SUCCESS, ret);
affected_rows = 0;
ret = exec.exec_insert_ignore(tname, splicer, affected_rows);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_EQ(0, affected_rows);
splicer.reset();
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("zone", "HZ.BIG2"));
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("name", "item1"));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("value", 1));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("info", "info"));
ASSERT_EQ(OB_SUCCESS, splicer.add_gmt_modified());
affected_rows = 0;
ret = exec.exec_insert_ignore(tname, splicer, affected_rows);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_EQ(1, affected_rows);
splicer.reset();
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("zone", "HZ.BIG"));
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("name", "item1"));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("value", 2));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("info", "info"));
ret = exec.exec_replace(tname, splicer, affected_rows);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_EQ(2, affected_rows);
splicer.reset();
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("zone", "HZ.BIG"));
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("name", "item2"));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("value", 2));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("info", "info"));
ret = exec.exec_replace(tname, splicer, affected_rows);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_EQ(1, affected_rows);
splicer.reset();
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("zone", "HZ.BIG"));
ASSERT_EQ(OB_SUCCESS, splicer.add_pk_column("name", "item2"));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("value", 3));
ASSERT_EQ(OB_SUCCESS, splicer.add_column("info", "info"));
ret = exec.exec_insert_update(tname, splicer, affected_rows);
ASSERT_EQ(OB_SUCCESS, ret);
ASSERT_EQ(2, affected_rows);
}
} // end namespace share
} // end 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();
}