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();
|
|
}
|