ImmunityNegationConditionTest.cpp 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. * ImmunityNegationConditionTest.cpp, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #include "StdInc.h"
  11. #include "TargetConditionItemFixture.h"
  12. #include "../../../lib/bonuses/BonusSubtypes.h"
  13. //FIXME: Orb of vulnerability mechanics is not such trivial (mantis issue 1791)
  14. //TODO: NEGATE_ALL_NATURAL_IMMUNITIES special cases: dispel, chain lightning
  15. //Tests are incomplete and only covers actual implementation for now
  16. namespace test
  17. {
  18. using namespace ::spells;
  19. using namespace ::testing;
  20. class ImmunityNegationConditionTest : public TargetConditionItemTest, public WithParamInterface<std::tuple<bool, bool>>
  21. {
  22. public:
  23. bool ownerMatches;
  24. bool isMagicalEffect;
  25. void setDefaultExpectations()
  26. {
  27. ownerMatches = ::testing::get<0>(GetParam());
  28. isMagicalEffect = ::testing::get<1>(GetParam());
  29. EXPECT_CALL(unitMock, getAllBonuses(_, _, _, _)).Times(AtLeast(0));
  30. EXPECT_CALL(unitMock, getTreeVersion()).Times(AtLeast(0));
  31. EXPECT_CALL(mechanicsMock, isMagicalEffect()).Times(AtLeast(0)).WillRepeatedly(Return(isMagicalEffect));
  32. EXPECT_CALL(mechanicsMock, ownerMatches(Eq(&unitMock), Field(&boost::logic::tribool::value, boost::logic::tribool::false_value))).WillRepeatedly(Return(ownerMatches));
  33. }
  34. protected:
  35. void SetUp() override
  36. {
  37. TargetConditionItemTest::SetUp();
  38. subject = TargetConditionItemFactory::getDefault()->createImmunityNegation();
  39. GTEST_ASSERT_NE(subject, nullptr);
  40. }
  41. };
  42. TEST_P(ImmunityNegationConditionTest, NotReceptiveByDefault)
  43. {
  44. setDefaultExpectations();
  45. EXPECT_FALSE(subject->isReceptive(&mechanicsMock, &unitMock));
  46. }
  47. TEST_P(ImmunityNegationConditionTest, WithHeroNegation)
  48. {
  49. setDefaultExpectations();
  50. unitBonuses.addNewBonus(std::make_shared<Bonus>(BonusDuration::ONE_BATTLE, BonusType::NEGATE_ALL_NATURAL_IMMUNITIES, BonusSource::OTHER, 0, TBonusSourceID::NONE, BonusSubtypes::immunityEnemyHero));
  51. EXPECT_EQ(isMagicalEffect, subject->isReceptive(&mechanicsMock, &unitMock));
  52. }
  53. TEST_P(ImmunityNegationConditionTest, WithBattleWideNegation)
  54. {
  55. setDefaultExpectations();
  56. unitBonuses.addNewBonus(std::make_shared<Bonus>(BonusDuration::ONE_BATTLE, BonusType::NEGATE_ALL_NATURAL_IMMUNITIES, BonusSource::OTHER, 0, TBonusSourceID::NONE, BonusSubtypes::immunityBattleWide));
  57. //This should return if ownerMatches, because anyone should cast onto owner's stacks, but not on enemyStacks
  58. EXPECT_EQ(ownerMatches && isMagicalEffect, subject->isReceptive(&mechanicsMock, &unitMock));
  59. }
  60. INSTANTIATE_TEST_SUITE_P
  61. (
  62. ByUnitOwner,
  63. ImmunityNegationConditionTest,
  64. Combine
  65. (
  66. Values(false, true),
  67. Values(false, true)
  68. )
  69. );
  70. }