45 lines
1.1 KiB
C++
45 lines
1.1 KiB
C++
#include <Nazara/Core/MemoryPool.hpp>
|
|
#include <catch2/catch.hpp>
|
|
|
|
#include <Nazara/Math/Vector2.hpp>
|
|
|
|
SCENARIO("MemoryPool", "[CORE][MEMORYPOOL]")
|
|
{
|
|
GIVEN("A MemoryPool to contain one Nz::Vector2<int>")
|
|
{
|
|
Nz::MemoryPool memoryPool(sizeof(Nz::Vector2<int>), 1, false);
|
|
|
|
WHEN("We construct a Nz::Vector2<int>")
|
|
{
|
|
Nz::Vector2<int>* vector2 = memoryPool.New<Nz::Vector2<int>>(1, 2);
|
|
|
|
THEN("Memory is available")
|
|
{
|
|
vector2->x = 3;
|
|
REQUIRE(*vector2 == Nz::Vector2<int>(3, 2));
|
|
}
|
|
|
|
THEN("We can destroy the vector2")
|
|
{
|
|
memoryPool.Delete(vector2);
|
|
}
|
|
}
|
|
|
|
WHEN("We construct three vectors")
|
|
{
|
|
Nz::Vector2<int>* vector1 = memoryPool.New<Nz::Vector2<int>>(1, 2);
|
|
Nz::Vector2<int>* vector2 = memoryPool.New<Nz::Vector2<int>>(3, 4);
|
|
Nz::Vector2<int>* vector3 = memoryPool.New<Nz::Vector2<int>>(5, 6);
|
|
|
|
THEN("Memory is available")
|
|
{
|
|
vector1->x = 3;
|
|
vector2->y = 5;
|
|
CHECK(*vector1 == Nz::Vector2<int>(3, 2));
|
|
CHECK(*vector2 == Nz::Vector2<int>(3, 5));
|
|
CHECK(vector3->GetSquaredLength() == Approx(61.f));
|
|
}
|
|
}
|
|
}
|
|
}
|