216 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			216 lines
		
	
	
		
			10 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 SQL_ENG
 | 
						|
#include <gtest/gtest.h>
 | 
						|
#include "../../../../src/sql/engine/expr/ob_expr_right.h"
 | 
						|
#include "ob_expr_test_utils.h"
 | 
						|
#include "lib/oblog/ob_log.h"
 | 
						|
#include <iostream>
 | 
						|
using namespace oceanbase::common;
 | 
						|
using namespace oceanbase::sql;
 | 
						|
 | 
						|
class ObExprFuncRightTest : public ::testing::Test {
 | 
						|
public:
 | 
						|
  ObExprFuncRightTest();
 | 
						|
  virtual ~ObExprFuncRightTest();
 | 
						|
  virtual void SetUp();
 | 
						|
  virtual void TearDown();
 | 
						|
 | 
						|
private:
 | 
						|
  // disallow copy
 | 
						|
  ObExprFuncRightTest(const ObExprFuncRightTest& other);
 | 
						|
  ObExprFuncRightTest& operator=(const ObExprFuncRightTest& other);
 | 
						|
 | 
						|
protected:
 | 
						|
  // data members
 | 
						|
};
 | 
						|
 | 
						|
ObExprFuncRightTest::ObExprFuncRightTest()
 | 
						|
{}
 | 
						|
 | 
						|
ObExprFuncRightTest::~ObExprFuncRightTest()
 | 
						|
{}
 | 
						|
 | 
						|
void ObExprFuncRightTest::SetUp()
 | 
						|
{}
 | 
						|
 | 
						|
void ObExprFuncRightTest::TearDown()
 | 
						|
{}
 | 
						|
 | 
						|
#define BINARY_RIGHT(str, count, res_str) \
 | 
						|
  EXPECT_RESULT2_CT(right,                \
 | 
						|
      &buf,                               \
 | 
						|
      calc_result2,                       \
 | 
						|
      binary,                             \
 | 
						|
      str,                                \
 | 
						|
      CS_TYPE_BINARY,                     \
 | 
						|
      int,                                \
 | 
						|
      count,                              \
 | 
						|
      CS_TYPE_BINARY,                     \
 | 
						|
      binary,                             \
 | 
						|
      res_str,                            \
 | 
						|
      CS_TYPE_BINARY)
 | 
						|
 | 
						|
TEST_OPERATOR(ObExprRight);
 | 
						|
 | 
						|
