80 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2010-2016 Branimir Karadzic. All rights reserved.
 | |
|  * License: https://github.com/bkaradzic/bx#license-bsd-2-clause
 | |
|  */
 | |
| 
 | |
| #include "test.h"
 | |
| #include <bx/handlealloc.h>
 | |
| 
 | |
| TEST(HandleListT)
 | |
| {
 | |
| 	bx::HandleListT<32> list;
 | |
| 
 | |
| 	list.pushBack(16);
 | |
| 	CHECK(list.getFront() == 16);
 | |
| 	CHECK(list.getBack()  == 16);
 | |
| 
 | |
| 	list.pushFront(7);
 | |
| 	CHECK(list.getFront() ==  7);
 | |
| 	CHECK(list.getBack()  == 16);
 | |
| 
 | |
| 	uint16_t expected0[] = { 15, 31, 7, 16, 17, 11, 13 };
 | |
| 	list.pushBack(17);
 | |
| 	list.pushBack(11);
 | |
| 	list.pushBack(13);
 | |
| 	list.pushFront(31);
 | |
| 	list.pushFront(15);
 | |
| 	uint16_t count = 0;
 | |
| 	for (uint16_t it = list.getFront(); it != UINT16_MAX; it = list.getNext(it), ++count)
 | |
| 	{
 | |
| 		CHECK(it == expected0[count]);
 | |
| 	}
 | |
| 	CHECK(count == BX_COUNTOF(expected0) );
 | |
| 
 | |
| 	list.remove(17);
 | |
| 	list.remove(31);
 | |
| 	list.remove(16);
 | |
| 	list.pushBack(16);
 | |
| 	uint16_t expected1[] = { 15, 7, 11, 13, 16 };
 | |
| 	count = 0;
 | |
| 	for (uint16_t it = list.getFront(); it != UINT16_MAX; it = list.getNext(it), ++count)
 | |
| 	{
 | |
| 		CHECK(it == expected1[count]);
 | |
| 	}
 | |
| 	CHECK(count == BX_COUNTOF(expected1) );
 | |
| 
 | |
| 	list.popBack();
 | |
| 	list.popFront();
 | |
| 	list.popBack();
 | |
| 	list.popBack();
 | |
| 
 | |
| 	CHECK(list.getFront() ==  7);
 | |
| 	CHECK(list.getBack()  ==  7);
 | |
| 
 | |
| 	list.popBack();
 | |
| 	CHECK(list.getFront() ==  UINT16_MAX);
 | |
| 	CHECK(list.getBack()  ==  UINT16_MAX);
 | |
| }
 | |
| 
 | |
| TEST(HandleAllocLruT)
 | |
| {
 | |
| 	bx::HandleAllocLruT<16> lru;
 | |
| 
 | |
| 	uint16_t handle[4] =
 | |
| 	{
 | |
| 		lru.alloc(),
 | |
| 		lru.alloc(),
 | |
| 		lru.alloc(),
 | |
| 		lru.alloc(),
 | |
| 	};
 | |
| 
 | |
| 	lru.touch(handle[1]);
 | |
| 
 | |
| 	uint16_t expected0[] = { handle[1], handle[3], handle[2], handle[0] };
 | |
| 	uint16_t count = 0;
 | |
| 	for (uint16_t it = lru.getFront(); it != UINT16_MAX; it = lru.getNext(it), ++count)
 | |
| 	{
 | |
| 		CHECK(it == expected0[count]);
 | |
| 	}
 | |
| }
 | 
