mirror of
https://github.com/eclipse-openvehicle-api/openvehicle-api.git
synced 2026-06-30 12:58:16 +00:00
115
tests/unit_tests/repository/repository_test.cpp
Normal file
115
tests/unit_tests/repository/repository_test.cpp
Normal file
@@ -0,0 +1,115 @@
|
||||
#include <gtest/gtest.h>
|
||||
#include <fstream>
|
||||
#include "mock.h"
|
||||
#include "generated/IComponent.h"
|
||||
#include <interfaces/repository.h>
|
||||
#include "../../../global/exec_dir_helper.h"
|
||||
|
||||
const uint32_t LoopCount = 100; //< amount of loops used for concurrency tests. more loops means more thorough deadlock check at the cost of increased runtime
|
||||
|
||||
// used to supply external objects for testing pruposes. Implements IObjectControl to make sure this is NOT called for externally supplied objects
|
||||
class TestExternalObject : public sdv::IInterfaceAccess, public sdv::IObjectControl
|
||||
{
|
||||
public:
|
||||
|
||||
BEGIN_SDV_INTERFACE_MAP()
|
||||
SDV_INTERFACE_ENTRY(sdv::IObjectControl)
|
||||
END_SDV_INTERFACE_MAP()
|
||||
|
||||
virtual void Initialize([[maybe_unused]] const sdv::u8string& ssObjectConfig)
|
||||
{
|
||||
FAIL() << "Error: Initialize should not be called by Repo Service!";
|
||||
//m_eObjectStatus = sdv::EObjectStatus::initialization_failure;
|
||||
}
|
||||
|
||||
virtual sdv::EObjectStatus GetStatus() const
|
||||
{
|
||||
return m_eObjectStatus;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Set the component operation mode. Overload of sdv::IObjectControl::SetOperationMode.
|
||||
* @param[in] eMode The operation mode, the component should run in.
|
||||
*/
|
||||
void SetOperationMode(sdv::EOperationMode eMode)
|
||||
{
|
||||
switch (eMode)
|
||||
{
|
||||
case sdv::EOperationMode::configuring:
|
||||
if (m_eObjectStatus == sdv::EObjectStatus::running || m_eObjectStatus == sdv::EObjectStatus::initialized)
|
||||
m_eObjectStatus = sdv::EObjectStatus::configuring;
|
||||
break;
|
||||
case sdv::EOperationMode::running:
|
||||
if (m_eObjectStatus == sdv::EObjectStatus::configuring || m_eObjectStatus == sdv::EObjectStatus::initialized)
|
||||
m_eObjectStatus = sdv::EObjectStatus::running;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
virtual void Shutdown()
|
||||
{
|
||||
m_eObjectStatus = sdv::EObjectStatus::shutdown_in_progress;
|
||||
FAIL() << "Error: Shutdown should not be called by Repo Service!";
|
||||
//m_eObjectStatus = sdv::EObjectStatus::destruction_pending;
|
||||
|
||||
}
|
||||
|
||||
sdv::EObjectStatus m_eObjectStatus = sdv::EObjectStatus::initialization_pending;
|
||||
};
|
||||
|
||||
TEST(RepositoryTest, LoadNonexistentModule)
|
||||
{
|
||||
CRepository repository; // Must be created first
|
||||
CModuleControl modulectrl;
|
||||
CHelper helper(modulectrl, repository);
|
||||
EXPECT_FALSE(modulectrl.Load((GetExecDirectory() / "TestFooBar.sdv").generic_u8string()));
|
||||
}
|
||||
|
||||
TEST(RepositoryTest, CreateNonexistentClass)
|
||||
{
|
||||
CRepository repository; // Must be created first
|
||||
CModuleControl modulectrl;
|
||||
CHelper helper(modulectrl, repository);
|
||||
ASSERT_TRUE(modulectrl.Load((GetExecDirectory() / "UnitTest_Repository_test_module.sdv").generic_u8string()));
|
||||
EXPECT_FALSE(repository.CreateObject2("TestFooBar", nullptr, nullptr));
|
||||
repository.DestroyObject2("TestFooBar");
|
||||
}
|
||||
|
||||
TEST(RepositoryTest, GetNonexistentObject)
|
||||
{
|
||||
CRepository repository; // Must be created first
|
||||
CModuleControl modulectrl;
|
||||
CHelper helper(modulectrl, repository);
|
||||
ASSERT_TRUE(modulectrl.Load((GetExecDirectory() / "UnitTest_Repository_test_module.sdv").generic_u8string()));
|
||||
bool bRes = repository.CreateObject2("Example_Object", nullptr, nullptr);
|
||||
EXPECT_TRUE(bRes);
|
||||
EXPECT_EQ(nullptr, repository.GetObject("TestFooBar"));
|
||||
repository.DestroyObject2("Example_Object");
|
||||
}
|
||||
|
||||
TEST(RepositoryTest, InstantiateAndGet)
|
||||
{
|
||||
CRepository repository; // Must be created first
|
||||
CModuleControl modulectrl;
|
||||
CHelper helper(modulectrl, repository);
|
||||
ASSERT_TRUE(modulectrl.Load((GetExecDirectory() / "UnitTest_Repository_test_module.sdv").generic_u8string()));
|
||||
bool bRes = repository.CreateObject2("Example_Object", nullptr, nullptr);
|
||||
EXPECT_TRUE(bRes);
|
||||
EXPECT_NE(nullptr, repository.GetObject("Example_Object"));
|
||||
repository.DestroyObject2("Example_Object");
|
||||
EXPECT_EQ(nullptr, repository.GetObject("Example_Object"));
|
||||
}
|
||||
|
||||
TEST(RepositoryTest, InstantiateInitFail)
|
||||
{
|
||||
CRepository repository; // Must be created first
|
||||
CModuleControl modulectrl;
|
||||
CHelper helper(modulectrl, repository);
|
||||
ASSERT_TRUE(modulectrl.Load((GetExecDirectory() / "UnitTest_Repository_test_module.sdv").generic_u8string()));
|
||||
bool bRes = repository.CreateObject2("TestObject_IObjectControlFail", nullptr, nullptr);
|
||||
EXPECT_FALSE(bRes);
|
||||
EXPECT_EQ(nullptr, repository.GetObject("TestObject_IObjectControlFail"));
|
||||
repository.DestroyObject2("TestObject_IObjectControlFail");
|
||||
}
|
||||
Reference in New Issue
Block a user