oceanbase/unittest/sql/engine/expr/test_postfix_expression.cpp
wangzelin.wzl 93a1074b0c patch 4.0
2022-10-24 17:57:12 +08:00

182 lines
5.3 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.
*/
#include "sql/engine/expr/ob_postfix_expression.h"
#include "sql/engine/expr/ob_expr_operator_factory.h"
#include <gtest/gtest.h>
#include "lib/utility/ob_test_util.h"
#include "sql/engine/expr/ob_expr_add.h"
#include "sql/engine/expr/ob_expr_concat.h"
using namespace oceanbase::common;
using namespace oceanbase::sql;
class TestPostfixExpression: public ::testing::Test
{
public:
TestPostfixExpression();
virtual ~TestPostfixExpression();
virtual void SetUp();
virtual void TearDown();
inline static int64_t get_usec()
{
struct timeval time_val;
gettimeofday(&time_val, NULL);
return time_val.tv_sec*1000000 + time_val.tv_usec;
}
private:
// disallow copy
DISALLOW_COPY_AND_ASSIGN(TestPostfixExpression);
protected:
// function members
protected:
// data members
};
TestPostfixExpression::TestPostfixExpression()
{
}
TestPostfixExpression::~TestPostfixExpression()
{
}
void TestPostfixExpression::SetUp()
{
}
void TestPostfixExpression::TearDown()
{
}
// concat("ABC", 123 + C1, 10.1)
TEST_F(TestPostfixExpression, item_serialization)
{
// prepare
ObArenaAllocator allocator(ObModIds::TEST);
ObExprOperatorFactory factory(allocator);
ObExprOperatorFactory::register_expr_operators();
ObPostfixExpression expr(allocator, 0);
ObObj obj1;
obj1.set_int(123);
ObObj obj2;
obj2.set_varchar(ObString::make_string("ABC"));
obj2.set_collation_level(CS_LEVEL_IMPLICIT);
obj2.set_collation_type(CS_TYPE_UTF8MB4_GENERAL_CI);
ObObj obj3;
number::ObNumber dec;
ASSERT_EQ(OB_SUCCESS, dec.from("10.1", allocator));
obj3.set_unumber(dec);
COMMON_LOG(INFO, "decimal", K(dec.get_length()), K(dec));
ObExprOperator *op_cnn = NULL;
factory.alloc(T_OP_CNN, op_cnn);
op_cnn->set_real_param_num(2);
ASSERT_TRUE(NULL != op_cnn);
ObExprOperator *op_add = NULL;
factory.alloc(T_OP_ADD, op_add);
op_add->set_real_param_num(2);
ASSERT_TRUE(NULL != op_add);
expr.set_item_count(6);
ObPostExprItem item;
ASSERT_EQ(OB_SUCCESS, item.assign(obj1));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
ASSERT_EQ(OB_SUCCESS, item.assign(obj2));
ObAccuracy accuracy;
accuracy.set_length(3);
item.set_accuracy(accuracy);
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
accuracy.set_length(-1);
item.set_accuracy(accuracy);
ASSERT_EQ(OB_SUCCESS, item.set_column(1));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
ASSERT_EQ(OB_SUCCESS, item.assign(op_add));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
ASSERT_EQ(OB_SUCCESS, item.assign(obj3));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
ASSERT_EQ(OB_SUCCESS, item.assign(op_cnn));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
COMMON_LOG(INFO, "expr1", K(expr));
const char* expr_str = S(expr);
// test
char buf[1024];
int64_t buf_len = 1024;
int64_t pos = 0;
ASSERT_EQ(OB_SUCCESS, expr.serialize(buf, buf_len, pos));
ASSERT_EQ(pos, expr.get_serialize_size());
COMMON_LOG(INFO, "serialize size", K(pos));
ObPostfixExpression expr2(allocator, 0);
int64_t data_len = pos;
pos = 0;
ASSERT_EQ(OB_SUCCESS, expr2.deserialize(buf, data_len, pos));
ASSERT_EQ(data_len, pos);
COMMON_LOG(INFO, "expr2", K(expr));
const char* expr2_str = S(expr2);
ASSERT_STREQ(expr_str, expr2_str);
// teardown
}
TEST_F(TestPostfixExpression, item_calc)
{
// prepare
ObArenaAllocator allocator(ObModIds::TEST);
ObExprOperatorFactory factory(allocator);
ObExprOperatorFactory::register_expr_operators();
ObPostfixExpression expr(allocator, 0);
ObObj obj1;
obj1.set_int(123);
ObObj obj2;
obj2.set_int(321);
ObExprOperator *op_add = NULL;
factory.alloc(T_OP_ADD, op_add);
op_add->set_real_param_num(2);
ObExprResType result_type;
result_type.set_calc_type(ObIntType);
op_add->set_result_type(result_type);
ASSERT_TRUE(NULL != op_add);
expr.set_item_count(3);
ObPostExprItem item;
ASSERT_EQ(OB_SUCCESS, item.assign(obj1));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
ASSERT_EQ(OB_SUCCESS, item.assign(obj2));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
ASSERT_EQ(OB_SUCCESS, item.assign(op_add));
ASSERT_EQ(OB_SUCCESS, expr.add_expr_item(item));
DefaultPageAllocator buf;
ObExprCtx expr_ctx(NULL, NULL, NULL, &buf);
ObNewRow input_row;
ObObj result_val;
int64_t time_1 = get_usec();
int64_t t = 5000000;
for (int64_t i = 0; i < t; i++)
ASSERT_EQ(OB_SUCCESS, expr.calc(expr_ctx, input_row, result_val));
int64_t time_2 = get_usec();
std::cout << "# of exec:" << t<< std::endl;
std::cout << "total time:" << time_2 - time_1 << std::endl;
COMMON_LOG(INFO, "result", K(result_val));
// teardown
}
int main(int argc, char **argv)
{
::testing::InitGoogleTest(&argc,argv);
OB_LOGGER.set_log_level("INFO");
OB_LOGGER.set_file_name("test_postfix_expression.log", true);
return RUN_ALL_TESTS();
}