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