mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 09:35:28 +00:00
Merge branch 'fix_esm_loader' into 'master'
Fix logic expression for not found value in EsmLoader::getModel See merge request OpenMW/openmw!1308
This commit is contained in:
commit
ed811176bc
@ -52,6 +52,7 @@ if (GTEST_FOUND AND GMOCK_FOUND)
|
||||
sqlite3/transaction.cpp
|
||||
|
||||
esmloader/load.cpp
|
||||
esmloader/esmdata.cpp
|
||||
)
|
||||
|
||||
source_group(apps\\openmw_test_suite FILES openmw_test_suite.cpp ${UNITTEST_SRC_FILES})
|
||||
|
101
apps/openmw_test_suite/esmloader/esmdata.cpp
Normal file
101
apps/openmw_test_suite/esmloader/esmdata.cpp
Normal file
@ -0,0 +1,101 @@
|
||||
#include <components/esmloader/esmdata.cpp>
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
#include <array>
|
||||
#include <functional>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
namespace
|
||||
{
|
||||
using namespace testing;
|
||||
using namespace EsmLoader;
|
||||
|
||||
struct Params
|
||||
{
|
||||
std::string mRefId;
|
||||
ESM::RecNameInts mType;
|
||||
std::string mResult;
|
||||
std::function<void (EsmData&)> mPushBack;
|
||||
};
|
||||
|
||||
struct EsmLoaderGetModelTest : TestWithParam<Params> {};
|
||||
|
||||
TEST_P(EsmLoaderGetModelTest, shouldReturnFoundModelName)
|
||||
{
|
||||
EsmData data;
|
||||
GetParam().mPushBack(data);
|
||||
EXPECT_EQ(EsmLoader::getModel(data, GetParam().mRefId, GetParam().mType), GetParam().mResult);
|
||||
}
|
||||
|
||||
void pushBack(ESM::Activator&& value, EsmData& esmData)
|
||||
{
|
||||
esmData.mActivators.push_back(std::move(value));
|
||||
}
|
||||
|
||||
void pushBack(ESM::Container&& value, EsmData& esmData)
|
||||
{
|
||||
esmData.mContainers.push_back(std::move(value));
|
||||
}
|
||||
|
||||
void pushBack(ESM::Door&& value, EsmData& esmData)
|
||||
{
|
||||
esmData.mDoors.push_back(std::move(value));
|
||||
}
|
||||
|
||||
void pushBack(ESM::Static&& value, EsmData& esmData)
|
||||
{
|
||||
esmData.mStatics.push_back(std::move(value));
|
||||
}
|
||||
|
||||
template <class T>
|
||||
struct PushBack
|
||||
{
|
||||
std::string mId;
|
||||
std::string mModel;
|
||||
|
||||
void operator()(EsmData& esmData) const
|
||||
{
|
||||
T value;
|
||||
value.mId = mId;
|
||||
value.mModel = mModel;
|
||||
pushBack(std::move(value), esmData);
|
||||
}
|
||||
};
|
||||
|
||||
const std::array params = {
|
||||
Params {"acti_ref_id", ESM::REC_ACTI, "acti_model", PushBack<ESM::Activator> {"acti_ref_id", "acti_model"}},
|
||||
Params {"cont_ref_id", ESM::REC_CONT, "cont_model", PushBack<ESM::Container> {"cont_ref_id", "cont_model"}},
|
||||
Params {"door_ref_id", ESM::REC_DOOR, "door_model", PushBack<ESM::Door> {"door_ref_id", "door_model"}},
|
||||
Params {"static_ref_id", ESM::REC_STAT, "static_model", PushBack<ESM::Static> {"static_ref_id", "static_model"}},
|
||||
Params {"acti_ref_id_a", ESM::REC_ACTI, "", PushBack<ESM::Activator> {"acti_ref_id_z", "acti_model"}},
|
||||
Params {"cont_ref_id_a", ESM::REC_CONT, "", PushBack<ESM::Container> {"cont_ref_id_z", "cont_model"}},
|
||||
Params {"door_ref_id_a", ESM::REC_DOOR, "", PushBack<ESM::Door> {"door_ref_id_z", "door_model"}},
|
||||
Params {"static_ref_id_a", ESM::REC_STAT, "", PushBack<ESM::Static> {"static_ref_id_z", "static_model"}},
|
||||
Params {"acti_ref_id_z", ESM::REC_ACTI, "", PushBack<ESM::Activator> {"acti_ref_id_a", "acti_model"}},
|
||||
Params {"cont_ref_id_z", ESM::REC_CONT, "", PushBack<ESM::Container> {"cont_ref_id_a", "cont_model"}},
|
||||
Params {"door_ref_id_z", ESM::REC_DOOR, "", PushBack<ESM::Door> {"door_ref_id_a", "door_model"}},
|
||||
Params {"static_ref_id_z", ESM::REC_STAT, "", PushBack<ESM::Static> {"static_ref_id_a", "static_model"}},
|
||||
Params {"ref_id", ESM::REC_STAT, "", [] (EsmData&) {}},
|
||||
Params {"ref_id", ESM::REC_BOOK, "", [] (EsmData&) {}},
|
||||
};
|
||||
|
||||
INSTANTIATE_TEST_SUITE_P(Params, EsmLoaderGetModelTest, ValuesIn(params));
|
||||
|
||||
TEST(EsmLoaderGetGameSettingTest, shouldReturnFoundValue)
|
||||
{
|
||||
std::vector<ESM::GameSetting> settings;
|
||||
ESM::GameSetting setting;
|
||||
setting.mId = "setting";
|
||||
setting.mValue = ESM::Variant(42);
|
||||
settings.push_back(setting);
|
||||
EXPECT_EQ(EsmLoader::getGameSetting(settings, "setting"), ESM::Variant(42));
|
||||
}
|
||||
|
||||
TEST(EsmLoaderGetGameSettingTest, shouldThrowExceptionWhenNotFound)
|
||||
{
|
||||
const std::vector<ESM::GameSetting> settings;
|
||||
EXPECT_THROW(EsmLoader::getGameSetting(settings, "setting"), std::runtime_error);
|
||||
}
|
||||
}
|
@ -37,7 +37,7 @@ namespace EsmLoader
|
||||
{
|
||||
const auto it = std::lower_bound(values.begin(), values.end(), refId, LessById {});
|
||||
|
||||
if (it == values.end() && it->mId != refId)
|
||||
if (it == values.end() || it->mId != refId)
|
||||
return returnAs(std::forward<F>(f));
|
||||
|
||||
return std::forward<F>(f)(*it);
|
||||
|
Loading…
x
Reference in New Issue
Block a user