Generate test cases for all ESM3 format versions since MaxStringRefIdFormatVersion

depth-refraction
elsid 2 years ago
parent 90ed24f4c9
commit d6c8c54dc5
No known key found for this signature in database
GPG Key ID: 4DE04C198CBA7625

@ -71,11 +71,16 @@ namespace ESM
{ {
using namespace ::testing; using namespace ::testing;
constexpr std::array formats = { std::vector<ESM::FormatVersion> getFormats()
MaxLimitedSizeStringsFormatVersion, {
MaxStringRefIdFormatVersion, std::vector<ESM::FormatVersion> result({
CurrentSaveGameFormatVersion, MaxLimitedSizeStringsFormatVersion,
}; MaxStringRefIdFormatVersion,
});
for (ESM::FormatVersion v = result.back() + 1; v <= ESM::CurrentSaveGameFormatVersion; ++v)
result.push_back(v);
return result;
}
constexpr std::uint32_t fakeRecordId = fourCC("FAKE"); constexpr std::uint32_t fakeRecordId = fourCC("FAKE");
@ -327,6 +332,6 @@ namespace ESM
EXPECT_EQ(result.mKeys, record.mKeys); EXPECT_EQ(result.mKeys, record.mKeys);
} }
INSTANTIATE_TEST_SUITE_P(FormatVersions, Esm3SaveLoadRecordTest, ValuesIn(formats)); INSTANTIATE_TEST_SUITE_P(FormatVersions, Esm3SaveLoadRecordTest, ValuesIn(getFormats()));
} }
} }

@ -269,22 +269,27 @@ std::unique_ptr<std::istream> getEsmFile(T record, bool deleted, ESM::FormatVers
namespace namespace
{ {
constexpr std::array formats = { std::vector<ESM::FormatVersion> getFormats()
ESM::DefaultFormatVersion, {
ESM::CurrentContentFormatVersion, std::vector<ESM::FormatVersion> result({
ESM::MaxOldWeatherFormatVersion, ESM::DefaultFormatVersion,
ESM::MaxOldDeathAnimationFormatVersion, ESM::CurrentContentFormatVersion,
ESM::MaxOldForOfWarFormatVersion, ESM::MaxOldWeatherFormatVersion,
ESM::MaxWerewolfDeprecatedDataFormatVersion, ESM::MaxOldDeathAnimationFormatVersion,
ESM::MaxOldTimeLeftFormatVersion, ESM::MaxOldForOfWarFormatVersion,
ESM::MaxIntFallbackFormatVersion, ESM::MaxWerewolfDeprecatedDataFormatVersion,
ESM::MaxClearModifiersFormatVersion, ESM::MaxOldTimeLeftFormatVersion,
ESM::MaxOldAiPackageFormatVersion, ESM::MaxIntFallbackFormatVersion,
ESM::MaxOldSkillsAndAttributesFormatVersion, ESM::MaxClearModifiersFormatVersion,
ESM::MaxOldCreatureStatsFormatVersion, ESM::MaxOldAiPackageFormatVersion,
ESM::MaxStringRefIdFormatVersion, ESM::MaxOldSkillsAndAttributesFormatVersion,
ESM::CurrentSaveGameFormatVersion, ESM::MaxOldCreatureStatsFormatVersion,
}; ESM::MaxStringRefIdFormatVersion,
});
for (ESM::FormatVersion v = result.back() + 1; v <= ESM::CurrentSaveGameFormatVersion; ++v)
result.push_back(v);
return result;
}
template <class T, class = std::void_t<>> template <class T, class = std::void_t<>>
struct HasBlankFunction : std::false_type struct HasBlankFunction : std::false_type
@ -305,7 +310,7 @@ TYPED_TEST_P(StoreTest, delete_test)
{ {
using RecordType = TypeParam; using RecordType = TypeParam;
for (const ESM::FormatVersion formatVersion : formats) for (const ESM::FormatVersion formatVersion : getFormats())
{ {
SCOPED_TRACE("FormatVersion: " + std::to_string(formatVersion)); SCOPED_TRACE("FormatVersion: " + std::to_string(formatVersion));
const ESM::RefId recordId = ESM::RefId::stringRefId("foobar"); const ESM::RefId recordId = ESM::RefId::stringRefId("foobar");
@ -383,7 +388,7 @@ TYPED_TEST_P(StoreTest, overwrite_test)
{ {
using RecordType = TypeParam; using RecordType = TypeParam;
for (const ESM::FormatVersion formatVersion : formats) for (const ESM::FormatVersion formatVersion : getFormats())
{ {
SCOPED_TRACE("FormatVersion: " + std::to_string(formatVersion)); SCOPED_TRACE("FormatVersion: " + std::to_string(formatVersion));
@ -442,7 +447,7 @@ namespace
else else
refId = ESM::StringRefId("foobar"); refId = ESM::StringRefId("foobar");
for (const ESM::FormatVersion formatVersion : formats) for (const ESM::FormatVersion formatVersion : getFormats())
{ {
SCOPED_TRACE("FormatVersion: " + std::to_string(formatVersion)); SCOPED_TRACE("FormatVersion: " + std::to_string(formatVersion));

Loading…
Cancel
Save