allocVariant.cpp 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. // ArduinoJson - https://arduinojson.org
  2. // Copyright © 2014-2024, Benoit BLANCHON
  3. // MIT License
  4. #include <ArduinoJson/Memory/Alignment.hpp>
  5. #include <ArduinoJson/Memory/ResourceManager.hpp>
  6. #include <ArduinoJson/Memory/VariantPoolImpl.hpp>
  7. #include <catch.hpp>
  8. #include "Allocators.hpp"
  9. using namespace ArduinoJson::detail;
  10. TEST_CASE("ResourceManager::allocSlot()") {
  11. SECTION("Returns different pointer") {
  12. ResourceManager resources;
  13. VariantSlot* s1 = resources.allocSlot();
  14. REQUIRE(s1 != 0);
  15. VariantSlot* s2 = resources.allocSlot();
  16. REQUIRE(s2 != 0);
  17. REQUIRE(s1 != s2);
  18. }
  19. SECTION("Returns the same slot after calling freeSlot()") {
  20. ResourceManager resources;
  21. auto s1 = resources.allocSlot();
  22. auto s2 = resources.allocSlot();
  23. resources.freeSlot(s1);
  24. resources.freeSlot(s2);
  25. auto s3 = resources.allocSlot();
  26. auto s4 = resources.allocSlot();
  27. auto s5 = resources.allocSlot();
  28. REQUIRE(s2.id() != s1.id());
  29. REQUIRE(s3.id() == s2.id());
  30. REQUIRE(s4.id() == s1.id());
  31. REQUIRE(s5.id() != s1.id());
  32. REQUIRE(s5.id() != s2.id());
  33. }
  34. SECTION("Returns aligned pointers") {
  35. ResourceManager resources;
  36. REQUIRE(isAligned(resources.allocSlot().operator VariantSlot*()));
  37. REQUIRE(isAligned(resources.allocSlot().operator VariantSlot*()));
  38. }
  39. SECTION("Returns null if pool list allocation fails") {
  40. ResourceManager resources(FailingAllocator::instance());
  41. auto variant = resources.allocSlot();
  42. REQUIRE(variant.id() == NULL_SLOT);
  43. REQUIRE(static_cast<VariantSlot*>(variant) == nullptr);
  44. }
  45. SECTION("Returns null if pool allocation fails") {
  46. ResourceManager resources(FailingAllocator::instance());
  47. resources.allocSlot();
  48. auto variant = resources.allocSlot();
  49. REQUIRE(variant.id() == NULL_SLOT);
  50. REQUIRE(static_cast<VariantSlot*>(variant) == nullptr);
  51. }
  52. SECTION("Try overflow pool counter") {
  53. ResourceManager resources;
  54. // this test assumes SlotId is 8-bit; otherwise it consumes a lot of memory
  55. // tyhe GitHub Workflow gets killed
  56. REQUIRE(NULL_SLOT == 255);
  57. // fill all the pools
  58. for (SlotId i = 0; i < NULL_SLOT; i++) {
  59. auto slot = resources.allocSlot();
  60. REQUIRE(slot.id() == i); // or != NULL_SLOT
  61. REQUIRE(static_cast<VariantSlot*>(slot) != nullptr);
  62. }
  63. REQUIRE(resources.overflowed() == false);
  64. // now all allocations should fail
  65. for (int i = 0; i < 10; i++) {
  66. auto slot = resources.allocSlot();
  67. REQUIRE(slot.id() == NULL_SLOT);
  68. REQUIRE(static_cast<VariantSlot*>(slot) == nullptr);
  69. }
  70. REQUIRE(resources.overflowed() == true);
  71. }
  72. }