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