[FEAT MERGE] del_tenant_memleak branch

Co-authored-by: HaHaJeff <jeffzhouhhh@gmail.com>
This commit is contained in:
obdev
2023-01-28 19:29:23 +08:00
committed by ob-robot
parent e3b89cd741
commit ba19ba90e0
179 changed files with 3235 additions and 2291 deletions

View File

@ -16,27 +16,27 @@
using namespace oceanbase::lib;
using namespace oceanbase::common;
TEST(TestMallocAllocator, create_tenant_ctx_allocator)
TEST(TestMallocAllocator, create_and_add_tenant_allocator)
{
ObMallocAllocator *malloc_allocator = ObMallocAllocator::get_instance();
const int64_t limit = 10 * 1000 * 1000;
const uint64_t small_tenant_id = 200;
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_tenant_ctx_allocator(small_tenant_id, 0));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_and_add_tenant_allocator(small_tenant_id));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->set_tenant_limit(small_tenant_id, limit));
ASSERT_EQ(limit, malloc_allocator->get_tenant_limit(small_tenant_id));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_tenant_ctx_allocator(small_tenant_id, 0));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_and_add_tenant_allocator(small_tenant_id));
ASSERT_EQ(limit, malloc_allocator->get_tenant_limit(small_tenant_id));
const uint64_t big_tenant_id = 20000 + 10000;
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_tenant_ctx_allocator(big_tenant_id, 0));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_and_add_tenant_allocator(big_tenant_id));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->set_tenant_limit(big_tenant_id, limit));
ASSERT_EQ(limit, malloc_allocator->get_tenant_limit(big_tenant_id));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_tenant_ctx_allocator(big_tenant_id, 0));
ASSERT_EQ(OB_ENTRY_EXIST, malloc_allocator->create_and_add_tenant_allocator(big_tenant_id));
ASSERT_EQ(limit, malloc_allocator->get_tenant_limit(big_tenant_id));
const uint64_t tenant_id = 20000;
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_tenant_ctx_allocator(tenant_id, 0));
ObTenantCtxAllocator *tenant_allocator = malloc_allocator->get_tenant_ctx_allocator(big_tenant_id, 0);
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_and_add_tenant_allocator(tenant_id));
auto tenant_allocator = malloc_allocator->get_tenant_ctx_allocator(big_tenant_id, ObCtxIds::DEFAULT_CTX_ID);
ASSERT_TRUE(NULL != tenant_allocator);
}
@ -44,14 +44,14 @@ TEST(TestMallocAllocator, create_tenant_ctx_allocator)
TEST(TestMallocAllocator, idle)
{
ObMallocAllocator *malloc_allocator = ObMallocAllocator::get_instance();
const uint64_t tenant_id = 200;
const uint64_t tenant_id = 201;
const uint64_t ctx_id = 1;
ASSERT_EQ(OB_TENANT_NOT_EXIST, malloc_allocator->set_tenant_ctx_idle(tenant_id, ctx_id,
OB_MALLOC_BIG_BLOCK_SIZE));
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_tenant_ctx_allocator(tenant_id, ctx_id));
ObTenantCtxAllocator *ta = malloc_allocator->get_tenant_ctx_allocator(tenant_id, ctx_id);
ASSERT_EQ(OB_SUCCESS, malloc_allocator->create_and_add_tenant_allocator(tenant_id));
auto ta = malloc_allocator->get_tenant_ctx_allocator(tenant_id, ctx_id);
ASSERT_TRUE(NULL != ta);
ta->set_tenant_memory_mgr();
ASSERT_EQ(OB_SUCCESS, malloc_allocator->set_tenant_limit(tenant_id, 1024 * 1024 * 1024));