Use wxSelectionStore object instead of a pointer in the test
Just simplify the code, there is no need to allocate and free a pointer when we can just use an object. No real changes.
This commit is contained in:
@@ -22,18 +22,11 @@
|
|||||||
class SelStoreTestCase : public CppUnit::TestCase
|
class SelStoreTestCase : public CppUnit::TestCase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
SelStoreTestCase() { m_store = NULL; }
|
SelStoreTestCase() { }
|
||||||
|
|
||||||
virtual void setUp() wxOVERRIDE
|
virtual void setUp() wxOVERRIDE
|
||||||
{
|
{
|
||||||
m_store = new wxSelectionStore;
|
m_store.SetItemCount(NUM_ITEMS);
|
||||||
m_store->SetItemCount(NUM_ITEMS);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void tearDown() wxOVERRIDE
|
|
||||||
{
|
|
||||||
delete m_store;
|
|
||||||
m_store = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -56,7 +49,7 @@ private:
|
|||||||
// NB: must be even
|
// NB: must be even
|
||||||
static const unsigned NUM_ITEMS;
|
static const unsigned NUM_ITEMS;
|
||||||
|
|
||||||
wxSelectionStore *m_store;
|
wxSelectionStore m_store;
|
||||||
|
|
||||||
wxDECLARE_NO_COPY_CLASS(SelStoreTestCase);
|
wxDECLARE_NO_COPY_CLASS(SelStoreTestCase);
|
||||||
};
|
};
|
||||||
@@ -71,116 +64,116 @@ const unsigned SelStoreTestCase::NUM_ITEMS = 10; // NB: must be even
|
|||||||
|
|
||||||
void SelStoreTestCase::SelectItem()
|
void SelStoreTestCase::SelectItem()
|
||||||
{
|
{
|
||||||
m_store->SelectItem(0);
|
m_store.SelectItem(0);
|
||||||
CPPUNIT_ASSERT_EQUAL( 1u, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( 1u, m_store.GetSelectedCount() );
|
||||||
CPPUNIT_ASSERT( m_store->IsSelected(0) );
|
CPPUNIT_ASSERT( m_store.IsSelected(0) );
|
||||||
|
|
||||||
m_store->SelectItem(NUM_ITEMS - 1);
|
m_store.SelectItem(NUM_ITEMS - 1);
|
||||||
CPPUNIT_ASSERT_EQUAL( 2u, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( 2u, m_store.GetSelectedCount() );
|
||||||
CPPUNIT_ASSERT( m_store->IsSelected(NUM_ITEMS - 1) );
|
CPPUNIT_ASSERT( m_store.IsSelected(NUM_ITEMS - 1) );
|
||||||
|
|
||||||
m_store->SelectItem(0, false);
|
m_store.SelectItem(0, false);
|
||||||
CPPUNIT_ASSERT_EQUAL( 1u, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( 1u, m_store.GetSelectedCount() );
|
||||||
CPPUNIT_ASSERT( !m_store->IsSelected(0) );
|
CPPUNIT_ASSERT( !m_store.IsSelected(0) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelStoreTestCase::SelectRange()
|
void SelStoreTestCase::SelectRange()
|
||||||
{
|
{
|
||||||
m_store->SelectRange(0, NUM_ITEMS/2);
|
m_store.SelectRange(0, NUM_ITEMS/2);
|
||||||
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS/2 + 1, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS/2 + 1, m_store.GetSelectedCount() );
|
||||||
CPPUNIT_ASSERT( m_store->IsSelected(0) );
|
CPPUNIT_ASSERT( m_store.IsSelected(0) );
|
||||||
CPPUNIT_ASSERT( !m_store->IsSelected(NUM_ITEMS - 1) );
|
CPPUNIT_ASSERT( !m_store.IsSelected(NUM_ITEMS - 1) );
|
||||||
|
|
||||||
m_store->SelectRange(NUM_ITEMS/2, NUM_ITEMS - 1);
|
m_store.SelectRange(NUM_ITEMS/2, NUM_ITEMS - 1);
|
||||||
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS, m_store.GetSelectedCount() );
|
||||||
CPPUNIT_ASSERT( m_store->IsSelected(0) );
|
CPPUNIT_ASSERT( m_store.IsSelected(0) );
|
||||||
CPPUNIT_ASSERT( m_store->IsSelected(NUM_ITEMS - 1) );
|
CPPUNIT_ASSERT( m_store.IsSelected(NUM_ITEMS - 1) );
|
||||||
|
|
||||||
m_store->SelectRange(1, NUM_ITEMS - 2, false);
|
m_store.SelectRange(1, NUM_ITEMS - 2, false);
|
||||||
CPPUNIT_ASSERT_EQUAL( 2u, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( 2u, m_store.GetSelectedCount() );
|
||||||
CPPUNIT_ASSERT( m_store->IsSelected(0) );
|
CPPUNIT_ASSERT( m_store.IsSelected(0) );
|
||||||
CPPUNIT_ASSERT( !m_store->IsSelected(NUM_ITEMS/2) );
|
CPPUNIT_ASSERT( !m_store.IsSelected(NUM_ITEMS/2) );
|
||||||
CPPUNIT_ASSERT( m_store->IsSelected(NUM_ITEMS - 1) );
|
CPPUNIT_ASSERT( m_store.IsSelected(NUM_ITEMS - 1) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelStoreTestCase::SetItemCount()
|
void SelStoreTestCase::SetItemCount()
|
||||||
{
|
{
|
||||||
m_store->SelectRange(1, NUM_ITEMS - 2);
|
m_store.SelectRange(1, NUM_ITEMS - 2);
|
||||||
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS - 2, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS - 2, m_store.GetSelectedCount() );
|
||||||
|
|
||||||
m_store->SetItemCount(NUM_ITEMS/2);
|
m_store.SetItemCount(NUM_ITEMS/2);
|
||||||
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS/2 - 1, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( NUM_ITEMS/2 - 1, m_store.GetSelectedCount() );
|
||||||
|
|
||||||
|
|
||||||
m_store->Clear();
|
m_store.Clear();
|
||||||
m_store->SetItemCount(NUM_ITEMS);
|
m_store.SetItemCount(NUM_ITEMS);
|
||||||
|
|
||||||
|
|
||||||
m_store->SelectItem(NUM_ITEMS/2 - 1);
|
m_store.SelectItem(NUM_ITEMS/2 - 1);
|
||||||
m_store->SelectItem(NUM_ITEMS/2 + 1);
|
m_store.SelectItem(NUM_ITEMS/2 + 1);
|
||||||
m_store->SetItemCount(NUM_ITEMS/2);
|
m_store.SetItemCount(NUM_ITEMS/2);
|
||||||
CPPUNIT_ASSERT_EQUAL( 1u, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( 1u, m_store.GetSelectedCount() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelStoreTestCase::Clear()
|
void SelStoreTestCase::Clear()
|
||||||
{
|
{
|
||||||
CPPUNIT_ASSERT(m_store->IsEmpty());
|
CPPUNIT_ASSERT(m_store.IsEmpty());
|
||||||
CPPUNIT_ASSERT_EQUAL( 0u, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( 0u, m_store.GetSelectedCount() );
|
||||||
|
|
||||||
m_store->SelectItem(0);
|
m_store.SelectItem(0);
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!m_store->IsEmpty());
|
CPPUNIT_ASSERT(!m_store.IsEmpty());
|
||||||
|
|
||||||
m_store->Clear();
|
m_store.Clear();
|
||||||
|
|
||||||
CPPUNIT_ASSERT(m_store->IsEmpty());
|
CPPUNIT_ASSERT(m_store.IsEmpty());
|
||||||
CPPUNIT_ASSERT_EQUAL( 0u, m_store->GetSelectedCount() );
|
CPPUNIT_ASSERT_EQUAL( 0u, m_store.GetSelectedCount() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelStoreTestCase::Iterate()
|
void SelStoreTestCase::Iterate()
|
||||||
{
|
{
|
||||||
m_store->SelectRange(NUM_ITEMS/2 - 1, NUM_ITEMS/2 + 1);
|
m_store.SelectRange(NUM_ITEMS/2 - 1, NUM_ITEMS/2 + 1);
|
||||||
|
|
||||||
wxSelectionStore::IterationState cookie;
|
wxSelectionStore::IterationState cookie;
|
||||||
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2 - 1, m_store->GetFirstSelectedItem(cookie));
|
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2 - 1, m_store.GetFirstSelectedItem(cookie));
|
||||||
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2, m_store->GetNextSelectedItem(cookie));
|
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2, m_store.GetNextSelectedItem(cookie));
|
||||||
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2 + 1, m_store->GetNextSelectedItem(cookie));
|
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2 + 1, m_store.GetNextSelectedItem(cookie));
|
||||||
|
|
||||||
CPPUNIT_ASSERT_EQUAL(wxSelectionStore::NO_SELECTION, m_store->GetNextSelectedItem(cookie));
|
CPPUNIT_ASSERT_EQUAL(wxSelectionStore::NO_SELECTION, m_store.GetNextSelectedItem(cookie));
|
||||||
|
|
||||||
|
|
||||||
m_store->SelectRange(0, NUM_ITEMS - 1);
|
m_store.SelectRange(0, NUM_ITEMS - 1);
|
||||||
m_store->SelectItem(0, false);
|
m_store.SelectItem(0, false);
|
||||||
CPPUNIT_ASSERT_EQUAL(1, m_store->GetFirstSelectedItem(cookie));
|
CPPUNIT_ASSERT_EQUAL(1, m_store.GetFirstSelectedItem(cookie));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelStoreTestCase::ItemsAddDelete()
|
void SelStoreTestCase::ItemsAddDelete()
|
||||||
{
|
{
|
||||||
m_store->SelectItem(0);
|
m_store.SelectItem(0);
|
||||||
m_store->SelectItem(NUM_ITEMS/2);
|
m_store.SelectItem(NUM_ITEMS/2);
|
||||||
m_store->SelectItem(NUM_ITEMS - 1);
|
m_store.SelectItem(NUM_ITEMS - 1);
|
||||||
|
|
||||||
m_store->OnItemsInserted(NUM_ITEMS/2 + 1, 1);
|
m_store.OnItemsInserted(NUM_ITEMS/2 + 1, 1);
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(0));
|
CPPUNIT_ASSERT(m_store.IsSelected(0));
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(NUM_ITEMS/2));
|
CPPUNIT_ASSERT(m_store.IsSelected(NUM_ITEMS/2));
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(NUM_ITEMS));
|
CPPUNIT_ASSERT(m_store.IsSelected(NUM_ITEMS));
|
||||||
CPPUNIT_ASSERT_EQUAL(3, m_store->GetSelectedCount());
|
CPPUNIT_ASSERT_EQUAL(3, m_store.GetSelectedCount());
|
||||||
|
|
||||||
CPPUNIT_ASSERT(m_store->OnItemsDeleted(NUM_ITEMS/2 - 1, 2));
|
CPPUNIT_ASSERT(m_store.OnItemsDeleted(NUM_ITEMS/2 - 1, 2));
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(0));
|
CPPUNIT_ASSERT(m_store.IsSelected(0));
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(NUM_ITEMS - 2));
|
CPPUNIT_ASSERT(m_store.IsSelected(NUM_ITEMS - 2));
|
||||||
CPPUNIT_ASSERT_EQUAL(2, m_store->GetSelectedCount());
|
CPPUNIT_ASSERT_EQUAL(2, m_store.GetSelectedCount());
|
||||||
|
|
||||||
m_store->OnItemsInserted(0, 2);
|
m_store.OnItemsInserted(0, 2);
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(2));
|
CPPUNIT_ASSERT(m_store.IsSelected(2));
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(NUM_ITEMS));
|
CPPUNIT_ASSERT(m_store.IsSelected(NUM_ITEMS));
|
||||||
CPPUNIT_ASSERT_EQUAL(2, m_store->GetSelectedCount());
|
CPPUNIT_ASSERT_EQUAL(2, m_store.GetSelectedCount());
|
||||||
|
|
||||||
m_store->OnItemDelete(0);
|
m_store.OnItemDelete(0);
|
||||||
|
|
||||||
m_store->SelectRange(0, NUM_ITEMS - 1);
|
m_store.SelectRange(0, NUM_ITEMS - 1);
|
||||||
CPPUNIT_ASSERT(m_store->OnItemsDeleted(0, NUM_ITEMS/2));
|
CPPUNIT_ASSERT(m_store.OnItemsDeleted(0, NUM_ITEMS/2));
|
||||||
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2, m_store->GetSelectedCount());
|
CPPUNIT_ASSERT_EQUAL(NUM_ITEMS/2, m_store.GetSelectedCount());
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(0));
|
CPPUNIT_ASSERT(m_store.IsSelected(0));
|
||||||
CPPUNIT_ASSERT(m_store->IsSelected(NUM_ITEMS/2));
|
CPPUNIT_ASSERT(m_store.IsSelected(NUM_ITEMS/2));
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user