mirror of
https://github.com/vcmi/vcmi.git
synced 2025-11-23 22:37:55 +02:00
Merge pull request #6244 from vcmi/test_fix
Try to fix tests not running on some presets
This commit is contained in:
@@ -462,19 +462,19 @@
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "windows-msvc-ninja-release",
|
||||
"configurePreset": "windows-msvc-ninja-release",
|
||||
"inherits": "default-release"
|
||||
"name": "windows-msvc-ninja-release",
|
||||
"configurePreset": "windows-msvc-ninja-release",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "windows-msvc-ninja-release-x86",
|
||||
"configurePreset": "windows-msvc-ninja-release-x86",
|
||||
"inherits": "default-release"
|
||||
"name": "windows-msvc-ninja-release-x86",
|
||||
"configurePreset": "windows-msvc-ninja-release-x86",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "windows-msvc-ninja-release-arm64",
|
||||
"configurePreset": "windows-msvc-ninja-release-arm64",
|
||||
"inherits": "default-release"
|
||||
"name": "windows-msvc-ninja-release-arm64",
|
||||
"configurePreset": "windows-msvc-ninja-release-arm64",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "ios-release-conan",
|
||||
@@ -518,9 +518,24 @@
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "linux-clang-release",
|
||||
"configurePreset": "linux-clang-release",
|
||||
"inherits": "default-release"
|
||||
"name": "linux-clang-debug",
|
||||
"configurePreset": "linux-clang-debug",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-clang-release",
|
||||
"configurePreset": "linux-clang-release",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-clang-test",
|
||||
"configurePreset": "linux-clang-test",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-gcc-debug",
|
||||
"configurePreset": "linux-gcc-debug",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-gcc-release",
|
||||
@@ -528,25 +543,10 @@
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-clang-debug",
|
||||
"configurePreset": "linux-clang-test",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-gcc-debug",
|
||||
"name": "linux-gcc-test",
|
||||
"configurePreset": "linux-gcc-test",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-gcc-test",
|
||||
"configurePreset": "linux-gcc-test",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "linux-clang-test",
|
||||
"configurePreset": "linux-clang-test",
|
||||
"inherits": "default-release"
|
||||
},
|
||||
{
|
||||
"name": "macos-xcode-release",
|
||||
"configurePreset": "macos-xcode-release",
|
||||
|
||||
@@ -189,6 +189,8 @@ TEST_F(BonusSystemTest, battlewidePropagationToAll)
|
||||
|
||||
EXPECT_TRUE(heroAine.hasBonusOfType(BonusType::BLOCK_ALL_MAGIC));
|
||||
EXPECT_TRUE(heroBron.hasBonusOfType(BonusType::BLOCK_ALL_MAGIC));
|
||||
|
||||
heroAine.detachFromSource(orb);
|
||||
}
|
||||
|
||||
TEST_F(BonusSystemTest, battlewidePropagationToEnemies)
|
||||
@@ -297,6 +299,8 @@ TEST_F(BonusSystemTest, legionPieces)
|
||||
|
||||
heroAine.detachFrom(townAndVisitor);
|
||||
EXPECT_EQ(town.valOfBonuses(BonusType::CREATURE_GROWTH, BonusCustomSubtype::creatureLevel(3)), 0);
|
||||
|
||||
heroAine.detachFromSource(legion);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -22,9 +22,11 @@ namespace test
|
||||
using namespace ::testing;
|
||||
using namespace ::events;
|
||||
|
||||
class ListenerMock
|
||||
class ApplyDamageListenerMock
|
||||
{
|
||||
public:
|
||||
virtual ~ApplyDamageListenerMock() = default;
|
||||
|
||||
MOCK_METHOD1(beforeEvent, void(ApplyDamage &));
|
||||
MOCK_METHOD1(afterEvent, void(const ApplyDamage &));
|
||||
};
|
||||
@@ -33,7 +35,7 @@ class ApplyDamageTest : public Test
|
||||
{
|
||||
public:
|
||||
EventBus eventBus;
|
||||
ListenerMock listener;
|
||||
ApplyDamageListenerMock listener;
|
||||
StrictMock<EnvironmentMock> environmentMock;
|
||||
|
||||
std::shared_ptr<StrictMock<UnitMock>> targetMock;
|
||||
@@ -47,8 +49,8 @@ protected:
|
||||
//this should be the only subscription test for events, just in case cross-binary subscription breaks
|
||||
TEST_F(ApplyDamageTest, Subscription)
|
||||
{
|
||||
auto subscription1 = eventBus.subscribeBefore<ApplyDamage>(std::bind(&ListenerMock::beforeEvent, &listener, _1));
|
||||
auto subscription2 = eventBus.subscribeAfter<ApplyDamage>(std::bind(&ListenerMock::afterEvent, &listener, _1));
|
||||
auto subscription1 = eventBus.subscribeBefore<ApplyDamage>(std::bind(&ApplyDamageListenerMock::beforeEvent, &listener, _1));
|
||||
auto subscription2 = eventBus.subscribeAfter<ApplyDamage>(std::bind(&ApplyDamageListenerMock::afterEvent, &listener, _1));
|
||||
|
||||
EXPECT_CALL(listener, beforeEvent(_)).Times(1);
|
||||
EXPECT_CALL(listener, afterEvent(_)).Times(1);
|
||||
|
||||
@@ -35,9 +35,11 @@ public:
|
||||
friend class SubscriptionRegistry<EventExample>;
|
||||
};
|
||||
|
||||
class ListenerMock
|
||||
class EventBusListenerMock
|
||||
{
|
||||
public:
|
||||
virtual ~EventBusListenerMock() = default;
|
||||
|
||||
MOCK_METHOD1(beforeEvent, void(EventExample &));
|
||||
MOCK_METHOD1(onEvent, void(EventExample &));
|
||||
MOCK_METHOD1(afterEvent, void(const EventExample &));
|
||||
@@ -51,9 +53,9 @@ public:
|
||||
EventBus subject1;
|
||||
EventBus subject2;
|
||||
|
||||
StrictMock<ListenerMock> listener;
|
||||
StrictMock<ListenerMock> listener1;
|
||||
StrictMock<ListenerMock> listener2;
|
||||
StrictMock<EventBusListenerMock> listener;
|
||||
StrictMock<EventBusListenerMock> listener1;
|
||||
StrictMock<EventBusListenerMock> listener2;
|
||||
};
|
||||
|
||||
TEST_F(EventBusTest, ExecuteNoListeners)
|
||||
@@ -67,15 +69,15 @@ TEST_F(EventBusTest, ExecuteNoListenersWithHandler)
|
||||
EXPECT_CALL(event1, isEnabled()).WillRepeatedly(Return(true));
|
||||
EXPECT_CALL(listener, onEvent(Ref(event1))).Times(1);
|
||||
|
||||
subject1.executeEvent(event1, std::bind(&ListenerMock::onEvent, &listener, _1));
|
||||
subject1.executeEvent(event1, std::bind(&EventBusListenerMock::onEvent, &listener, _1));
|
||||
}
|
||||
|
||||
TEST_F(EventBusTest, ExecuteIgnoredSubscription)
|
||||
{
|
||||
EXPECT_CALL(event1, isEnabled()).WillRepeatedly(Return(true));
|
||||
|
||||
subject1.subscribeBefore<EventExample>(std::bind(&ListenerMock::beforeEvent, &listener, _1));
|
||||
subject1.subscribeAfter<EventExample>(std::bind(&ListenerMock::afterEvent, &listener, _1));
|
||||
subject1.subscribeBefore<EventExample>(std::bind(&EventBusListenerMock::beforeEvent, &listener, _1));
|
||||
subject1.subscribeAfter<EventExample>(std::bind(&EventBusListenerMock::afterEvent, &listener, _1));
|
||||
|
||||
EXPECT_CALL(listener, beforeEvent(_)).Times(0);
|
||||
EXPECT_CALL(listener, afterEvent(_)).Times(0);
|
||||
@@ -87,10 +89,10 @@ TEST_F(EventBusTest, ExecuteSequence)
|
||||
{
|
||||
EXPECT_CALL(event1, isEnabled()).WillRepeatedly(Return(true));
|
||||
|
||||
auto subscription1 = subject1.subscribeBefore<EventExample>(std::bind(&ListenerMock::beforeEvent, &listener1, _1));
|
||||
auto subscription2 = subject1.subscribeAfter<EventExample>(std::bind(&ListenerMock::afterEvent, &listener1, _1));
|
||||
auto subscription3 = subject1.subscribeBefore<EventExample>(std::bind(&ListenerMock::beforeEvent, &listener2, _1));
|
||||
auto subscription4 = subject1.subscribeAfter<EventExample>(std::bind(&ListenerMock::afterEvent, &listener2, _1));
|
||||
auto subscription1 = subject1.subscribeBefore<EventExample>(std::bind(&EventBusListenerMock::beforeEvent, &listener1, _1));
|
||||
auto subscription2 = subject1.subscribeAfter<EventExample>(std::bind(&EventBusListenerMock::afterEvent, &listener1, _1));
|
||||
auto subscription3 = subject1.subscribeBefore<EventExample>(std::bind(&EventBusListenerMock::beforeEvent, &listener2, _1));
|
||||
auto subscription4 = subject1.subscribeAfter<EventExample>(std::bind(&EventBusListenerMock::afterEvent, &listener2, _1));
|
||||
|
||||
{
|
||||
InSequence sequence;
|
||||
@@ -101,17 +103,17 @@ TEST_F(EventBusTest, ExecuteSequence)
|
||||
EXPECT_CALL(listener2, afterEvent(Ref(event1))).Times(1);
|
||||
}
|
||||
|
||||
subject1.executeEvent(event1, std::bind(&ListenerMock::onEvent, &listener, _1));
|
||||
subject1.executeEvent(event1, std::bind(&EventBusListenerMock::onEvent, &listener, _1));
|
||||
}
|
||||
|
||||
TEST_F(EventBusTest, BusesAreIndependent)
|
||||
{
|
||||
EXPECT_CALL(event1, isEnabled()).WillRepeatedly(Return(true));
|
||||
|
||||
auto subscription1 = subject1.subscribeBefore<EventExample>(std::bind(&ListenerMock::beforeEvent, &listener1, _1));
|
||||
auto subscription2 = subject1.subscribeAfter<EventExample>(std::bind(&ListenerMock::afterEvent, &listener1, _1));
|
||||
auto subscription3 = subject2.subscribeBefore<EventExample>(std::bind(&ListenerMock::beforeEvent, &listener2, _1));
|
||||
auto subscription4 = subject2.subscribeAfter<EventExample>(std::bind(&ListenerMock::afterEvent, &listener2, _1));
|
||||
auto subscription1 = subject1.subscribeBefore<EventExample>(std::bind(&EventBusListenerMock::beforeEvent, &listener1, _1));
|
||||
auto subscription2 = subject1.subscribeAfter<EventExample>(std::bind(&EventBusListenerMock::afterEvent, &listener1, _1));
|
||||
auto subscription3 = subject2.subscribeBefore<EventExample>(std::bind(&EventBusListenerMock::beforeEvent, &listener2, _1));
|
||||
auto subscription4 = subject2.subscribeAfter<EventExample>(std::bind(&EventBusListenerMock::afterEvent, &listener2, _1));
|
||||
|
||||
EXPECT_CALL(listener1, beforeEvent(_)).Times(1);
|
||||
EXPECT_CALL(listener2, beforeEvent(_)).Times(0);
|
||||
@@ -125,7 +127,7 @@ TEST_F(EventBusTest, DisabledTestDontExecute)
|
||||
{
|
||||
EXPECT_CALL(event1, isEnabled()).Times(AtLeast(1)).WillRepeatedly(Return(false));
|
||||
EXPECT_CALL(listener, onEvent(Ref(event1))).Times(0);
|
||||
subject1.executeEvent(event1, std::bind(&ListenerMock::onEvent, &listener, _1));
|
||||
subject1.executeEvent(event1, std::bind(&EventBusListenerMock::onEvent, &listener, _1));
|
||||
}
|
||||
|
||||
TEST_F(EventBusTest, DisabledTestDontExecutePostHandler)
|
||||
@@ -134,10 +136,10 @@ TEST_F(EventBusTest, DisabledTestDontExecutePostHandler)
|
||||
EXPECT_CALL(listener, onEvent(Ref(event1))).WillRepeatedly(Return());
|
||||
EXPECT_CALL(listener1, afterEvent(Ref(event1))).Times(0);
|
||||
|
||||
auto subscription1 = subject1.subscribeAfter<EventExample>(std::bind(&ListenerMock::afterEvent, &listener1, _1));
|
||||
auto subscription1 = subject1.subscribeAfter<EventExample>(std::bind(&EventBusListenerMock::afterEvent, &listener1, _1));
|
||||
|
||||
|
||||
subject1.executeEvent(event1, std::bind(&ListenerMock::onEvent, &listener, _1));
|
||||
subject1.executeEvent(event1, std::bind(&EventBusListenerMock::onEvent, &listener, _1));
|
||||
}
|
||||
|
||||
TEST_F(EventBusTest, DisabledTestExecutePreHandler)
|
||||
@@ -146,9 +148,9 @@ TEST_F(EventBusTest, DisabledTestExecutePreHandler)
|
||||
EXPECT_CALL(listener, onEvent(Ref(event1))).WillRepeatedly(Return());
|
||||
EXPECT_CALL(listener1, beforeEvent(Ref(event1))).Times(1);
|
||||
|
||||
auto subscription1 = subject1.subscribeBefore<EventExample>(std::bind(&ListenerMock::beforeEvent, &listener1, _1));
|
||||
auto subscription1 = subject1.subscribeBefore<EventExample>(std::bind(&EventBusListenerMock::beforeEvent, &listener1, _1));
|
||||
|
||||
subject1.executeEvent(event1, std::bind(&ListenerMock::onEvent, &listener, _1));
|
||||
subject1.executeEvent(event1, std::bind(&EventBusListenerMock::onEvent, &listener, _1));
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user