#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 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& 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::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 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 ); //} }