NouVeL/ADVect/ext/bgfx/bx/tests/queue_test.cpp
2022-08-18 12:17:43 -04:00

36 lines
805 B
C++

/*
* Copyright 2010-2022 Branimir Karadzic. All rights reserved.
* License: https://github.com/bkaradzic/bx/blob/master/LICENSE
*/
#include "test.h"
#include <bx/spscqueue.h>
#include <bx/mpscqueue.h>
void* bitsToPtr(uintptr_t _ui)
{
union { uintptr_t ui; void* ptr; } cast = { _ui };
return cast.ptr;
}
uintptr_t ptrToBits(void* _ptr)
{
union { void* ptr; uintptr_t ui; } cast = { _ptr };
return cast.ui;
}
TEST_CASE("SpSc", "")
{
bx::DefaultAllocator allocator;
bx::SpScUnboundedQueue queue(&allocator);
queue.push(bitsToPtr(0xdeadbeef) );
REQUIRE(0xdeadbeef == ptrToBits(queue.pop() ) );
}
TEST_CASE("MpSc", "")
{
bx::DefaultAllocator allocator;
bx::MpScUnboundedQueueT<void> queue(&allocator);
queue.push(bitsToPtr(0xdeadbeef) );
REQUIRE(0xdeadbeef == ptrToBits(queue.pop() ) );
}