main.cpp 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. #include <gtest/gtest.h>
  2. #include <entt/core/attribute.h>
  3. #include <entt/meta/factory.hpp>
  4. #include <entt/meta/meta.hpp>
  5. #include <entt/meta/resolve.hpp>
  6. #include "types.h"
  7. ENTT_API void set_up();
  8. ENTT_API void tear_down();
  9. ENTT_API entt::meta_any wrap_int(int);
  10. TEST(Lib, Meta) {
  11. using namespace entt::literals;
  12. ASSERT_FALSE(entt::resolve("position"_hs));
  13. ASSERT_FALSE(entt::resolve("velocity"_hs));
  14. set_up();
  15. entt::meta<double>().conv<int>();
  16. ASSERT_TRUE(entt::resolve("position"_hs));
  17. ASSERT_TRUE(entt::resolve("velocity"_hs));
  18. ASSERT_EQ(entt::resolve<position>(), entt::resolve("position"_hs));
  19. ASSERT_EQ(entt::resolve<velocity>(), entt::resolve("velocity"_hs));
  20. auto pos = entt::resolve("position"_hs).construct(42., 3.);
  21. auto vel = entt::resolve("velocity"_hs).ctor<>().invoke();
  22. ASSERT_TRUE(pos && vel);
  23. ASSERT_EQ(pos.type().data("x"_hs).type(), entt::resolve<int>());
  24. ASSERT_NE(pos.type().data("y"_hs).get(pos).try_cast<int>(), nullptr);
  25. ASSERT_EQ(pos.type().data("x"_hs).get(pos).cast<int>(), 42);
  26. ASSERT_EQ(pos.type().data("y"_hs).get(pos).cast<int>(), 3);
  27. ASSERT_EQ(vel.type().data("dx"_hs).type(), entt::resolve<double>());
  28. ASSERT_TRUE(vel.type().data("dy"_hs).get(vel).allow_cast<double>());
  29. ASSERT_EQ(vel.type().data("dx"_hs).get(vel).cast<double>(), 0.);
  30. ASSERT_EQ(vel.type().data("dy"_hs).get(vel).cast<double>(), 0.);
  31. ASSERT_EQ(wrap_int(42).type(), entt::resolve<int>());
  32. ASSERT_EQ(wrap_int(42).cast<int>(), 42);
  33. tear_down();
  34. ASSERT_FALSE(entt::resolve("position"_hs));
  35. ASSERT_FALSE(entt::resolve("velocity"_hs));
  36. }