147 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			147 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 "share/object/ob_obj_cast.h"
 | |
| #include <gtest/gtest.h>
 | |
| #include "lib/worker.h"
 | |
| 
 | |
| 
 | |
| namespace oceanbase
 | |
| {
 | |
| namespace common
 | |
| {
 | |
| using namespace number;
 | |
| 
 | |
| class TestObjCast : public ::testing::Test
 | |
| {
 | |
| public:
 | |
|   virtual void SetUp();
 | |
|   virtual void TearDown() {}
 | |
| 
 | |
|   ObArenaAllocator allocator_;
 | |
| };
 | |
| 
 | |
| void TestObjCast::SetUp()
 | |
| {
 | |
|   const lib::ObMemAttr attr(common::OB_SYS_TENANT_ID, ObModIds::OB_NUMBER);
 | |
|   int ret = ObNumberConstValue::init(allocator_, attr);
 | |
|   ASSERT_EQ(OB_SUCCESS, ret);
 | |
| }
 | |
| 
 | |
| TEST_F(TestObjCast, test_number_range_check_mysql_old)
 | |
| {
 | |
|   int ret = OB_SUCCESS;
 | |
|   lib::CompatModeGuard tmp_mode(lib::Worker::CompatMode::MYSQL);
 | |
|   ObNumber zero_number;
 | |
|   zero_number.set_zero();
 | |
|   ObObj obj1;
 | |
|   obj1.set_number(zero_number);
 | |
|   const ObObj *res_obj = &obj1;
 | |
|   ObObjCastParams params;
 | |
|   params.allocator_v2_ = &allocator_;
 | |
|   params.cast_mode_ |= CM_WARN_ON_FAIL;
 | |
|   int64_t get_range_beg = ObTimeUtility::current_time();
 | |
|   for (int16_t precision = OB_MIN_DECIMAL_PRECISION; OB_SUCC(ret) && precision <= ObNumber::MAX_PRECISION; ++precision) {
 | |
|     for (int16_t scale = 0; OB_SUCC(ret) && precision >= scale && scale <= ObNumber::MAX_SCALE; ++scale) {
 | |
|       ObAccuracy accuracy(precision, scale);
 | |
|       ret = number_range_check(params, accuracy, obj1, obj1, res_obj, params.cast_mode_);
 | |
|       ASSERT_EQ(OB_SUCCESS, ret);
 | |
|     }
 | |
|   }
 | |
|   int64_t get_range_cost = ObTimeUtility::current_time() - get_range_beg;
 | |
|   _OB_LOG(INFO, "test_number_range_check_mysql_old(%d) cost time: %f", (ObNumber::MAX_PRECISION + 1) * (ObNumber::MAX_SCALE + 1) / 2, (double)get_range_cost / (double)1000);
 | |
| }
 | |
| 
 | |
| TEST_F(TestObjCast, test_number_range_check_mysql_new)
 | |
| {
 | |
|   int ret = OB_SUCCESS;
 | |
|   lib::CompatModeGuard tmp_mode(lib::Worker::CompatMode::MYSQL);
 | |
|   ObNumber zero_number;
 | |
|   zero_number.set_zero();
 | |
|   ObObj obj1;
 | |
|   obj1.set_number(zero_number);
 | |
|   const ObObj *res_obj = &obj1;
 | |
|   ObObjCastParams params;
 | |
|   params.allocator_v2_ = &allocator_;
 | |
|   params.cast_mode_ |= CM_WARN_ON_FAIL;
 | |
|   int64_t get_range_beg = ObTimeUtility::current_time();
 | |
|   for (int16_t precision = OB_MIN_DECIMAL_PRECISION; OB_SUCC(ret) && precision <= ObNumber::MAX_PRECISION; ++precision) {
 | |
|     for (int16_t scale = 0; OB_SUCC(ret) && precision >= scale && scale <= ObNumber::MAX_SCALE; ++scale) {
 | |
|       ObAccuracy accuracy(precision, scale);
 | |
|       ret = number_range_check_v2(params, accuracy, obj1, obj1, res_obj, params.cast_mode_);
 | |
|       ASSERT_EQ(OB_SUCCESS, ret);
 | |
|     }
 | |
|   }
 | |
|   int64_t get_range_cost = ObTimeUtility::current_time() - get_range_beg;
 | |
|   _OB_LOG(INFO, "test_number_range_check_mysql_new(%d) cost time: %f", (ObNumber::MAX_PRECISION + 1) * (ObNumber::MAX_SCALE + 1) / 2, (double)get_range_cost / (double)1000);
 | |
| }
 | |
| 
 | |
| TEST_F(TestObjCast, test_number_range_check_oracle_old)
 | |
| {
 | |
|   int ret = OB_SUCCESS;
 | |
|   lib::CompatModeGuard tmp_mode(lib::Worker::CompatMode::ORACLE);
 | |
|   ObNumber zero_number;
 | |
|   zero_number.set_zero();
 | |
|   ObObj obj1;
 | |
|   obj1.set_number(zero_number);
 | |
|   const ObObj *res_obj = &obj1;
 | |
|   ObObjCastParams params;
 | |
|   params.allocator_v2_ = &allocator_;
 | |
|   params.cast_mode_ |= CM_WARN_ON_FAIL;
 | |
|   int64_t get_range_beg = ObTimeUtility::current_time();
 | |
|   for (int16_t precision = OB_MIN_NUMBER_PRECISION; OB_SUCC(ret) && precision <= OB_MAX_NUMBER_PRECISION; ++precision) {
 | |
|     for (int16_t scale = ObNumber::MIN_SCALE; OB_SUCC(ret) && scale <= ObNumber::MAX_SCALE; ++scale) {
 | |
|       ObAccuracy accuracy(precision, scale);
 | |
|       ret = number_range_check_for_oracle(params, accuracy, obj1, obj1, res_obj, params.cast_mode_);
 | |
|       ASSERT_EQ(OB_SUCCESS, ret);
 | |
|     }
 | |
|   }
 | |
|   int64_t get_range_cost = ObTimeUtility::current_time() - get_range_beg;
 | |
|   _OB_LOG(INFO, "test_number_range_check_oracle_old(%ld) cost time: %f", (OB_MAX_NUMBER_PRECISION) * (ObNumberConstValue::MAX_ORACLE_SCALE_SIZE + 1), (double)get_range_cost / (double)1000);
 | |
| }
 | |
| 
 | |
| TEST_F(TestObjCast, test_number_range_check_oracle_new)
 | |
| {
 | |
|   int ret = OB_SUCCESS;
 | |
|   lib::CompatModeGuard tmp_mode(lib::Worker::CompatMode::ORACLE);
 | |
|   ObNumber zero_number;
 | |
|   zero_number.set_zero();
 | |
|   ObObj obj1;
 | |
|   obj1.set_number(zero_number);
 | |
|   const ObObj *res_obj = &obj1;
 | |
|   ObObjCastParams params;
 | |
|   params.allocator_v2_ = &allocator_;
 | |
|   params.cast_mode_ |= CM_WARN_ON_FAIL;
 | |
|   int64_t get_range_beg = ObTimeUtility::current_time();
 | |
|   for (int16_t precision = OB_MIN_NUMBER_PRECISION; OB_SUCC(ret) && precision <= OB_MAX_NUMBER_PRECISION; ++precision) {
 | |
|     for (int16_t scale = ObNumber::MIN_SCALE; OB_SUCC(ret) && scale <= ObNumber::MAX_SCALE; ++scale) {
 | |
|       ObAccuracy accuracy(precision, scale);
 | |
|       ret = number_range_check_v2(params, accuracy, obj1, obj1, res_obj, params.cast_mode_);
 | |
|       ASSERT_EQ(OB_SUCCESS, ret);
 | |
|     }
 | |
|   }
 | |
|   int64_t get_range_cost = ObTimeUtility::current_time() - get_range_beg;
 | |
|   _OB_LOG(INFO, "test_number_range_check_oracle_new(%ld) cost time: %f", (OB_MAX_NUMBER_PRECISION) * (ObNumberConstValue::MAX_ORACLE_SCALE_SIZE + 1), (double)get_range_cost / (double)1000);
 | |
| }
 | |
| 
 | |
| } // 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();
 | |
| }
 | 
