mirror of
https://github.com/OpenMW/openmw.git
synced 2025-11-29 14:04:30 +00:00
192 lines
6.8 KiB
C++
192 lines
6.8 KiB
C++
#include <components/nif/physics.hpp>
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
namespace Nif
|
|
{
|
|
namespace
|
|
{
|
|
using namespace testing;
|
|
|
|
constexpr VFS::Path::NormalizedView path("test");
|
|
|
|
void writeUInt8(std::uint8_t value, std::ostream& stream)
|
|
{
|
|
stream.write(reinterpret_cast<const char*>(&value), sizeof(value));
|
|
}
|
|
|
|
void writeUInt16(std::uint16_t value, std::ostream& stream)
|
|
{
|
|
stream.write(reinterpret_cast<const char*>(&value), sizeof(value));
|
|
}
|
|
|
|
void writeUInt32(std::uint32_t value, std::ostream& stream)
|
|
{
|
|
stream.write(reinterpret_cast<const char*>(&value), sizeof(value));
|
|
}
|
|
|
|
void writeString(std::string_view value, std::ostream& stream)
|
|
{
|
|
stream.write(value.data(), value.size());
|
|
}
|
|
|
|
void writeUInt8SizedString(std::string_view value, std::ostream& stream)
|
|
{
|
|
writeUInt8(static_cast<std::uint8_t>(value.size() + 1), stream);
|
|
writeString(value, stream);
|
|
stream.put(0);
|
|
}
|
|
|
|
void writeUInt32SizedString(std::string_view value, std::ostream& stream)
|
|
{
|
|
writeUInt32(static_cast<std::uint32_t>(value.size() + 1), stream);
|
|
writeString(value, stream);
|
|
stream.put(0);
|
|
}
|
|
|
|
void writeFloat(float value, std::ostream& stream)
|
|
{
|
|
stream.write(reinterpret_cast<const char*>(&value), sizeof(value));
|
|
}
|
|
|
|
struct NifBhkRagdollTemplateTest : Test
|
|
{
|
|
NifBhkRagdollTemplateTest()
|
|
{
|
|
Nif::Reader::setLoadUnsupportedFiles(true);
|
|
Nif::Reader::setWriteNifDebugLog(true);
|
|
}
|
|
};
|
|
|
|
TEST_F(NifBhkRagdollTemplateTest, shouldParseRecord)
|
|
{
|
|
NIFFile file(path);
|
|
const ToUTF8::StatelessUtf8Encoder* const encoder = nullptr;
|
|
Reader reader(file, encoder);
|
|
|
|
std::ostringstream stream;
|
|
|
|
writeString("Gamebryo File Format, Version 20.2.0.7\n", stream);
|
|
writeUInt32(NIFStream::generateVersion(20, 2, 0, 7), stream);
|
|
|
|
constexpr std::uint8_t endianness = 1;
|
|
writeUInt8(endianness, stream);
|
|
|
|
constexpr std::uint32_t userVersion = 11;
|
|
writeUInt32(userVersion, stream);
|
|
|
|
constexpr std::uint32_t recordsCount = 2;
|
|
writeUInt32(recordsCount, stream);
|
|
|
|
constexpr std::uint32_t bsStreamVersion = 34;
|
|
writeUInt32(bsStreamVersion, stream);
|
|
|
|
writeUInt8SizedString("author", stream);
|
|
writeUInt8SizedString("process_script", stream);
|
|
writeUInt8SizedString("export_script", stream);
|
|
|
|
constexpr std::uint16_t recordTypesCount = 2;
|
|
writeUInt16(recordTypesCount, stream);
|
|
|
|
constexpr std::uint16_t bhkRagdollTemplateTypeIndex = 0;
|
|
writeUInt32SizedString("bhkRagdollTemplate", stream);
|
|
|
|
constexpr std::uint16_t bhkRagdollTemplateDataTypeIndex = 1;
|
|
writeUInt32SizedString("bhkRagdollTemplateData", stream);
|
|
|
|
writeUInt16(bhkRagdollTemplateTypeIndex, stream);
|
|
writeUInt16(bhkRagdollTemplateDataTypeIndex, stream);
|
|
|
|
for (std::uint32_t i = 0; i < recordsCount; ++i)
|
|
{
|
|
constexpr std::uint32_t recordSize = 0;
|
|
writeUInt32(recordSize, stream);
|
|
}
|
|
|
|
constexpr std::uint32_t stringsCount = 2;
|
|
writeUInt32(stringsCount, stream);
|
|
|
|
constexpr std::uint32_t maxStringSize = 0;
|
|
writeUInt32(maxStringSize, stream);
|
|
|
|
constexpr std::uint32_t bhkRagdollTemplateNameIndex = 0;
|
|
writeUInt32SizedString("bhkRagdollTemplateName", stream);
|
|
|
|
constexpr std::uint32_t bhkRagdollTemplateDataNameIndex = 1;
|
|
writeUInt32SizedString("bhkRagdollTemplateDataName", stream);
|
|
|
|
constexpr std::uint32_t groupsCount = 0;
|
|
writeUInt32(groupsCount, stream);
|
|
|
|
writeUInt32(bhkRagdollTemplateNameIndex, stream);
|
|
|
|
constexpr std::uint32_t bonesCount = 1;
|
|
writeUInt32(bonesCount, stream);
|
|
|
|
constexpr std::uint32_t bhkRagdollTemplateDataIndex = 1;
|
|
writeUInt32(bhkRagdollTemplateDataIndex, stream);
|
|
|
|
writeUInt32(bhkRagdollTemplateDataNameIndex, stream);
|
|
|
|
constexpr float mass = 1.1f;
|
|
writeFloat(mass, stream);
|
|
|
|
constexpr float restitution = 2.2f;
|
|
writeFloat(restitution, stream);
|
|
|
|
constexpr float friction = 3.3f;
|
|
writeFloat(friction, stream);
|
|
|
|
constexpr float radius = 4.4f;
|
|
writeFloat(radius, stream);
|
|
|
|
constexpr std::uint32_t havokMaterial = 42;
|
|
writeUInt32(havokMaterial, stream);
|
|
|
|
constexpr std::uint32_t constraintsCount = 0;
|
|
writeUInt32(constraintsCount, stream);
|
|
|
|
constexpr std::uint32_t rootsCount = 0;
|
|
writeUInt32(rootsCount, stream);
|
|
|
|
const std::string buffer = stream.str();
|
|
|
|
std::unique_ptr<std::istringstream> input = std::make_unique<std::istringstream>(buffer);
|
|
input->exceptions(std::ios::failbit | std::ios_base::badbit);
|
|
|
|
reader.parse(std::move(input));
|
|
|
|
{
|
|
const Record* const record = reader.getRecord(0);
|
|
ASSERT_NE(record, nullptr);
|
|
EXPECT_EQ(record->recIndex, 0);
|
|
EXPECT_EQ(record->recName, "bhkRagdollTemplate");
|
|
EXPECT_EQ(record->recType, RC_bhkRagdollTemplate);
|
|
|
|
const bhkRagdollTemplate* const typed = dynamic_cast<const bhkRagdollTemplate*>(record);
|
|
ASSERT_NE(typed, nullptr);
|
|
EXPECT_EQ(typed->mName, "bhkRagdollTemplateName");
|
|
EXPECT_EQ(typed->mBones.size(), 1);
|
|
EXPECT_NE(typed->mBones[0].getPtr(), nullptr);
|
|
}
|
|
|
|
{
|
|
const Record* const record = reader.getRecord(1);
|
|
ASSERT_NE(record, nullptr);
|
|
EXPECT_EQ(record->recIndex, 1);
|
|
EXPECT_EQ(record->recName, "bhkRagdollTemplateData");
|
|
EXPECT_EQ(record->recType, RC_bhkRagdollTemplateData);
|
|
|
|
const bhkRagdollTemplateData* const typed = dynamic_cast<const bhkRagdollTemplateData*>(record);
|
|
ASSERT_NE(typed, nullptr);
|
|
EXPECT_EQ(typed->mName, "bhkRagdollTemplateDataName");
|
|
EXPECT_EQ(typed->mMass, mass);
|
|
EXPECT_EQ(typed->mRestitution, restitution);
|
|
EXPECT_EQ(typed->mFriction, friction);
|
|
EXPECT_EQ(typed->mRadius, radius);
|
|
EXPECT_EQ(typed->mHavokMaterial.mMaterial, havokMaterial);
|
|
EXPECT_EQ(typed->mConstraints.size(), 0);
|
|
}
|
|
}
|
|
}
|
|
}
|