Former-commit-id: a6c2075cfbfd0eccf2b77def71c0d42684bed590 [formerly 36ece2bc6a148bde6cacf45084821d20edcd115e] [formerly 4a6988792ec026e65be6850c46dfe8ddda92a885 [formerly fd3f4f975de5c427f3adc98b220446fd255be396]] Former-commit-id: c87fdc9483202842267c60eff3d619f0df2963bf [formerly ee35202f1b2df7ca20da5b6d8b13147f2b92c933] Former-commit-id: dad5de1b00bb4413f7aa191ca06b7d43b659f32a
34 lines
1.3 KiB
C++
34 lines
1.3 KiB
C++
#include <NDK/Systems/PhysicsSystem.hpp>
|
|
#include <NDK/World.hpp>
|
|
#include <NDK/Components/CollisionComponent.hpp>
|
|
#include <NDK/Components/NodeComponent.hpp>
|
|
#include <NDK/Components/PhysicsComponent.hpp>
|
|
#include <Catch/catch.hpp>
|
|
|
|
SCENARIO("PhysicsSystem", "[NDK][PHYSICSSYSTEM]")
|
|
{
|
|
GIVEN("A world and a static entity & a dynamic entity")
|
|
{
|
|
Ndk::World world;
|
|
const Ndk::EntityHandle& staticEntity = world.CreateEntity();
|
|
Ndk::CollisionComponent& collisionComponentStatic = staticEntity->AddComponent<Ndk::CollisionComponent>();
|
|
Ndk::NodeComponent& nodeComponentStatic = staticEntity->AddComponent<Ndk::NodeComponent>();
|
|
|
|
const Ndk::EntityHandle& dynamicEntity = world.CreateEntity();
|
|
Ndk::NodeComponent& nodeComponentDynamic = dynamicEntity->AddComponent<Ndk::NodeComponent>();
|
|
Ndk::PhysicsComponent& physicsComponentDynamic = dynamicEntity->AddComponent<Ndk::PhysicsComponent>();
|
|
|
|
WHEN("We make collide these two entities")
|
|
{
|
|
nodeComponentDynamic.SetPosition(-Nz::Vector3f::UnitZ());
|
|
physicsComponentDynamic.AddForce(Nz::Vector3f::UnitZ());
|
|
|
|
THEN("The dynamic entity should have hit the static one")
|
|
{
|
|
world.Update(1.f); // On origin
|
|
world.Update(1.f); // On origin due to collision
|
|
REQUIRE(nodeComponentStatic.GetPosition().SquaredDistance(nodeComponentDynamic.GetPosition()) < 0.2f);
|
|
}
|
|
}
|
|
}
|
|
} |