greenplumn CKeyCollectionTest 源码
greenplumn CKeyCollectionTest 代码
文件路径:/src/backend/gporca/server/src/unittest/gpopt/base/CKeyCollectionTest.cpp
//---------------------------------------------------------------------------
// Greenplum Database
// Copyright (C) 2009 - 2012 EMC Corp.
//
// @filename:
// CKeyCollectionTest.cpp
//
// @doc:
// Tests for CKeyCollectionTest
//---------------------------------------------------------------------------
#include "unittest/gpopt/base/CKeyCollectionTest.h"
#include "gpopt/base/CKeyCollection.h"
#include "gpopt/eval/CConstExprEvaluatorDefault.h"
#include "gpopt/mdcache/CMDAccessor.h"
#include "gpopt/mdcache/CMDCache.h"
#include "gpopt/metadata/CName.h"
#include "naucrates/md/CMDProviderMemory.h"
#include "naucrates/md/IMDTypeInt4.h"
#include "unittest/base.h"
#include "unittest/gpopt/CTestUtils.h"
using namespace gpopt;
//---------------------------------------------------------------------------
// @function:
// CKeyCollectionTest::EresUnittest
//
// @doc:
// Unittest for key collections
//
//---------------------------------------------------------------------------
GPOS_RESULT
CKeyCollectionTest::EresUnittest()
{
CUnittest rgut[] = {
GPOS_UNITTEST_FUNC(CKeyCollectionTest::EresUnittest_Basics),
GPOS_UNITTEST_FUNC(CKeyCollectionTest::EresUnittest_Subsumes)};
return CUnittest::EresExecute(rgut, GPOS_ARRAY_SIZE(rgut));
}
//---------------------------------------------------------------------------
// @function:
// CKeyCollectionTest::EresUnittest_Basics
//
// @doc:
// Basic test for key collections
//
//---------------------------------------------------------------------------
GPOS_RESULT
CKeyCollectionTest::EresUnittest_Basics()
{
CAutoMemoryPool amp;
CMemoryPool *mp = amp.Pmp();
CColRefSet *pcrs = GPOS_NEW(mp) CColRefSet(mp);
// Setup an MD cache with a file-based provider
CMDProviderMemory *pmdp = CTestUtils::m_pmdpf;
pmdp->AddRef();
CMDAccessor mda(mp, CMDCache::Pcache());
mda.RegisterProvider(CTestUtils::m_sysidDefault, pmdp);
// install opt context in TLS
CAutoOptCtxt aoc(mp, &mda, nullptr, /* pceeval */
CTestUtils::GetCostModel(mp));
// get column factory from optimizer context object
CColumnFactory *col_factory = COptCtxt::PoctxtFromTLS()->Pcf();
// create test set
CWStringConst strName(GPOS_WSZ_LIT("Test Column"));
CName name(&strName);
const IMDTypeInt4 *pmdtypeint4 = mda.PtMDType<IMDTypeInt4>();
CKeyCollection *pkc = GPOS_NEW(mp) CKeyCollection(mp);
const ULONG num_cols = 10;
for (ULONG i = 0; i < num_cols; i++)
{
CColRef *colref =
col_factory->PcrCreate(pmdtypeint4, default_type_modifier, name);
pcrs->Include(colref);
}
pkc->Add(pcrs);
GPOS_ASSERT(pkc->FKey(pcrs));
CColRefArray *colref_array = pkc->PdrgpcrKey(mp);
GPOS_ASSERT(pkc->FKey(mp, colref_array));
pcrs->Include(colref_array);
GPOS_ASSERT(pkc->FKey(pcrs));
colref_array->Release();
pkc->Release();
return GPOS_OK;
}
//---------------------------------------------------------------------------
// @function:
// CKeyCollectionTest::EresUnittest_Subsumes
//
// @doc:
// Basic test for triming key collections
//
//---------------------------------------------------------------------------
GPOS_RESULT
CKeyCollectionTest::EresUnittest_Subsumes()
{
CAutoMemoryPool amp;
CMemoryPool *mp = amp.Pmp();
// Setup an MD cache with a file-based provider
CMDProviderMemory *pmdp = CTestUtils::m_pmdpf;
pmdp->AddRef();
CMDAccessor mda(mp, CMDCache::Pcache());
mda.RegisterProvider(CTestUtils::m_sysidDefault, pmdp);
// install opt context in TLS
CAutoOptCtxt aoc(mp, &mda, nullptr, /* pceeval */
CTestUtils::GetCostModel(mp));
// get column factory from optimizer context object
CColumnFactory *col_factory = COptCtxt::PoctxtFromTLS()->Pcf();
// create test set
CWStringConst strName(GPOS_WSZ_LIT("Test Column"));
CName name(&strName);
const IMDTypeInt4 *pmdtypeint4 = mda.PtMDType<IMDTypeInt4>();
CKeyCollection *pkc = GPOS_NEW(mp) CKeyCollection(mp);
CColRefSet *pcrs0 = GPOS_NEW(mp) CColRefSet(mp);
CColRefSet *pcrs1 = GPOS_NEW(mp) CColRefSet(mp);
CColRefSet *pcrs2 = GPOS_NEW(mp) CColRefSet(mp);
const ULONG num_cols = 10;
const ULONG ulLen1 = 3;
for (ULONG ul = 0; ul < num_cols; ul++)
{
CColRef *colref =
col_factory->PcrCreate(pmdtypeint4, default_type_modifier, name);
pcrs0->Include(colref);
if (ul < ulLen1)
{
pcrs1->Include(colref);
}
if (ul == 0)
{
pcrs2->Include(colref);
}
}
pkc->Add(pcrs0);
pkc->Add(pcrs1);
pkc->Add(pcrs2);
GPOS_ASSERT(pkc->FKey(pcrs2));
// get the second key
CColRefArray *colref_array = pkc->PdrgpcrKey(mp, 1);
GPOS_ASSERT(ulLen1 == colref_array->Size());
GPOS_ASSERT(pkc->FKey(mp, colref_array));
// get the subsumed key
CColRefArray *pdrgpcrSubsumed = pkc->PdrgpcrTrim(mp, colref_array);
GPOS_ASSERT(colref_array->Size() >= pdrgpcrSubsumed->Size());
CColRefSet *pcrsSubsumed = GPOS_NEW(mp) CColRefSet(mp);
pcrsSubsumed->Include(colref_array);
#ifdef GPOS_DEBUG
const ULONG ulLenSubsumed = pdrgpcrSubsumed->Size();
for (ULONG ul = 0; ul < ulLenSubsumed; ul++)
{
CColRef *colref = (*pdrgpcrSubsumed)[ul];
GPOS_ASSERT(pcrsSubsumed->FMember(colref));
}
#endif // GPOS_DEBUG
pcrsSubsumed->Release();
colref_array->Release();
pdrgpcrSubsumed->Release();
pkc->Release();
return GPOS_OK;
}
// EOF
相关信息
相关文章
greenplumn CColRefSetIterTest 源码
greenplumn CColumnFactoryTest 源码
greenplumn CDistributionSpecTest 源码
greenplumn CEquivalenceClassesTest 源码
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