TEST_F(ObExprFuncRightTest, ascii)
 | 
						|
{
 | 
						|
  ObMalloc buf;
 | 
						|
  TestObExprRight rev;
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "12345abcde", int, -4, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "12345abcde", int, 0, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "12345abcde", int, 2, varchar, "de");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "12345abcde", int, 5, varchar, "abcde");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "12345abcde", int, 8, varchar, "345abcde");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "12345abcde", int, 10, varchar, "12345abcde");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "12345abcde", int, 15, varchar, "12345abcde");
 | 
						|
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "12345abcde", int, -4, char, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "12345abcde", int, 0, char, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "12345abcde", int, 2, char, "de");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "12345abcde", int, 5, char, "abcde");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "12345abcde", int, 8, char, "345abcde");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "12345abcde", int, 10, char, "12345abcde");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "12345abcde", int, 15, char, "12345abcde");
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(ObExprFuncRightTest, utf8)
 | 
						|
{
 | 
						|
  ObMalloc buf;
 | 
						|
  TestObExprRight rev;
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "上山打老虎", int, -4, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "上山打老虎", int, 0, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "上山打老虎", int, 2, varchar, "老虎");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "上山打老虎", int, 4, varchar, "山打老虎");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "上山打老虎", int, 5, varchar, "上山打老虎");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "上山打老虎", int, 10, varchar, "上山打老虎");
 | 
						|
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "上山打老虎", int, -4, char, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "上山打老虎", int, 0, char, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "上山打老虎", int, 2, char, "老虎");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "上山打老虎", int, 4, char, "山打老虎");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "上山打老虎", int, 5, char, "上山打老虎");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "上山打老虎", int, 10, char, "上山打老虎");
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(ObExprFuncRightTest, utf8_mixed)
 | 
						|
{
 | 
						|
  ObMalloc buf;
 | 
						|
  TestObExprRight rev;
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, -4, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, 0, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, 1, varchar, "e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, 2, varchar, "虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, 3, varchar, "5虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, 7, varchar, "c4老d5虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(
 | 
						|
      rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, 15, varchar, "1上a2山b3打c4老d5虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(
 | 
						|
      rev, &buf, calc_result2, varchar, "1上a2山b3打c4老d5虎e", int, 42, varchar, "1上a2山b3打c4老d5虎e");
 | 
						|
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, -4, char, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, 0, char, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, 1, char, "e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, 2, char, "虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, 3, char, "5虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, 7, char, "c4老d5虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(
 | 
						|
      rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, 15, char, "1上a2山b3打c4老d5虎e");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(
 | 
						|
      rev, &buf, calc_result2, char, "1上a2山b3打c4老d5虎e", int, 42, char, "1上a2山b3打c4老d5虎e");
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(ObExprFuncRightTest, binary)
 | 
						|
{
 | 
						|
  ObMalloc buf;
 | 
						|
  TestObExprRight right;
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", -4, "");
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", 0, "");
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", 1, "\xFF");
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", 2, "\xEE\xFF");
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", 4, "\xBB\xEE\xEE\xFF");
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", 7, "\xEE\xAA\xDD\xBB\xEE\xEE\xFF");
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", 8, "\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF");
 | 
						|
  BINARY_RIGHT("\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF", 42, "\xDD\xEE\xAA\xDD\xBB\xEE\xEE\xFF");
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(ObExprFuncRightTest, casted)
 | 
						|
{
 | 
						|
  ObMalloc buf;
 | 
						|
  TestObExprRight rev;
 | 
						|
  number::ObNumber num;
 | 
						|
  num.from("-42.466778", buf);
 | 
						|
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, int, 12345, int, -4, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, int, 12345, int, 0, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, int, 12345, int, 1, varchar, "5");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, int, 12345, int, 3, varchar, "345");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, int, 12345, int, 5, varchar, "12345");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, int, 12345, int, 10, varchar, "12345");
 | 
						|
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, smallint, 12345, int, -4, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, smallint, 12345, int, 0, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, smallint, 12345, int, 1, varchar, "5");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, smallint, 12345, int, 3, varchar, "345");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, smallint, 12345, int, 5, varchar, "12345");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, smallint, 12345, int, 10, varchar, "12345");
 | 
						|
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, tinyint, -123, int, -4, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, tinyint, -123, int, 0, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, tinyint, -123, int, 1, varchar, "3");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, tinyint, -123, int, 3, varchar, "123");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, tinyint, -123, int, 4, varchar, "-123");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, tinyint, -123, int, 10, varchar, "-123");
 | 
						|
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, double, -123.45, int, -3, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, double, -123.45, int, 0, varchar, "");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, double, -123.45, int, 3, varchar, ".45");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, double, -123.45, int, 7, varchar, "-123.45");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, double, -123.45, int, 10, varchar, "-123.45");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, double, -123.45, int, 11, varchar, "-123.45");
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, double, -123.45, int, 16, varchar, "-123.45");
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(ObExprFuncRightTest, invalid_encoding)
 | 
						|
{
 | 
						|
  ObMalloc buf;
 | 
						|
  TestObExprRight rev;
 | 
						|
  EXPECT_FAIL_RESULT2_CT(rev,
 | 
						|
      &buf,
 | 
						|
      calc_result2,
 | 
						|
      char,
 | 
						|
      "上山打老\xE4\xBD\x00",
 | 
						|
      CS_TYPE_UTF8MB4_GENERAL_CI,
 | 
						|
      int,
 | 
						|
      3,
 | 
						|
      CS_TYPE_UTF8MB4_GENERAL_CI);
 | 
						|
  EXPECT_FAIL_RESULT2_CT(rev,
 | 
						|
      &buf,
 | 
						|
      calc_result2,
 | 
						|
      char,
 | 
						|
      "上山打老\xE4\xBD",
 | 
						|
      CS_TYPE_UTF8MB4_GENERAL_CI,
 | 
						|
      int,
 | 
						|
      3,
 | 
						|
      CS_TYPE_UTF8MB4_GENERAL_CI);
 | 
						|
  EXPECT_FAIL_RESULT2_CT(
 | 
						|
      rev, &buf, calc_result2, char, "上山\xE4打老", CS_TYPE_UTF8MB4_GENERAL_CI, int, 3, CS_TYPE_UTF8MB4_GENERAL_CI);
 | 
						|
  EXPECT_RESULT2_UTF8MB4CI(rev, &buf, calc_result2, char, "上山\xE4打老", int, 2, char, "打老");
 | 
						|
}
 | 
						|
 | 
						|
int main(int argc, char** argv)
 | 
						|
{
 | 
						|
  ::testing::InitGoogleTest(&argc, argv);
 | 
						|
  return RUN_ALL_TESTS();
 | 
						|
}
 |