mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-12 02:28:11 +02:00
Reduced code duplication in CHealthTest
This commit is contained in:
parent
e677373241
commit
3bc082a1c5
@ -20,12 +20,17 @@ class CUnitHealthInfoMock : public IUnitHealthInfo
|
||||
public:
|
||||
CUnitHealthInfoMock():
|
||||
maxHealth(UNIT_HEALTH),
|
||||
baseAmount(UNIT_AMOUNT)
|
||||
{}
|
||||
baseAmount(UNIT_AMOUNT),
|
||||
health(this)
|
||||
{
|
||||
health.init();
|
||||
}
|
||||
|
||||
int32_t maxHealth;
|
||||
int32_t baseAmount;
|
||||
|
||||
CHealth health;
|
||||
|
||||
int32_t unitMaxHealth() const override
|
||||
{
|
||||
return maxHealth;
|
||||
@ -99,16 +104,12 @@ BOOST_AUTO_TEST_CASE(empty)
|
||||
checkEmptyHealth(health, uhi);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(damage)
|
||||
BOOST_FIXTURE_TEST_CASE(damage, CUnitHealthInfoMock)
|
||||
{
|
||||
CUnitHealthInfoMock uhi;
|
||||
CHealth health(&uhi);
|
||||
health.init();
|
||||
|
||||
checkNormalDamage(health, 0);
|
||||
checkFullHealth(health, uhi);
|
||||
checkFullHealth(health, *this);
|
||||
|
||||
checkNormalDamage(health, uhi.maxHealth - 1);
|
||||
checkNormalDamage(health, maxHealth - 1);
|
||||
BOOST_CHECK_EQUAL(health.getCount(), UNIT_AMOUNT);
|
||||
BOOST_CHECK_EQUAL(health.getFirstHPleft(), 1);
|
||||
BOOST_CHECK_EQUAL(health.getResurrected(), 0);
|
||||
@ -119,17 +120,14 @@ BOOST_AUTO_TEST_CASE(damage)
|
||||
BOOST_CHECK_EQUAL(health.getResurrected(), 0);
|
||||
|
||||
checkNormalDamage(health, UNIT_HEALTH * (UNIT_AMOUNT - 1));
|
||||
checkEmptyHealth(health, uhi);
|
||||
checkEmptyHealth(health, *this);
|
||||
|
||||
checkNoDamage(health, 1337);
|
||||
checkEmptyHealth(health, uhi);
|
||||
checkEmptyHealth(health, *this);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(heal)
|
||||
BOOST_FIXTURE_TEST_CASE(heal, CUnitHealthInfoMock)
|
||||
{
|
||||
CUnitHealthInfoMock uhi;
|
||||
CHealth health(&uhi);
|
||||
health.init();
|
||||
checkNormalDamage(health, 99);
|
||||
BOOST_CHECK_EQUAL(health.getCount(), UNIT_AMOUNT);
|
||||
BOOST_CHECK_EQUAL(health.getFirstHPleft(), UNIT_HEALTH-99);
|
||||
@ -146,15 +144,11 @@ BOOST_AUTO_TEST_CASE(heal)
|
||||
BOOST_CHECK_EQUAL(health.getResurrected(), 0);
|
||||
|
||||
checkHeal(health, EHealLevel::OVERHEAL, EHealPower::PERMANENT, 50, 50);
|
||||
checkFullHealth(health, uhi);
|
||||
checkFullHealth(health, *this);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(resurrectOneBattle)
|
||||
BOOST_FIXTURE_TEST_CASE(resurrectOneBattle, CUnitHealthInfoMock)
|
||||
{
|
||||
CUnitHealthInfoMock uhi;
|
||||
CHealth health(&uhi);
|
||||
health.init();
|
||||
|
||||
checkNormalDamage(health, UNIT_HEALTH);
|
||||
BOOST_CHECK_EQUAL(health.getCount(), UNIT_AMOUNT - 1);
|
||||
BOOST_CHECK_EQUAL(health.getFirstHPleft(), UNIT_HEALTH);
|
||||
@ -173,7 +167,7 @@ BOOST_AUTO_TEST_CASE(resurrectOneBattle)
|
||||
health.init();
|
||||
|
||||
checkNormalDamage(health, UNIT_HEALTH * UNIT_AMOUNT);
|
||||
checkEmptyHealth(health, uhi);
|
||||
checkEmptyHealth(health, *this);
|
||||
|
||||
checkHeal(health, EHealLevel::RESURRECT, EHealPower::ONE_BATTLE, UNIT_HEALTH * UNIT_AMOUNT, UNIT_HEALTH * UNIT_AMOUNT);
|
||||
BOOST_CHECK_EQUAL(health.getCount(), UNIT_AMOUNT);
|
||||
@ -181,15 +175,11 @@ BOOST_AUTO_TEST_CASE(resurrectOneBattle)
|
||||
BOOST_CHECK_EQUAL(health.getResurrected(), UNIT_AMOUNT);
|
||||
|
||||
health.takeResurrected();
|
||||
checkEmptyHealth(health, uhi);
|
||||
checkEmptyHealth(health, *this);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(resurrectPermanent)
|
||||
BOOST_FIXTURE_TEST_CASE(resurrectPermanent, CUnitHealthInfoMock)
|
||||
{
|
||||
CUnitHealthInfoMock uhi;
|
||||
CHealth health(&uhi);
|
||||
health.init();
|
||||
|
||||
checkNormalDamage(health, UNIT_HEALTH);
|
||||
BOOST_CHECK_EQUAL(health.getCount(), UNIT_AMOUNT - 1);
|
||||
BOOST_CHECK_EQUAL(health.getFirstHPleft(), UNIT_HEALTH);
|
||||
@ -208,13 +198,13 @@ BOOST_AUTO_TEST_CASE(resurrectPermanent)
|
||||
health.init();
|
||||
|
||||
checkNormalDamage(health, UNIT_HEALTH * UNIT_AMOUNT);
|
||||
checkEmptyHealth(health, uhi);
|
||||
checkEmptyHealth(health, *this);
|
||||
|
||||
checkHeal(health, EHealLevel::RESURRECT, EHealPower::PERMANENT, UNIT_HEALTH * UNIT_AMOUNT, UNIT_HEALTH * UNIT_AMOUNT);
|
||||
checkFullHealth(health, uhi);
|
||||
checkFullHealth(health, *this);
|
||||
|
||||
health.takeResurrected();
|
||||
checkFullHealth(health, uhi);
|
||||
checkFullHealth(health, *this);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_SUITE_END()
|
||||
|
Loading…
Reference in New Issue
Block a user