DragonNest/Client/DnTableVerifier/item_data_test.cpp
Cussrro 47f7895977 Revert "修复编码问题"
This reverts commit 9e69c01767.
2024-12-21 10:04:04 +08:00

300 lines
No EOL
10 KiB
C++

#include "StdAfx.h"
#include "item_data_test.h"
DNTableFileFormat* item_data_test::s_pItemTable = NULL;
DNTableFileFormat* item_data_test::s_pItemDropTable = NULL;
DNTableFileFormat* item_data_test::s_pItemDropGroupTable = NULL;
DNTableFileFormat* item_data_test::s_pCombinedShopTable = NULL;
#define ITEM_T item_data_test::s_pItemTable
#define ITEMDROP_T item_data_test::s_pItemDropTable
#define ITEMDROPGROUP_T item_data_test::s_pItemDropGroupTable
#define COMBINEDSHOP_T item_data_test::s_pCombinedShopTable
item_data_test::item_data_test(void)
{
}
item_data_test::~item_data_test(void)
{
}
void item_data_test::SetUpTestCase( void )
{
//// 지정된 국가 우선으로 검색하고 없으면 기본 리소스 폴더에서 찾는다.
//vector<string> vlFilePathsToVerify;
//string strTableFullPath;
//// ItemTable_Quest, ItemTable_Event, ItemTable_Equipment, ItemTable_Cash 시리즈별로 모두 모아서 로드 됨.
//GatherConcernedExt( "ItemTable.ext", vlFilePathsToVerify, strTableFullPath );
//s_pItemTable = new DNTableFileFormat( strTableFullPath.c_str() );
//GatherConcernedExt( "ItemDropTable.ext", vlFilePathsToVerify, strTableFullPath );
//s_pItemDropTable = new DNTableFileFormat( strTableFullPath.c_str() );
//GatherConcernedExt( "ItemDropGroupTable.ext", vlFilePathsToVerify, strTableFullPath );
//s_pItemDropGroupTable = new DNTableFileFormat( strTableFullPath.c_str() );
s_pItemTable = LoadExtFile( "ItemTable.dnt" );
s_pItemDropTable = LoadExtFile( "ItemDropTable.dnt" );
s_pItemDropGroupTable = LoadExtFile( "ItemDropGroupTable.dnt" );
s_pCombinedShopTable = LoadExtFile( "combinedshoptable.dnt" );
}
void item_data_test::TearDownTestCase( void )
{
SAFE_DELETE( s_pItemTable );
SAFE_DELETE( s_pItemDropTable );
SAFE_DELETE( s_pItemDropGroupTable );
SAFE_DELETE( s_pCombinedShopTable );
}
void item_data_test::SetUp( void )
{
}
void item_data_test::TearDown( void )
{
}
void ValidateItemDropGroupTableID( const char* pLabel, int iGroupTableID )
{
//char acBuf[ MAX_PATH ] = { 0 };
//TCHAR atcBuf[ 256 ] = { 0 };
//for( int k = 1; k <= 10; ++k )
//{
// sprintf_s( acBuf, pLabel, k );
// int iDropTableIDToFind = ITEMDROPGROUP_T->GetFieldFromLablePtr( iGroupTableID, acBuf )->GetInteger();
// if( 0 == iDropTableIDToFind )
// continue;
// _stprintf_s( atcBuf, _T("{TableName:ItemDropGroupTable, Index:%d, Note:존재하지 않는 DropTableID(%d) 입니다.}"), iGroupTableID, iDropTableIDToFind );
// SCOPED_TRACE( atcBuf );
// EXPECT_TRUE( ITEMDROP_T->IsExistItem( iDropTableIDToFind ) );
//}
}
// 1. Easy1~10, Normal1~10, Hard1~0, Master1~10, Abyss1~10 총 50개 항목의 인덱스가 ItemDropTableID에 없으면 Error.
TEST_F( item_data_test, GROUPTABLE_REFERENCED_INVALID_DROP_TABLE_ID )
{
// #38719, #31905 이슈로 드랍 그룹 테이블 구조 변경됨. 변경된 것 반영.
TCHAR atcBuf[ 256 ] = { 0 };
int iNumGroupTable = ITEMDROPGROUP_T->GetItemCount();
for( int i = 0; i < iNumGroupTable; ++i )
{
int iGroupTableID = ITEMDROPGROUP_T->GetItemID( i );
int iDropTableIDToFind = ITEMDROPGROUP_T->GetFieldFromLablePtr( iGroupTableID, "_DropID" )->GetInteger();
_stprintf_s( atcBuf, _T("{TableName:ItemDropGroupTable, Index:%d, Note:존재하지 않는 DropTableID(%d) 입니다.}"), iGroupTableID, iDropTableIDToFind );
SCOPED_TRACE( atcBuf );
EXPECT_TRUE( ITEMDROP_T->IsExistItem( iDropTableIDToFind ) );
}
//int iNumGroupTable = ITEMDROPGROUP_T->GetItemCount();
//for( int i = 0; i < iNumGroupTable; ++i )
//{
// int iGroupTableID = ITEMDROPGROUP_T->GetItemID( i );
// ValidateItemDropGroupTableID( "Easy%d", iGroupTableID );
// ValidateItemDropGroupTableID( "Normal%d", iGroupTableID );
// ValidateItemDropGroupTableID( "Hard%d", iGroupTableID );
// ValidateItemDropGroupTableID( "Master%d", iGroupTableID );
// ValidateItemDropGroupTableID( "Abyss%d", iGroupTableID );
//}
}
// 1. _Item1Prob ~ _Item20Prob의 총 합이 10억 (1,000,000,000) 이 넘는 경우 Error
TEST_F( item_data_test, DROP_TABLE_PROB_OVER )
{
char acBuf[ 256 ] = { 0 };
TCHAR atcBuf[ 256 ] = { 0 };
int iNumDropTable = ITEMDROP_T->GetItemCount();
for( int i = 0; i < iNumDropTable; ++i )
{
int iDropTableID = ITEMDROP_T->GetItemID( i );
int iWholeProb = 0;
for( int k = 1; k <= 20; ++k )
{
sprintf_s( acBuf, "_Item%dProb", k );
int iProb = ITEMDROP_T->GetFieldFromLablePtr( iDropTableID, acBuf )->GetInteger();
iWholeProb += iProb;
}
_stprintf_s( atcBuf, _T("{TableName:ItemDropTable, Index:%d, Note:확률 값의 합이 10억 보다 큽니다. 현재 합계- %d}"), iDropTableID, iWholeProb );
SCOPED_TRACE( atcBuf );
EXPECT_LE( iWholeProb, 1000000000 );
}
}
//
//// 2. _IsGroup 의 값이 n 일때 _Item1Index ~ _Item20Index에 설정된 Index에 해당하는 아이템이 없는 경우 Error.
//TEST_F( item_data_test, INVALID_REFERENCE_ITEM_TABLE_ID )
//{
// char acBuf[ 256 ] = { 0 };
// TCHAR atcBuf[ 256 ] = { 0 };
// int iNumDropTable = ITEMDROP_T->GetItemCount();
// for( int i = 0; i < iNumDropTable; ++i )
// {
// int iDropTableID = ITEMDROP_T->GetItemID( i );
// int iWholeProb = 0;
// for( int k = 1; k <= 20; ++k )
// {
// sprintf_s( acBuf, "_IsGroup%d", k );
// int iIsGroup = ITEMDROP_T->GetFieldFromLablePtr( iDropTableID, acBuf )->GetInteger();
// if( iIsGroup == 0 )
// {
// sprintf_s( acBuf, "_Item%dIndex", k );
// int iItemTableID = ITEMDROP_T->GetFieldFromLablePtr( iDropTableID, acBuf )->GetInteger();
//
// if( 0 == iItemTableID )
// continue;
//
// _stprintf_s( atcBuf, _T("[DropTableID: %d] 존재하지 않는 아이템 ID 입니다. 참조 아이템ID: %d"), iDropTableID, iItemTableID );
// SCOPED_TRACE( atcBuf );
// EXPECT_TRUE( ITEM_T->IsExistItem( iItemTableID ) );
// }
// }
// }
//}
void ValidateDropTableReferenceItemID( int iDropTableID/*, vector<int>& vlParentDropTableStack*/ )
{
char acBuf[ 256 ] = { 0 };
TCHAR atcBuf[ 256 ] = { 0 };
for( int k = 1; k <= 20; ++k )
{
sprintf_s( acBuf, "_IsGroup%d", k );
int iIsGroup = ITEMDROP_T->GetFieldFromLablePtr( iDropTableID, acBuf )->GetInteger();
if( iIsGroup == 1 )
{
sprintf_s( acBuf, "_Item%dIndex", k );
int iReferenceDropTableID = ITEMDROP_T->GetFieldFromLablePtr( iDropTableID, acBuf )->GetInteger();
if( 0 == iReferenceDropTableID )
continue;
//vector<int>::iterator iter = find( vlParentDropTableStack.begin(), vlParentDropTableStack.end(), iReferenceDropTableID );
//bool bDuplicatedSelfReference = (vlParentDropTableStack.end() != iter);
//if( bDuplicatedSelfReference )
//{
// continue;
//}
_stprintf_s( atcBuf, _T("{TableName:ItemDropTable, Index:%d, _Item%dIndex:%d, Note:존재하지 않는 DropTableID 입니다.}"), iDropTableID, k, iReferenceDropTableID );
SCOPED_TRACE( atcBuf );
bool bExistDropItemID = ITEMDROP_T->IsExistItem( iReferenceDropTableID );
EXPECT_TRUE( bExistDropItemID );
//if( bExistDropItemID )
//{
//vlParentDropTableStack.push_back( iReferenceDropTableID );
//ValidateDropTableReferenceItemID( iReferenceDropTableID/*, vlParentDropTableStack*/ );
//vlParentDropTableStack.pop_back();
//}
}
else
{
sprintf_s( acBuf, "_Item%dIndex", k );
int iItemTableID = ITEMDROP_T->GetFieldFromLablePtr( iDropTableID, acBuf )->GetInteger();
if( 0 == iItemTableID )
continue;
_stprintf_s( atcBuf, _T("{TableName:ItemDropTable, Index:%d, _Item%dIndex:%d, Note:존재하지 않는 ItemTableID 입니다.}"), iDropTableID, k, iItemTableID );
SCOPED_TRACE( atcBuf );
EXPECT_TRUE( ITEM_T->IsExistItem( iItemTableID ) );
}
}
}
// 3. _IsGroup 의 값이 y 일때 _Item1Index ~ _Item20Index에 설정된 Index에 해당하는 ItemDropTableID가 없는 경우 Error.TEST_F( item_data_test, INVALID_REFERENCE_ITEM_TABLE_ID )
TEST_F( item_data_test, INVALID_REFERENCE_DROP_GROUP_TABLE_ID )
{
int iNumDropTable = ITEMDROP_T->GetItemCount();
for( int i = 0; i < iNumDropTable; ++i )
{
int iDropTableID = ITEMDROP_T->GetItemID( i );
// 드랍 테이블이 자신의 인덱스를 참조하므로 무한참조로 이어지는지 체크.
//vector<int> vlDropTableIDStack;
//vlDropTableIDStack.push_back( iDropTableID );
ValidateDropTableReferenceItemID( iDropTableID/*, vlDropTableIDStack*/ );
//_ASSERT( (int)vlDropTableIDStack.size() == 1 );
}
}
// #45783 CombinedShop 테이블 검증 추가 요청
TEST_F( item_data_test, INVALID_ID_REFERENCE_COMBINED_SHOP_TABLE_ID )
{
TCHAR atcBuf[ 256 ] = { 0 };
int iNumCombinedShopTable = COMBINEDSHOP_T->GetItemCount();
for( int i = 0; i < iNumCombinedShopTable; ++i )
{
int iCombinedShopTableID = COMBINEDSHOP_T->GetItemID( i );
// 아이템 테이블에 존재하는지 체크
int iItemTableID = COMBINEDSHOP_T->GetFieldFromLablePtr( iCombinedShopTableID, "_itemindex" )->GetInteger();
_stprintf_s( atcBuf, _T("{TableName:CombinedShopTable, Index:%d, Note:존재하지 않는 ItemTableID(%d) 입니다.}"), iCombinedShopTableID, iItemTableID );
SCOPED_TRACE( atcBuf );
EXPECT_TRUE( ITEM_T->IsExistItem( iItemTableID ) );
}
}
// #48623 상점 판매 가격이 더 비싼 관련 테이블 데이터 검증
TEST_F( item_data_test, SELLING_PRICE_ERROR )
{
TCHAR atcBuf[ 256 ] = { 0 };
int iNumItems = COMBINEDSHOP_T->GetItemCount();
for( int i = 0; i < iNumItems; ++i )
{
int iItemID = COMBINEDSHOP_T->GetItemID( i );
int aiPurchaseType[ 2 ] = { 0 };
aiPurchaseType[ 0 ] = COMBINEDSHOP_T->GetFieldFromLablePtr( iItemID, "_PurchaseType1" )->GetInteger();
aiPurchaseType[ 1 ] = COMBINEDSHOP_T->GetFieldFromLablePtr( iItemID, "_PurchaseType2" )->GetInteger();
// 1 이 골드임. 골드만 검증하면 됨.
for( int k = 0; k < 2; ++k )
{
int iItemTableID = COMBINEDSHOP_T->GetFieldFromLablePtr( iItemID, "_itemindex" )->GetInteger();
if( 1 == aiPurchaseType[ k ] )
{
char acBuf[ 128 ] = { 0 };
sprintf_s( acBuf, "_PurchaseItemValue%d", k+1 );
int iBuyPrice = COMBINEDSHOP_T->GetFieldFromLablePtr( iItemID, acBuf )->GetInteger();
int iSellPriceTwice = ITEM_T->GetFieldFromLablePtr( iItemTableID, "_SellAmount" )->GetInteger() * 2;
_stprintf_s( atcBuf, _T("{TableName:CombinedShopTable, Index:%d, Note:상점 판매금액이 구입가보다 높습니다.}"), iItemTableID );
SCOPED_TRACE( atcBuf );
EXPECT_GE( iBuyPrice, iSellPriceTwice );
}
}
}
//// 앞으로 아이템 테이블 것은 안쓴다지만.. 쓰는 곳도 있다하니 일단 추가.
//iNumItems = ITEM_T->GetItemCount();
//for( int i = 0; i < iNumItems; ++i )
//{
// int iItemID = ITEM_T->GetItemID( i );
// int iBuyPrice = ITEM_T->GetFieldFromLablePtr( iItemID, "_Amount" )->GetInteger();
// int iSellPriceTwice = ITEM_T->GetFieldFromLablePtr( iItemID, "_SellAmount" )->GetInteger();
// _stprintf_s( atcBuf, _T("{TableName:ItemTable, Index:%d, Note:상점 판매금액이 구입가보다 높습니다.}"), iItemID );
// SCOPED_TRACE( atcBuf );
// EXPECT_GT( iBuyPrice, iSellPriceTwice );
//}
}