1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-10 00:43:59 +02:00
vcmi/test/spells/effects/EffectFixture.cpp

122 lines
3.9 KiB
C++

/*
* EffectFixture.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 "EffectFixture.h"
#include <vstd/RNG.h>
#include "../../../lib/networkPacks/PacksForClientBattle.h"
#include "../../../lib/networkPacks/SetStackEffect.h"
#include "../../../lib/serializer/JsonDeserializer.h"
bool battle::operator==(const Destination& left, const Destination& right)
{
return left.unitValue == right.unitValue && left.hexValue == right.hexValue;
}
bool operator==(const Bonus & b1, const Bonus & b2)
{
return b1.duration == b2.duration
&& b1.type == b2.type
&& b1.subtype == b2.subtype
&& b1.source == b2.source
&& b1.val == b2.val
&& b1.sid == b2.sid
&& b1.valType == b2.valType
&& b1.additionalInfo == b2.additionalInfo
&& b1.effectRange == b2.effectRange;
}
namespace test
{
EffectFixture::EffectFixture(std::string effectName_)
:subject(),
problemMock(),
mechanicsMock(),
battleFake(),
effectName(effectName_)
{
}
EffectFixture::~EffectFixture() = default;
void EffectFixture::setupEffect(const JsonNode & effectConfig)
{
subject = Effect::create(GlobalRegistry::get(), effectName);
ASSERT_TRUE(subject);
JsonDeserializer deser(nullptr, effectConfig);
subject->serializeJson(deser);
}
void EffectFixture::setupEffect(Registry * registry, const JsonNode & effectConfig)
{
subject = Effect::create(registry, effectName);
ASSERT_TRUE(subject);
JsonDeserializer deser(nullptr, effectConfig);
subject->serializeJson(deser);
}
void EffectFixture::setUp()
{
#if SCRIPTING_ENABLED
pool = std::make_shared<PoolMock>();
battleFake = std::make_shared<battle::BattleFake>(pool);
#else
battleFake = std::make_shared<battle::BattleFake>();
#endif
battleFake->setUp();
EXPECT_CALL(mechanicsMock, game()).WillRepeatedly(Return(&gameMock));
EXPECT_CALL(mechanicsMock, battle()).WillRepeatedly(Return(battleFake.get()));
ON_CALL(*battleFake, getUnitsIf(_)).WillByDefault(Invoke(&unitsFake, &battle::UnitsFake::getUnitsIf));
ON_CALL(mechanicsMock, spells()).WillByDefault(Return(&spellServiceMock));
ON_CALL(spellServiceMock, getById(_)).WillByDefault(Return(&spellStub));
ON_CALL(mechanicsMock, creatures()).WillByDefault(Return(&creatureServiceMock));
ON_CALL(creatureServiceMock, getById(_)).WillByDefault(Return(&creatureStub));
ON_CALL(serverMock, getRNG()).WillByDefault(Return(&rngMock));
ON_CALL(serverMock, apply(Matcher<BattleLogMessage &>(_))).WillByDefault(Invoke(battleFake.get(), &battle::BattleFake::accept<BattleLogMessage>));
ON_CALL(serverMock, apply(Matcher<BattleStackMoved &>(_))).WillByDefault(Invoke(battleFake.get(), &battle::BattleFake::accept<BattleStackMoved>));
ON_CALL(serverMock, apply(Matcher<BattleUnitsChanged &>(_))).WillByDefault(Invoke(battleFake.get(), &battle::BattleFake::accept<BattleUnitsChanged>));
ON_CALL(serverMock, apply(Matcher<SetStackEffect &>(_))).WillByDefault(Invoke(battleFake.get(), &battle::BattleFake::accept<SetStackEffect>));
ON_CALL(serverMock, apply(Matcher<StacksInjured &>(_))).WillByDefault(Invoke(battleFake.get(), &battle::BattleFake::accept<StacksInjured>));
ON_CALL(serverMock, apply(Matcher<BattleObstaclesChanged &>(_))).WillByDefault(Invoke(battleFake.get(), &battle::BattleFake::accept<BattleObstaclesChanged>));
ON_CALL(serverMock, apply(Matcher<CatapultAttack &>(_))).WillByDefault(Invoke(battleFake.get(), &battle::BattleFake::accept<CatapultAttack>));
}
static int64_t getInt64Range(int64_t lower, int64_t upper)
{
return (lower + upper)/2;
}
static double getDoubleRange(double lower, double upper)
{
return (lower + upper)/2;
}
void EffectFixture::setupDefaultRNG()
{
EXPECT_CALL(serverMock, getRNG()).Times(AtLeast(0));
EXPECT_CALL(rngMock, nextInt64(_,_)).WillRepeatedly(Invoke(&getInt64Range));
EXPECT_CALL(rngMock, nextDouble(_,_)).WillRepeatedly(Invoke(&getDoubleRange));
}
}