// register in the unnamed registry so that these tests are run by default
CPPUNIT_TEST_SUITE_REGISTRATION( ListBoxTestCase );
-// also include in it's own registry so that these tests can be run alone
+// also include in its own registry so that these tests can be run alone
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( ListBoxTestCase, "ListBoxTestCase" );
//initialise the static variable
void ListBoxTestCase::Sort()
{
-#ifndef(__WXOSX__)
+#ifndef __WXOSX__
wxDELETE(m_list);
m_list = new wxListBox(wxTheApp->GetTopWindow(), wxID_ANY,
wxDefaultPosition, wxDefaultSize, 0, 0,
CPPUNIT_ASSERT(!m_list->IsSelected(1));
CPPUNIT_ASSERT(m_list->IsSelected(2));
CPPUNIT_ASSERT(!m_list->IsSelected(3));
+
+ m_list->SetSelection(0);
+ m_list->SetSelection(wxNOT_FOUND);
+
+ m_list->GetSelections(selected);
+ CPPUNIT_ASSERT_EQUAL(0, selected.Count());
}
void ListBoxTestCase::ClickEvents()
m_list->Append(testitems);
+ // It is important to set a valid selection: if the control doesn't have
+ // any, clicking anywhere in it, even outside of any item, selects the
+ // first item in the control under GTK resulting in a selection changed
+ // event. This is not a wx bug, just the native platform behaviour so
+ // simply avoid it by starting with a valid selection.
+ m_list->SetSelection(0);
+
m_list->Update();
m_list->Refresh();
void ListBoxTestCase::HitTest()
{
-#if defined(__WXMSW__) || defined(__WXOSX__)
wxArrayString testitems;
testitems.Add("item 0");
testitems.Add("item 1");
m_list->Append(testitems);
- CPPUNIT_ASSERT(m_list->HitTest(wxPoint(10, 10)) != wxNOT_FOUND);
- CPPUNIT_ASSERT(m_list->HitTest(10, 10) != wxNOT_FOUND);
-
- CPPUNIT_ASSERT(m_list->HitTest(wxPoint(290, 190)) == wxNOT_FOUND);
- CPPUNIT_ASSERT(m_list->HitTest(290, 190) == wxNOT_FOUND);
+#ifdef __WXGTK__
+ // The control needs to be realized for HitTest() to work.
+ wxYield();
#endif
+
+ CPPUNIT_ASSERT_EQUAL( 0, m_list->HitTest(5, 5) );
+
+ CPPUNIT_ASSERT_EQUAL( wxNOT_FOUND, m_list->HitTest(290, 190) );
}
#endif //wxUSE_LISTBOX