mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-04 00:15:53 +02:00
3dd4fa2528
Final goal (of multiple PR's) is to remove all remaining pointers from serializeable game state, and replace them with either identifiers or with shared/unique pointers. CGTownInstance::town and CGHeroInstance::type members have been removed. Now this data is computed dynamically using subID member. VLC entity of a town can now be accessed via following methods: - getFactionID() returns ID of a faction - getFaction() returns pointer to a faction - getTown() returns pointer to a town VLC entity of a hero can now be accessed via following methods: - getHeroTypeID() returns ID of a hero - getHeroClassID() returns ID of a hero class - getHeroType() returns pointer to a hero - getHeroClass() returns pointer to a hero class
177 lines
5.2 KiB
C++
177 lines
5.2 KiB
C++
/*
|
|
* CCreatureTest.cpp, part of VCMI engine
|
|
*
|
|
* Authors: listed in file AUTHORS in main folder
|
|
*
|
|
* License: GNU General Public License v2.0 or later
|
|
* Full text of license available in license.txt file, in main folder
|
|
*
|
|
*/
|
|
#include "StdInc.h"
|
|
|
|
#include "../../lib/CCreatureHandler.h"
|
|
#include "../../lib/json/JsonNode.h"
|
|
|
|
namespace test
|
|
{
|
|
|
|
using namespace ::testing;
|
|
|
|
class CCreatureTest : public Test
|
|
{
|
|
public:
|
|
MOCK_METHOD4(registarCb, void(int32_t, int32_t, const std::string &, const std::string &));
|
|
protected:
|
|
std::shared_ptr<CCreature> subject;
|
|
|
|
void SetUp() override
|
|
{
|
|
subject = std::make_shared<CCreature>();
|
|
}
|
|
};
|
|
|
|
TEST_F(CCreatureTest, RegistersIcons)
|
|
{
|
|
subject->iconIndex = 4242;
|
|
subject->smallIconName = "Test1";
|
|
subject->largeIconName = "Test2";
|
|
|
|
auto cb = [this](auto && PH1, auto && PH2, auto && PH3, auto && PH4)
|
|
{
|
|
registarCb(std::forward<decltype(PH1)>(PH1), std::forward<decltype(PH2)>(PH2), std::forward<decltype(PH3)>(PH3), std::forward<decltype(PH4)>(PH4));
|
|
};
|
|
|
|
EXPECT_CALL(*this, registarCb(Eq(4242), Eq(0), "CPRSMALL", "Test1"));
|
|
EXPECT_CALL(*this, registarCb(Eq(4242), Eq(0), "TWCRPORT", "Test2"));
|
|
|
|
subject->registerIcons(cb);
|
|
}
|
|
|
|
TEST_F(CCreatureTest, DISABLED_JsonUpdate)
|
|
{
|
|
JsonNode data;
|
|
|
|
JsonNode & config = data["config"];
|
|
config["cost"]["gold"].Integer() = 750;
|
|
config["attack"].Integer() = 17;
|
|
config["defense"].Integer() = 15;
|
|
config["hitPoints"].Integer() = 50;
|
|
|
|
config["speed"].Integer() = 9;
|
|
config["damage"]["min"].Integer() = 12;
|
|
config["damage"]["max"].Integer() = 20;
|
|
config["shots"].Integer() = 100;
|
|
|
|
config["growth"].Integer() = 1;
|
|
config["spellPoints"].Integer() = 2;
|
|
config["horde"].Integer() = 123;
|
|
config["aiValue"].Integer() = 3388;
|
|
|
|
config["fightValue"].Integer() = 2420;
|
|
config["level"].Integer() = 6;
|
|
config["faction"].Integer() = 55;
|
|
config["doubleWide"].Bool() = true;
|
|
|
|
subject->updateFrom(data);
|
|
|
|
EXPECT_EQ(subject->getRecruitCost(EGameResID::GOLD), 750);
|
|
EXPECT_EQ(subject->getBaseAttack(), 17);
|
|
EXPECT_EQ(subject->getAttack(false), 17);
|
|
EXPECT_EQ(subject->getAttack(true), 17);
|
|
|
|
EXPECT_EQ(subject->getBaseDefense(), 15);
|
|
EXPECT_EQ(subject->getDefense(false), 15);
|
|
EXPECT_EQ(subject->getDefense(true), 15);
|
|
EXPECT_EQ(subject->getBaseHitPoints(), 50);
|
|
|
|
EXPECT_EQ(subject->getBaseSpeed(), 9);
|
|
EXPECT_EQ(subject->getBaseDamageMin(), 12);
|
|
EXPECT_EQ(subject->getMinDamage(false), 12);
|
|
EXPECT_EQ(subject->getMinDamage(true), 12);
|
|
EXPECT_EQ(subject->getBaseDamageMax(), 20);
|
|
EXPECT_EQ(subject->getMaxDamage(false), 20);
|
|
EXPECT_EQ(subject->getMaxDamage(true), 20);
|
|
EXPECT_EQ(subject->getBaseShots(), 100);
|
|
|
|
EXPECT_EQ(subject->getGrowth(), 1);
|
|
EXPECT_EQ(subject->getBaseSpellPoints(), 2);
|
|
EXPECT_EQ(subject->getHorde(), 123);
|
|
EXPECT_EQ(subject->getAIValue(), 3388);
|
|
|
|
EXPECT_EQ(subject->getFightValue(), 2420);
|
|
EXPECT_EQ(subject->getLevel(), 6);
|
|
EXPECT_EQ(subject->getFactionID().getNum(), 55);
|
|
EXPECT_TRUE(subject->isDoubleWide());
|
|
}
|
|
|
|
TEST_F(CCreatureTest, DISABLED_JsonAddBonus)
|
|
{
|
|
JsonNode data;
|
|
|
|
auto b = std::make_shared<Bonus>(BonusDuration::PERMANENT, BonusType::BLOCKS_RETALIATION, BonusSource::CREATURE_ABILITY, 17, BonusSourceID(CreatureID(42)), BonusSubtypeID(CreatureID(43)), BonusValueType::BASE_NUMBER);
|
|
|
|
JsonNode & toAdd = data["bonuses"]["toAdd"];
|
|
|
|
toAdd.Vector().push_back(b->toJsonNode());
|
|
|
|
subject->updateFrom(data);
|
|
|
|
auto selector = [](const Bonus * bonus)
|
|
{
|
|
return (bonus->duration == BonusDuration::PERMANENT)
|
|
&& (bonus->type == BonusType::BLOCKS_RETALIATION)
|
|
&& (bonus->source == BonusSource::CREATURE_ABILITY)
|
|
&& (bonus->val == 17)
|
|
&& (bonus->sid.as<CreatureID>().getNum() == 42)
|
|
&& (bonus->subtype.as<CreatureID>().getNum() == 43)
|
|
&& (bonus->valType == BonusValueType::BASE_NUMBER);
|
|
};
|
|
|
|
EXPECT_TRUE(subject->hasBonus(selector));
|
|
}
|
|
|
|
TEST_F(CCreatureTest, DISABLED_JsonRemoveBonus)
|
|
{
|
|
JsonNode data;
|
|
|
|
auto b1 = std::make_shared<Bonus>(BonusDuration::PERMANENT, BonusType::BLOCKS_RETALIATION, BonusSource::CREATURE_ABILITY, 17, BonusSourceID(CreatureID(42)), BonusSubtypeID(CreatureID(43)), BonusValueType::BASE_NUMBER);
|
|
subject->addNewBonus(b1);
|
|
|
|
auto b2 = std::make_shared<Bonus>(BonusDuration::PERMANENT, BonusType::BLOCKS_RETALIATION, BonusSource::CREATURE_ABILITY, 18, BonusSourceID(CreatureID(42)), BonusSubtypeID(CreatureID(43)), BonusValueType::BASE_NUMBER);
|
|
subject->addNewBonus(b2);
|
|
|
|
|
|
JsonNode & toRemove = data["bonuses"]["toRemove"];
|
|
|
|
toRemove.Vector().push_back(b2->toJsonNode());
|
|
|
|
subject->updateFrom(data);
|
|
|
|
auto selector1 = [](const Bonus * bonus)
|
|
{
|
|
return (bonus->duration == BonusDuration::PERMANENT)
|
|
&& (bonus->type == BonusType::BLOCKS_RETALIATION)
|
|
&& (bonus->source == BonusSource::CREATURE_ABILITY)
|
|
&& (bonus->val == 17)
|
|
&& (bonus->sid.as<CreatureID>().getNum() == 42)
|
|
&& (bonus->subtype.as<CreatureID>().getNum() == 43)
|
|
&& (bonus->valType == BonusValueType::BASE_NUMBER);
|
|
};
|
|
|
|
EXPECT_TRUE(subject->hasBonus(selector1));
|
|
|
|
auto selector2 = [](const Bonus * bonus)
|
|
{
|
|
return (bonus->duration == BonusDuration::PERMANENT)
|
|
&& (bonus->type == BonusType::BLOCKS_RETALIATION)
|
|
&& (bonus->source == BonusSource::CREATURE_ABILITY)
|
|
&& (bonus->val == 18)
|
|
&& (bonus->sid.as<CreatureID>().getNum() == 42)
|
|
&& (bonus->valType == BonusValueType::BASE_NUMBER);
|
|
};
|
|
|
|
EXPECT_FALSE(subject->hasBonus(selector2));
|
|
}
|
|
|
|
}
|