90 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.5 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 <gtest/gtest.h>
 | 
						|
#include "common/ob_range.h"
 | 
						|
#include "common/ob_store_range.h"
 | 
						|
#include "lib/container/ob_se_array.h"
 | 
						|
#include "lib/ob_define.h"
 | 
						|
 | 
						|
using namespace oceanbase::common;
 | 
						|
 | 
						|
TEST(TestObRange, test_to_store_range)
 | 
						|
{
 | 
						|
  ObArenaAllocator allocator;
 | 
						|
  ObNewRange range;
 | 
						|
  ObStoreRange store_range;
 | 
						|
  int ret = OB_SUCCESS;
 | 
						|
  int rowkey_cnt = 2;
 | 
						|
  ObObj start_objs[3];
 | 
						|
  ObObj end_objs[3];
 | 
						|
 | 
						|
  ObSEArray<ObOrderType, OB_MAX_ROWKEY_COLUMN_NUMBER> all_asc_orders;
 | 
						|
  ObSEArray<ObOrderType, OB_MAX_ROWKEY_COLUMN_NUMBER> asc_desc_orders;
 | 
						|
  all_asc_orders.push_back(ObOrderType::ASC);
 | 
						|
  all_asc_orders.push_back(ObOrderType::ASC);
 | 
						|
  asc_desc_orders.push_back(ObOrderType::ASC);
 | 
						|
  asc_desc_orders.push_back(ObOrderType::DESC);
 | 
						|
 | 
						|
  //invalid keys cannot be converted
 | 
						|
  //ret = range.to_store_range(all_asc_orders, rowkey_cnt, store_range, allocator);
 | 
						|
  //ASSERT_EQ(ret, OB_INVALID_ARGUMENT);
 | 
						|
 | 
						|
  // cannot be converted if range key length does not match rowkey_cnt
 | 
						|
  range.start_key_.assign(start_objs, 3);
 | 
						|
  range.end_key_.assign(end_objs, 3);
 | 
						|
  //ret = range.to_store_range(all_asc_orders, rowkey_cnt, store_range, allocator);
 | 
						|
  //ASSERT_EQ(ret, OB_INVALID_ARGUMENT);
 | 
						|
 | 
						|
  start_objs[0].set_int(1);
 | 
						|
  start_objs[1].set_min_value();
 | 
						|
  range.start_key_.assign(start_objs, rowkey_cnt);
 | 
						|
  end_objs[0].set_int(9);
 | 
						|
  end_objs[1].set_max_value();
 | 
						|
  range.end_key_.assign(end_objs, rowkey_cnt);
 | 
						|
  range.table_id_ = 999;
 | 
						|
  range.border_flag_.unset_inclusive_start();
 | 
						|
  range.border_flag_.set_inclusive_end();
 | 
						|
 | 
						|
  //ret = range.to_store_range(all_asc_orders, rowkey_cnt, store_range, allocator);
 | 
						|
  //ASSERT_EQ(ret, OB_SUCCESS);
 | 
						|
  ASSERT_EQ(store_range.get_table_id(), 999);
 | 
						|
  ASSERT_TRUE(store_range.get_start_key().is_valid());
 | 
						|
  ASSERT_EQ(1, store_range.get_start_key().get_obj_ptr()[0].v_.int64_);
 | 
						|
  ASSERT_TRUE(store_range.get_start_key().get_obj_ptr()[1].is_min_value());
 | 
						|
  ASSERT_TRUE(store_range.get_end_key().is_valid());
 | 
						|
  ASSERT_EQ(9, store_range.get_end_key().get_obj_ptr()[0].v_.int64_);
 | 
						|
  ASSERT_TRUE(store_range.get_end_key().get_obj_ptr()[1].is_max_value());
 | 
						|
  ASSERT_FALSE(store_range.get_border_flag().inclusive_start());
 | 
						|
  ASSERT_TRUE(store_range.get_border_flag().inclusive_end());
 | 
						|
 | 
						|
 | 
						|
  //ret = range.to_store_range(asc_desc_orders, rowkey_cnt, store_range, allocator);
 | 
						|
  //ASSERT_EQ(ret, OB_SUCCESS);
 | 
						|
  ASSERT_EQ(store_range.get_table_id(), 999);
 | 
						|
  ASSERT_TRUE(store_range.get_start_key().is_valid());
 | 
						|
  ASSERT_EQ(1, store_range.get_start_key().get_obj_ptr()[0].v_.int64_);
 | 
						|
  ASSERT_TRUE(store_range.get_start_key().get_obj_ptr()[1].is_max_value());
 | 
						|
  ASSERT_TRUE(store_range.get_end_key().is_valid());
 | 
						|
  ASSERT_EQ(9, store_range.get_end_key().get_obj_ptr()[0].v_.int64_);
 | 
						|
  ASSERT_TRUE(store_range.get_end_key().get_obj_ptr()[1].is_min_value());
 | 
						|
  ASSERT_TRUE(store_range.get_border_flag().inclusive_start());
 | 
						|
  ASSERT_FALSE(store_range.get_border_flag().inclusive_end());
 | 
						|
}
 | 
						|
 | 
						|
int main(int argc, char **argv)
 | 
						|
{
 | 
						|
  testing::InitGoogleTest(&argc,argv);
 | 
						|
  OB_LOGGER.set_log_level("INFO");
 | 
						|
  return RUN_ALL_TESTS();
 | 
						|
}
 |