| //===- 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_EQ(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_EQ(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_EQ(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_EQ(1, pointer->one); |
| ASSERT_EQ(2, pointer->two); |
| ASSERT_EQ(3, pointer->three); |
| ASSERT_EQ(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_EQ(7, pointer->one); |
| ASSERT_EQ(7, pointer->two); |
| ASSERT_EQ(7, pointer->three); |
| ASSERT_EQ(7, pointer->four); |
| } |
| |
| TEST_F(RTLinearAllocatorTest, allocN_construct ) { |
| Data* pointer = m_pTestee->allocate(10); |
| m_pTestee->construct(pointer); |
| ASSERT_EQ(1, pointer->one); |
| ASSERT_EQ(2, pointer->two); |
| ASSERT_EQ(3, pointer->three); |
| ASSERT_EQ(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_EQ(7, pointer->one); |
| ASSERT_EQ(7, pointer->two); |
| ASSERT_EQ(7, pointer->three); |
| ASSERT_EQ(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; |
| } |
| **/ |
| } |
| |