test_size_map.cpp 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. #include "catch.hpp"
  2. #include "size_map.h"
  3. #include "shm_manager.h"
  4. TEST_CASE("SizeMap, CalcAlignment")
  5. {
  6. for(size_t i = 0; i < CLASS_MAX_BYTES; ++i)
  7. {
  8. auto value = bg::detail::SizeMap::CalcAlignment(i);
  9. REQUIRE(value > 0);
  10. REQUIRE(value % 8 == 0);
  11. REQUIRE(value <= CALIGNMENT_MAX_BYTES);
  12. if(i > 0x7F && i < (CALIGNMENT_MAX_BYTES << 4))
  13. {
  14. REQUIRE(PALIGN_DOWN(i, value << 3) == value << 3);
  15. }
  16. }
  17. }
  18. TEST_CASE("SizeMap, Class Index to Page")
  19. {
  20. bg::detail::SizeMap sizemap;
  21. sizemap.Init();
  22. for(size_t bytes = 0; bytes < CLASS_MAX_BYTES; ++bytes)
  23. {
  24. size_t index;
  25. if(bytes <= BYTES_COMP_VALUE)
  26. {
  27. index = sizemap.m_index_to_class[SMALL_BYTES_TO_INDEX(bytes)];
  28. }
  29. else
  30. {
  31. auto temp1 = BIG_BYTES_TO_INDEX(bytes);
  32. index = sizemap.m_index_to_class[BIG_BYTES_TO_INDEX(bytes)];
  33. }
  34. REQUIRE(index < CLASS_MAX_COUNT);
  35. REQUIRE(sizemap.m_class_to_size[index] >= bytes);
  36. REQUIRE(sizemap.m_class_to_pages[index] * CALIGNMENT_MAX_BYTES >= bytes);
  37. REQUIRE(sizemap.m_class_to_pages[index] * CALIGNMENT_MAX_BYTES <= CLASS_MAX_BYTES);
  38. }
  39. }