2018-03-02 13:22:51 +03:00
|
|
|
/*
|
|
|
|
* AbilityCasterTest.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 "mock/mock_battle_Unit.h"
|
|
|
|
#include "mock/mock_BonusBearer.h"
|
|
|
|
#include "mock/mock_spells_Spell.h"
|
|
|
|
|
2018-03-09 21:11:20 +03:00
|
|
|
#include "../../lib/spells/AbilityCaster.h"
|
2018-03-02 13:22:51 +03:00
|
|
|
|
|
|
|
namespace test
|
|
|
|
{
|
|
|
|
using namespace ::spells;
|
|
|
|
using namespace ::testing;
|
|
|
|
|
|
|
|
|
|
|
|
class AbilityCasterTest : public Test
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
std::shared_ptr<AbilityCaster> subject;
|
|
|
|
|
|
|
|
StrictMock<UnitMock> actualCaster;
|
|
|
|
BonusBearerMock casterBonuses;
|
|
|
|
StrictMock<SpellMock> spellMock;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void SetUp() override
|
|
|
|
{
|
|
|
|
ON_CALL(actualCaster, getAllBonuses(_, _, _, _)).WillByDefault(Invoke(&casterBonuses, &BonusBearerMock::getAllBonuses));
|
|
|
|
ON_CALL(actualCaster, getTreeVersion()).WillByDefault(Invoke(&casterBonuses, &BonusBearerMock::getTreeVersion));
|
|
|
|
}
|
|
|
|
|
|
|
|
void setupSubject(int skillLevel)
|
|
|
|
{
|
|
|
|
subject = std::make_shared<AbilityCaster>(&actualCaster, skillLevel);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(AbilityCasterTest, NonMagicAbilityIgnoresBonuses)
|
|
|
|
{
|
|
|
|
EXPECT_CALL(spellMock, getLevel()).WillRepeatedly(Return(0));
|
|
|
|
setupSubject(1);
|
|
|
|
|
|
|
|
EXPECT_EQ(subject->getSpellSchoolLevel(&spellMock), 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(AbilityCasterTest, MagicAbilityAffectedByGenericBonus)
|
|
|
|
{
|
|
|
|
EXPECT_CALL(spellMock, getLevel()).WillRepeatedly(Return(1));
|
|
|
|
|
2023-10-21 14:50:42 +03:00
|
|
|
casterBonuses.addNewBonus(std::make_shared<Bonus>(BonusDuration::ONE_BATTLE, BonusType::MAGIC_SCHOOL_SKILL, BonusSource::OTHER, 2, BonusSourceID(), BonusSubtypeID(SpellSchool::ANY)));
|
2018-03-02 13:22:51 +03:00
|
|
|
|
|
|
|
EXPECT_CALL(actualCaster, getAllBonuses(_, _, _, _)).Times(AtLeast(1));
|
|
|
|
EXPECT_CALL(actualCaster, getTreeVersion()).Times(AtLeast(0));
|
|
|
|
|
|
|
|
setupSubject(1);
|
|
|
|
|
|
|
|
EXPECT_EQ(subject->getSpellSchoolLevel(&spellMock), 2);
|
|
|
|
}
|
|
|
|
|
2024-06-24 03:23:26 +02:00
|
|
|
TEST_F(AbilityCasterTest, MagicAbilityIgnoresSchoolBonus)
|
2018-03-02 13:22:51 +03:00
|
|
|
{
|
|
|
|
EXPECT_CALL(spellMock, getLevel()).WillRepeatedly(Return(1));
|
|
|
|
|
2023-10-21 14:50:42 +03:00
|
|
|
casterBonuses.addNewBonus(std::make_shared<Bonus>(BonusDuration::ONE_BATTLE, BonusType::MAGIC_SCHOOL_SKILL, BonusSource::OTHER, 2, BonusSourceID(), BonusSubtypeID(SpellSchool::AIR)));
|
2018-03-02 13:22:51 +03:00
|
|
|
|
|
|
|
EXPECT_CALL(actualCaster, getAllBonuses(_, _, _, _)).Times(AtLeast(1));
|
|
|
|
EXPECT_CALL(actualCaster, getTreeVersion()).Times(AtLeast(0));
|
|
|
|
|
|
|
|
setupSubject(1);
|
|
|
|
|
|
|
|
EXPECT_EQ(subject->getSpellSchoolLevel(&spellMock), 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|