1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- /*
- * 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"
- #include "../../lib/spells/AbilityCaster.h"
- 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));
- casterBonuses.addNewBonus(std::make_shared<Bonus>(BonusDuration::ONE_BATTLE, BonusType::MAGIC_SCHOOL_SKILL, BonusSource::OTHER, 2, BonusSourceID(), BonusSubtypeID(SpellSchool::ANY)));
- EXPECT_CALL(actualCaster, getAllBonuses(_, _)).Times(AtLeast(1));
- EXPECT_CALL(actualCaster, getTreeVersion()).Times(AtLeast(0));
- setupSubject(1);
- EXPECT_EQ(subject->getSpellSchoolLevel(&spellMock), 2);
- }
- TEST_F(AbilityCasterTest, MagicAbilityIgnoresSchoolBonus)
- {
- EXPECT_CALL(spellMock, getLevel()).WillRepeatedly(Return(1));
- casterBonuses.addNewBonus(std::make_shared<Bonus>(BonusDuration::ONE_BATTLE, BonusType::MAGIC_SCHOOL_SKILL, BonusSource::OTHER, 2, BonusSourceID(), BonusSubtypeID(SpellSchool::AIR)));
- EXPECT_CALL(actualCaster, getAllBonuses(_, _)).Times(AtLeast(1));
- EXPECT_CALL(actualCaster, getTreeVersion()).Times(AtLeast(0));
- setupSubject(1);
- EXPECT_EQ(subject->getSpellSchoolLevel(&spellMock), 1);
- }
- }
|