//===- RTLinearAllocatorTest.cpp ------------------------------------------===// // // The MCLinker Project // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "mcld/Support/Allocators.h" #include "RTLinearAllocatorTest.h" using namespace mcld; using namespace mcldtest; // Constructor can do set-up work for all test here. RTLinearAllocatorTest::RTLinearAllocatorTest() { // create testee. modify it if need m_pTestee = new LinearAllocator<Data, 0>(CHUNK_SIZE); } // Destructor can do clean-up work that doesn't throw exceptions here. RTLinearAllocatorTest::~RTLinearAllocatorTest() { delete m_pTestee; } // SetUp() will be called immediately before each test. void RTLinearAllocatorTest::SetUp() { } // TearDown() will be called immediately after each test. void RTLinearAllocatorTest::TearDown() { } //==========================================================================// // Testcases // TEST_F(RTLinearAllocatorTest, AllocateN) { Data* pointer = m_pTestee->allocate(10); ASSERT_FALSE(0 == pointer); ASSERT_TRUE(CHUNK_SIZE == m_pTestee->max_size()); ASSERT_FALSE(m_pTestee->empty()); } TEST_F(RTLinearAllocatorTest, allocate) { Data* pointer = m_pTestee->allocate(); ASSERT_FALSE(0 == pointer); ASSERT_TRUE(CHUNK_SIZE == m_pTestee->max_size()); ASSERT_FALSE(m_pTestee->empty()); } TEST_F(RTLinearAllocatorTest, allocateOver) { Data* pointer = m_pTestee->allocate(CHUNK_SIZE + 1); ASSERT_TRUE(0 == pointer); ASSERT_TRUE(0 == m_pTestee->max_size()); ASSERT_TRUE(m_pTestee->empty()); } TEST_F(RTLinearAllocatorTest, alloc_construct) { Data* pointer = m_pTestee->allocate(); m_pTestee->construct(pointer); ASSERT_TRUE(1 == pointer->one); ASSERT_TRUE(2 == pointer->two); ASSERT_TRUE(3 == pointer->three); ASSERT_TRUE(4 == pointer->four); } TEST_F(RTLinearAllocatorTest, alloc_constructCopy) { Data* pointer = m_pTestee->allocate(); Data data(7, 7, 7, 7); m_pTestee->construct(pointer, data); ASSERT_TRUE(7 == pointer->one); ASSERT_TRUE(7 == pointer->two); ASSERT_TRUE(7 == pointer->three); ASSERT_TRUE(7 == pointer->four); } TEST_F(RTLinearAllocatorTest, allocN_construct) { Data* pointer = m_pTestee->allocate(10); m_pTestee->construct(pointer); ASSERT_TRUE(1 == pointer->one); ASSERT_TRUE(2 == pointer->two); ASSERT_TRUE(3 == pointer->three); ASSERT_TRUE(4 == pointer->four); } TEST_F(RTLinearAllocatorTest, allocN_constructCopy) { Data* pointer = m_pTestee->allocate(10); Data data(7, 7, 7, 7); m_pTestee->construct(pointer, data); ASSERT_TRUE(7 == pointer->one); ASSERT_TRUE(7 == pointer->two); ASSERT_TRUE(7 == pointer->three); ASSERT_TRUE(7 == pointer->four); } TEST_F(RTLinearAllocatorTest, multi_alloc_ctor_iterate) { for (int i = 0; i < 101; ++i) { Data* pointer = m_pTestee->allocate(); m_pTestee->construct(pointer); pointer->one = i; } /** Alloc::iterator data, dEnd = m_pTestee->end(); int counter = 0; for (data=m_pTestee->begin(); data!=dEnd; ++data) { ASSERT_EQ(counter, (*data).one); ++counter; } **/ } TEST_F(RTLinearAllocatorTest, multi_allocN_ctor_iterate) { int counter = 0; for (int i = 0; i < 10000; ++i) { Data* pointer = m_pTestee->allocate(10); for (int j = 0; j < 10; ++j) { m_pTestee->construct(pointer); pointer->one = counter; ++pointer; ++counter; } } /** Alloc::iterator data, dEnd = m_pTestee->end(); counter = 0; for (data=m_pTestee->begin(); data!=dEnd; ++data) { ASSERT_EQ(counter, (*data).one); ++counter; } **/ }