137 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			137 lines
		
	
	
		
			4.1 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 "share/ob_tenant_mgr.h"
 | 
						|
#include "share/ob_srv_rpc_proxy.h"
 | 
						|
 | 
						|
using namespace oceanbase;
 | 
						|
using namespace common;
 | 
						|
 | 
						|
 | 
						|
TEST(ObTenantManager, Simple1)
 | 
						|
{
 | 
						|
  ObTenantManager &tm = ObTenantManager::get_instance();
 | 
						|
 | 
						|
  ObAddr self;
 | 
						|
  self.set_ip_addr("127.0.0.1", 8088);
 | 
						|
  rpc::frame::ObReqTransport req_transport(NULL, NULL);
 | 
						|
  obrpc::ObSrvRpcProxy rpc_proxy;
 | 
						|
  int ret = tm.init(self, rpc_proxy, &req_transport, &ObServerConfig::get_instance());
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
 | 
						|
  const uint64_t tenantA = 1;
 | 
						|
  ret = tm.add_tenant(tenantA);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
 | 
						|
  const int64_t ulmt = 10;
 | 
						|
  const int64_t llmt = 1;
 | 
						|
  const int64_t disk_usage = 100;
 | 
						|
  int64_t ulmt_result, llmt_result, disk_result;
 | 
						|
  ret = tm.set_tenant_mem_limit(tenantA, ulmt, llmt);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  ret = tm.add_tenant_disk_used(tenantA, disk_usage, 1);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  ret = tm.get_tenant_disk_used(tenantA, disk_result, 1);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  EXPECT_EQ(disk_usage, disk_result);
 | 
						|
  ret = tm.subtract_tenant_disk_used(tenantA, disk_result, 1);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  ret = tm.get_tenant_disk_used(tenantA, disk_result, 1);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  EXPECT_EQ(0, disk_result);
 | 
						|
  ret = tm.get_tenant_mem_limit(tenantA, ulmt_result, llmt_result);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  EXPECT_EQ(ulmt, ulmt_result);
 | 
						|
  EXPECT_EQ(llmt, llmt_result);
 | 
						|
 | 
						|
  tm.destroy();
 | 
						|
}
 | 
						|
 | 
						|
int init_tenant_mgr()
 | 
						|
{
 | 
						|
  ObTenantManager &tm = ObTenantManager::get_instance();
 | 
						|
  ObAddr self;
 | 
						|
  self.set_ip_addr("127.0.0.1", 8086);
 | 
						|
  rpc::frame::ObReqTransport req_transport(NULL, NULL);
 | 
						|
  obrpc::ObSrvRpcProxy rpc_proxy;
 | 
						|
  int ret = tm.init(self, rpc_proxy, &req_transport, &ObServerConfig::get_instance());
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  ret = tm.add_tenant(OB_SYS_TENANT_ID);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  const int64_t ulmt = 16LL << 30;
 | 
						|
  const int64_t llmt = 8LL << 30;
 | 
						|
  ret = tm.set_tenant_mem_limit(OB_SYS_TENANT_ID, ulmt, llmt);
 | 
						|
  EXPECT_EQ(OB_SUCCESS, ret);
 | 
						|
  return OB_SUCCESS;
 | 
						|
}
 | 
						|
 | 
						|
class TestTenantStress: public share::ObThreadPool
 | 
						|
{
 | 
						|
public:
 | 
						|
  TestTenantStress();
 | 
						|
  virtual ~TestTenantStress();
 | 
						|
  virtual void run1();
 | 
						|
};
 | 
						|
 | 
						|
TestTenantStress::TestTenantStress()
 | 
						|
  : alloc_()
 | 
						|
{
 | 
						|
  alloc_.init(OB_SYS_TENANT_ID, 0);
 | 
						|
}
 | 
						|
 | 
						|
TestTenantStress::~TestTenantStress()
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
void TestTenantStress::run(obsys::CThread *thread, void *arg)
 | 
						|
{
 | 
						|
 | 
						|
  UNUSED(arg);
 | 
						|
  const int64_t loop_cnt = 1000;
 | 
						|
  for (int64_t loop = 0; loop < loop_cnt ; ++loop) {
 | 
						|
    void *ptr = malloc(65536);
 | 
						|
    EXPECT_NE((void*)NULL, ptr);
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
TEST(ObTenantManager, multithread)
 | 
						|
{
 | 
						|
  init_tenant_mgr();
 | 
						|
  TestTenantStress stress;
 | 
						|
  stress.set_thread_count(32);
 | 
						|
  uint64_t begin_time = ::oceanbase::common::ObTimeUtility::current_time();
 | 
						|
  stress.start();
 | 
						|
  stress.wait();
 | 
						|
  uint64_t end_time = ::oceanbase::common::ObTimeUtility::current_time();
 | 
						|
  printf("time: %ld us\n", (end_time - begin_time));
 | 
						|
  int64_t active_memstore_used = 0;
 | 
						|
  int64_t total_memstore_used = 0;
 | 
						|
  int64_t major_freeze_trigger = 0;
 | 
						|
  int64_t memstore_limit = 0;
 | 
						|
  int64_t freeze_cnt = 0;
 | 
						|
  ObTenantManager::get_instance().get_tenant_memstore_cond(OB_SYS_TENANT_ID,
 | 
						|
                                                           active_memstore_used,
 | 
						|
                                                           total_memstore_used,
 | 
						|
                                                           major_freeze_trigger,
 | 
						|
                                                           memstore_limit,
 | 
						|
                                                           freeze_cnt);
 | 
						|
  //EXPECT_TRUE(active_memstore_used, 65560*32*1000LL);
 | 
						|
}
 | 
						|
 | 
						|
int main(int argc, char **argv)
 | 
						|
{
 | 
						|
  testing::InitGoogleTest(&argc,argv);
 | 
						|
  return RUN_ALL_TESTS();
 | 
						|
}
 |