160 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			160 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();
 | |
| }
 | 
