| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- #include <gtest/gtest.h>
- #include <entt/entity/entity.hpp>
- #include <entt/entity/registry.hpp>
- #include "../common/custom_entity.h"
- struct custom_entity_traits {
- using value_type = test::custom_entity;
- using entity_type = std::uint32_t;
- using version_type = std::uint16_t;
- static constexpr entity_type entity_mask = 0x3FFFF; // 18b
- static constexpr entity_type version_mask = 0x3FFF; // 14b
- };
- template<>
- struct entt::entt_traits<test::custom_entity>: entt::basic_entt_traits<custom_entity_traits> {
- static constexpr std::size_t page_size = ENTT_SPARSE_PAGE;
- };
- template<typename Type>
- struct Entity: testing::Test {
- using type = Type;
- };
- using EntityTypes = ::testing::Types<entt::entity, test::custom_entity>;
- TYPED_TEST_SUITE(Entity, EntityTypes, );
- TYPED_TEST(Entity, Traits) {
- using entity_type = typename TestFixture::type;
- using traits_type = entt::entt_traits<entity_type>;
- constexpr entity_type tombstone = entt::tombstone;
- constexpr entity_type null = entt::null;
- entt::basic_registry<entity_type> registry{};
- registry.destroy(registry.create());
- const auto entity = registry.create();
- const auto other = registry.create();
- ASSERT_EQ(entt::to_integral(entity), entt::to_integral(entity));
- ASSERT_NE(entt::to_integral(entity), entt::to_integral<entity_type>(entt::null));
- ASSERT_NE(entt::to_integral(entity), entt::to_integral(entity_type{}));
- ASSERT_EQ(entt::to_entity(entity), 0u);
- ASSERT_EQ(entt::to_version(entity), 1u);
- ASSERT_EQ(entt::to_entity(other), 1u);
- ASSERT_EQ(entt::to_version(other), 0u);
- ASSERT_EQ(traits_type::construct(entt::to_entity(entity), entt::to_version(entity)), entity);
- ASSERT_EQ(traits_type::construct(entt::to_entity(other), entt::to_version(other)), other);
- ASSERT_NE(traits_type::construct(entt::to_entity(entity), {}), entity);
- ASSERT_EQ(traits_type::construct(entt::to_entity(other), entt::to_version(entity)), traits_type::combine(entt::to_integral(other), entt::to_integral(entity)));
- ASSERT_EQ(traits_type::combine(entt::tombstone, entt::null), tombstone);
- ASSERT_EQ(traits_type::combine(entt::null, entt::tombstone), null);
- ASSERT_EQ(traits_type::next(entity), traits_type::construct(entt::to_integral(entity), entt::to_version(entity) + 1u));
- ASSERT_EQ(traits_type::next(other), traits_type::construct(entt::to_integral(other), entt::to_version(other) + 1u));
- ASSERT_EQ(traits_type::next(entt::tombstone), traits_type::construct(entt::null, {}));
- ASSERT_EQ(traits_type::next(entt::null), traits_type::construct(entt::null, {}));
- }
- TYPED_TEST(Entity, Null) {
- using entity_type = typename TestFixture::type;
- using traits_type = entt::entt_traits<entity_type>;
- constexpr entity_type null = entt::null;
- ASSERT_FALSE(entity_type{} == entt::null);
- ASSERT_TRUE(entt::null == entt::null);
- ASSERT_FALSE(entt::null != entt::null);
- entt::basic_registry<entity_type> registry{};
- const auto entity = registry.create();
- ASSERT_EQ(traits_type::combine(entt::null, entt::to_integral(entity)), (traits_type::construct(entt::to_entity(null), entt::to_version(entity))));
- ASSERT_EQ(traits_type::combine(entt::null, entt::to_integral(null)), null);
- ASSERT_EQ(traits_type::combine(entt::null, entt::tombstone), null);
- registry.emplace<int>(entity, 42);
- ASSERT_FALSE(entity == entt::null);
- ASSERT_FALSE(entt::null == entity);
- ASSERT_TRUE(entity != entt::null);
- ASSERT_TRUE(entt::null != entity);
- const entity_type other = entt::null;
- ASSERT_FALSE(registry.valid(other));
- ASSERT_NE(registry.create(other), other);
- }
- TYPED_TEST(Entity, Tombstone) {
- using entity_type = typename TestFixture::type;
- using traits_type = entt::entt_traits<entity_type>;
- constexpr entity_type tombstone = entt::tombstone;
- ASSERT_FALSE(entity_type{} == entt::tombstone);
- ASSERT_TRUE(entt::tombstone == entt::tombstone);
- ASSERT_FALSE(entt::tombstone != entt::tombstone);
- entt::basic_registry<entity_type> registry{};
- const auto entity = registry.create();
- ASSERT_EQ(traits_type::combine(entt::to_integral(entity), entt::tombstone), (traits_type::construct(entt::to_entity(entity), entt::to_version(tombstone))));
- ASSERT_EQ(traits_type::combine(entt::tombstone, entt::to_integral(tombstone)), tombstone);
- ASSERT_EQ(traits_type::combine(entt::tombstone, entt::null), tombstone);
- registry.emplace<int>(entity, 42);
- ASSERT_FALSE(entity == entt::tombstone);
- ASSERT_FALSE(entt::tombstone == entity);
- ASSERT_TRUE(entity != entt::tombstone);
- ASSERT_TRUE(entt::tombstone != entity);
- constexpr auto vers = entt::to_version(tombstone);
- const auto other = traits_type::construct(entt::to_entity(entity), vers);
- ASSERT_FALSE(registry.valid(entt::tombstone));
- ASSERT_NE(registry.destroy(entity, vers), vers);
- ASSERT_NE(registry.create(other), other);
- }
|