queue_test.cpp 716 B

12345678910111213141516171819202122232425262728293031323334
  1. /*
  2. * Copyright 2010-2017 Branimir Karadzic. All rights reserved.
  3. * License: https://github.com/bkaradzic/bx#license-bsd-2-clause
  4. */
  5. #include "test.h"
  6. #include <bx/spscqueue.h>
  7. #include <bx/mpscqueue.h>
  8. void* bitsToPtr(uintptr_t _ui)
  9. {
  10. union { uintptr_t ui; void* ptr; } cast = { _ui };
  11. return cast.ptr;
  12. }
  13. uintptr_t ptrToBits(void* _ptr)
  14. {
  15. union { void* ptr; uintptr_t ui; } cast = { _ptr };
  16. return cast.ui;
  17. }
  18. TEST_CASE("SpSc", "")
  19. {
  20. bx::SpScUnboundedQueue queue;
  21. queue.push(bitsToPtr(0xdeadbeef) );
  22. REQUIRE(0xdeadbeef == ptrToBits(queue.pop() ) );
  23. }
  24. TEST_CASE("MpSc", "")
  25. {
  26. bx::MpScUnboundedQueueT<void> queue;
  27. queue.push(bitsToPtr(0xdeadbeef) );
  28. REQUIRE(0xdeadbeef == ptrToBits(queue.pop() ) );
  29. }