mirror of
https://github.com/MadeOfJelly/MushMachine.git
synced 2025-01-09 22:53:14 +01:00
145 lines
3.5 KiB
C++
145 lines
3.5 KiB
C++
#include "mm/services/service.hpp"
|
|
#include <gtest/gtest.h>
|
|
#include <gmock/gmock.h>
|
|
|
|
#include <memory>
|
|
#include <mm/engine.hpp>
|
|
#include <mm/update_strategies/update_strategy.hpp>
|
|
|
|
#include <entt/core/hashed_string.hpp>
|
|
|
|
using ::testing::Return;
|
|
using ::testing::_;
|
|
|
|
using namespace entt::literals;
|
|
|
|
class MockUpdateStrategy : public MM::UpdateStrategies::UpdateStrategy {
|
|
public:
|
|
const char* name(void) override { return "MockUpdateStrategy"; }
|
|
|
|
MOCK_METHOD(
|
|
bool,
|
|
registerService,
|
|
(const entt::id_type s_id, std::vector<MM::UpdateStrategies::UpdateCreationInfo>&& info),
|
|
(override)
|
|
);
|
|
|
|
// protected:
|
|
MOCK_METHOD(void, doUpdate, (MM::Engine& engine), (override));
|
|
|
|
MOCK_METHOD(bool, enableService, (const entt::id_type s_id), (override));
|
|
MOCK_METHOD(bool, disableService, (const entt::id_type s_id), (override));
|
|
|
|
// public:
|
|
MOCK_METHOD(bool, enable, (const MM::UpdateStrategies::update_key_t key), (override));
|
|
MOCK_METHOD(bool, disable, (const MM::UpdateStrategies::update_key_t key), (override));
|
|
|
|
MOCK_METHOD(bool, depend, (const MM::UpdateStrategies::update_key_t A, const MM::UpdateStrategies::update_key_t B), (override));
|
|
|
|
MOCK_METHOD(void, addDefered, (std::function<void(MM::Engine&)> function), (override));
|
|
};
|
|
|
|
class MockService : public MM::Services::Service {
|
|
public:
|
|
const char* name(void) override { return "MockService"; }
|
|
|
|
MOCK_METHOD(bool, enable, (MM::Engine& engine), (override));
|
|
MOCK_METHOD(void, disable, (MM::Engine& engine), (override));
|
|
|
|
MOCK_METHOD(std::vector<MM::UpdateStrategies::UpdateCreationInfo>, registerUpdates, (), (override));
|
|
};
|
|
|
|
TEST(engine_mock, update_strategy_run) {
|
|
auto mock = std::make_unique<MockUpdateStrategy>();
|
|
|
|
EXPECT_CALL(*mock, doUpdate(_))
|
|
.Times(1);
|
|
|
|
MM::Engine engine(std::move(mock));
|
|
|
|
engine.update();
|
|
}
|
|
|
|
TEST(engine_mock, service_update_strategy) {
|
|
auto mock = std::make_unique<MockUpdateStrategy>();
|
|
|
|
EXPECT_CALL(*mock, registerService(_, _))
|
|
.Times(1);
|
|
EXPECT_CALL(*mock, enableService(_))
|
|
.Times(1);
|
|
EXPECT_CALL(*mock, disableService(_))
|
|
.Times(1);
|
|
|
|
class TmpMockService : public MockService {
|
|
public:
|
|
TmpMockService(void) {
|
|
EXPECT_CALL(*this, registerUpdates())
|
|
.Times(1);
|
|
|
|
EXPECT_CALL(*this, enable(_))
|
|
.Times(1);
|
|
ON_CALL(*this, enable(_))
|
|
.WillByDefault(Return(true));
|
|
|
|
EXPECT_CALL(*this, disable(_))
|
|
.Times(1);
|
|
}
|
|
};
|
|
|
|
{
|
|
MM::Engine engine(std::move(mock));
|
|
|
|
engine.addService<TmpMockService>();
|
|
|
|
ASSERT_TRUE(engine.enableService<TmpMockService>());
|
|
engine.disableService<TmpMockService>();
|
|
}
|
|
}
|
|
|
|
TEST(engine_mock, service_update_strategy_run_1) {
|
|
auto mock = std::make_unique<MockUpdateStrategy>();
|
|
|
|
EXPECT_CALL(*mock, registerService(_, _))
|
|
.Times(1);
|
|
EXPECT_CALL(*mock, enableService(_))
|
|
.Times(1);
|
|
EXPECT_CALL(*mock, disableService(_))
|
|
.Times(1);
|
|
|
|
class TmpMockService : public MockService {
|
|
public:
|
|
explicit TmpMockService(void) {
|
|
EXPECT_CALL(*this, registerUpdates())
|
|
.Times(1);
|
|
ON_CALL(*this, registerUpdates())
|
|
.WillByDefault([]() -> std::vector<MM::UpdateStrategies::UpdateCreationInfo> {
|
|
return {
|
|
{
|
|
"TmpMockService"_hs,
|
|
"TmpMockService",
|
|
[](MM::Engine&) {}
|
|
}
|
|
};
|
|
});
|
|
|
|
EXPECT_CALL(*this, enable(_))
|
|
.Times(1);
|
|
ON_CALL(*this, enable(_))
|
|
.WillByDefault(Return(true));
|
|
|
|
EXPECT_CALL(*this, disable(_))
|
|
.Times(1);
|
|
}
|
|
};
|
|
|
|
{
|
|
MM::Engine engine(std::move(mock));
|
|
|
|
engine.addService<TmpMockService>();
|
|
|
|
ASSERT_TRUE(engine.enableService<TmpMockService>());
|
|
engine.disableService<TmpMockService>();
|
|
}
|
|
}
|
|
|