1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 09:35:28 +00:00

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

85 lines
3.5 KiB
C++
Raw Normal View History

2018-05-26 17:44:25 +03:00
#include <components/detournavigator/recastmeshobject.hpp>
2021-11-04 01:57:27 +01:00
#include <components/misc/convert.hpp>
2018-05-26 17:44:25 +03:00
#include <BulletCollision/CollisionShapes/btBoxShape.h>
#include <BulletCollision/CollisionShapes/btCompoundShape.h>
#include <gtest/gtest.h>
namespace
{
using namespace testing;
using namespace DetourNavigator;
struct DetourNavigatorRecastMeshObjectTest : Test
{
btBoxShape mBoxShapeImpl{ btVector3(1, 2, 3) };
2021-11-04 01:57:27 +01:00
const ObjectTransform mObjectTransform{ ESM::Position{ { 1, 2, 3 }, { 1, 2, 3 } }, 0.5f };
CollisionShape mBoxShape{ nullptr, mBoxShapeImpl, mObjectTransform };
btCompoundShape mCompoundShapeImpl{ true };
2021-11-04 01:57:27 +01:00
CollisionShape mCompoundShape{ nullptr, mCompoundShapeImpl, mObjectTransform };
btTransform mTransform{ Misc::Convert::makeBulletTransform(mObjectTransform.mPosition) };
2018-05-26 17:44:25 +03:00
DetourNavigatorRecastMeshObjectTest()
{
mCompoundShapeImpl.addChildShape(mTransform, std::addressof(mBoxShapeImpl));
2018-05-26 17:44:25 +03:00
}
};
TEST_F(DetourNavigatorRecastMeshObjectTest, constructed_object_should_have_shape_and_transform)
{
2018-07-18 22:09:50 +03:00
const RecastMeshObject object(mBoxShape, mTransform, AreaType_ground);
EXPECT_EQ(std::addressof(object.getShape()), std::addressof(mBoxShapeImpl));
2018-05-26 17:44:25 +03:00
EXPECT_EQ(object.getTransform(), mTransform);
}
TEST_F(DetourNavigatorRecastMeshObjectTest, update_with_same_transform_for_not_compound_shape_should_return_false)
{
2018-07-18 22:09:50 +03:00
RecastMeshObject object(mBoxShape, mTransform, AreaType_ground);
EXPECT_FALSE(object.update(mTransform, AreaType_ground));
2018-05-26 17:44:25 +03:00
}
TEST_F(DetourNavigatorRecastMeshObjectTest, update_with_different_transform_should_return_true)
{
2018-07-18 22:09:50 +03:00
RecastMeshObject object(mBoxShape, mTransform, AreaType_ground);
EXPECT_TRUE(object.update(btTransform::getIdentity(), AreaType_ground));
2018-07-12 11:44:11 +03:00
}
TEST_F(DetourNavigatorRecastMeshObjectTest, update_with_different_flags_should_return_true)
{
2018-07-18 22:09:50 +03:00
RecastMeshObject object(mBoxShape, mTransform, AreaType_ground);
EXPECT_TRUE(object.update(mTransform, AreaType_null));
2018-05-26 17:44:25 +03:00
}
TEST_F(DetourNavigatorRecastMeshObjectTest,
update_for_compound_shape_with_same_transform_and_not_changed_child_transform_should_return_false)
{
2018-07-18 22:09:50 +03:00
RecastMeshObject object(mCompoundShape, mTransform, AreaType_ground);
EXPECT_FALSE(object.update(mTransform, AreaType_ground));
2018-05-26 17:44:25 +03:00
}
TEST_F(DetourNavigatorRecastMeshObjectTest,
update_for_compound_shape_with_same_transform_and_changed_child_transform_should_return_true)
{
2018-07-18 22:09:50 +03:00
RecastMeshObject object(mCompoundShape, mTransform, AreaType_ground);
mCompoundShapeImpl.updateChildTransform(0, btTransform::getIdentity());
2018-07-18 22:09:50 +03:00
EXPECT_TRUE(object.update(mTransform, AreaType_ground));
2018-05-26 17:44:25 +03:00
}
TEST_F(DetourNavigatorRecastMeshObjectTest, repeated_update_for_compound_shape_without_changes_should_return_false)
{
2018-07-18 22:09:50 +03:00
RecastMeshObject object(mCompoundShape, mTransform, AreaType_ground);
mCompoundShapeImpl.updateChildTransform(0, btTransform::getIdentity());
2018-07-18 22:09:50 +03:00
object.update(mTransform, AreaType_ground);
EXPECT_FALSE(object.update(mTransform, AreaType_ground));
2018-05-26 17:44:25 +03:00
}
2019-03-03 15:51:02 +03:00
TEST_F(DetourNavigatorRecastMeshObjectTest, update_for_changed_local_scaling_should_return_true)
{
RecastMeshObject object(mBoxShape, mTransform, AreaType_ground);
mBoxShapeImpl.setLocalScaling(btVector3(2, 2, 2));
2019-03-03 15:51:02 +03:00
EXPECT_TRUE(object.update(mTransform, AreaType_ground));
}
2018-05-26 17:44:25 +03:00
}