]> git.saurik.com Git - wxWidgets.git/blobdiff - tests/controls/headerctrltest.cpp
Merge in from trunk r68626 - r68683
[wxWidgets.git] / tests / controls / headerctrltest.cpp
index 079e5e506bd8c2e596e58ea426b9f76634561397..f906a016c73fd8d2b4041e3b83711b7d8a78b141 100644 (file)
 
 #ifndef WX_PRECOMP
     #include "wx/app.h"
-    #include "wx/headerctrl.h"
 #endif // WX_PRECOMP
 
+#include "wx/headerctrl.h"
+
 // ----------------------------------------------------------------------------
 // test class
 // ----------------------------------------------------------------------------
@@ -38,12 +39,14 @@ private:
     CPPUNIT_TEST_SUITE( HeaderCtrlTestCase );
         CPPUNIT_TEST( AddDelete );
         CPPUNIT_TEST( BestSize );
+        CPPUNIT_TEST( Reorder );
     CPPUNIT_TEST_SUITE_END();
 
     void AddDelete();
     void BestSize();
+    void Reorder();
 
-    wxHeaderCtrl *m_header;
+    wxHeaderCtrlSimple *m_header;
 
     DECLARE_NO_COPY_CLASS(HeaderCtrlTestCase)
 };
@@ -51,7 +54,7 @@ private:
 // register in the unnamed registry so that these tests are run by default
 CPPUNIT_TEST_SUITE_REGISTRATION( HeaderCtrlTestCase );
 
-// 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( HeaderCtrlTestCase, "HeaderCtrlTestCase" );
 
 // ----------------------------------------------------------------------------
@@ -60,7 +63,7 @@ CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( HeaderCtrlTestCase, "HeaderCtrlTestCase"
 
 void HeaderCtrlTestCase::setUp()
 {
-    m_header = new wxHeaderCtrl(wxTheApp->GetTopWindow());
+    m_header = new wxHeaderCtrlSimple(wxTheApp->GetTopWindow());
 }
 
 void HeaderCtrlTestCase::tearDown()
@@ -77,13 +80,13 @@ void HeaderCtrlTestCase::AddDelete()
 {
     CPPUNIT_ASSERT_EQUAL( 0, m_header->GetColumnCount() );
 
-    m_header->AppendColumn(wxHeaderCtrlColumn("Column 1"));
+    m_header->AppendColumn(wxHeaderColumnSimple("Column 1"));
     CPPUNIT_ASSERT_EQUAL( 1, m_header->GetColumnCount() );
 
-    m_header->AppendColumn(wxHeaderCtrlColumn("Column 2"));
+    m_header->AppendColumn(wxHeaderColumnSimple("Column 2"));
     CPPUNIT_ASSERT_EQUAL( 2, m_header->GetColumnCount() );
 
-    m_header->InsertColumn(wxHeaderCtrlColumn("Column 0"), 0);
+    m_header->InsertColumn(wxHeaderColumnSimple("Column 0"), 0);
     CPPUNIT_ASSERT_EQUAL( 3, m_header->GetColumnCount() );
 
     m_header->DeleteColumn(2);
@@ -93,12 +96,54 @@ void HeaderCtrlTestCase::AddDelete()
 void HeaderCtrlTestCase::BestSize()
 {
     const wxSize sizeEmpty = m_header->GetBestSize();
-    CPPUNIT_ASSERT( sizeEmpty.x > 0 );
+    // this fails under wxGTK where wxControl::GetBestSize() is 0 in horizontal
+    // direction
+    //CPPUNIT_ASSERT( sizeEmpty.x > 0 );
     CPPUNIT_ASSERT( sizeEmpty.y > 0 );
 
-    m_header->AppendColumn(wxHeaderCtrlColumn("Foo"));
-    m_header->AppendColumn(wxHeaderCtrlColumn("Bar"));
+    m_header->AppendColumn(wxHeaderColumnSimple("Foo"));
+    m_header->AppendColumn(wxHeaderColumnSimple("Bar"));
     const wxSize size = m_header->GetBestSize();
     CPPUNIT_ASSERT_EQUAL( sizeEmpty.y, size.y );
 }
 
+void HeaderCtrlTestCase::Reorder()
+{
+    static const int COL_COUNT = 4;
+
+    int n;
+
+    for ( n = 0; n < COL_COUNT; n++ )
+        m_header->AppendColumn(wxHeaderColumnSimple(wxString::Format("%d", n)));
+
+    wxArrayInt order = m_header->GetColumnsOrder(); // initial order: [0 1 2 3]
+    for ( n = 0; n < COL_COUNT; n++ )
+        CPPUNIT_ASSERT_EQUAL( n, order[n] );
+
+    wxHeaderCtrl::MoveColumnInOrderArray(order, 0, 2);
+    m_header->SetColumnsOrder(order);   // change order to [1 2 0 3]
+
+    order = m_header->GetColumnsOrder();
+    CPPUNIT_ASSERT_EQUAL( 1, order[0] );
+    CPPUNIT_ASSERT_EQUAL( 2, order[1] );
+    CPPUNIT_ASSERT_EQUAL( 0, order[2] );
+    CPPUNIT_ASSERT_EQUAL( 3, order[3] );
+
+    order[2] = 3;
+    order[3] = 0;
+    m_header->SetColumnsOrder(order);   // and now [1 2 3 0]
+    order = m_header->GetColumnsOrder();
+    CPPUNIT_ASSERT_EQUAL( 1, order[0] );
+    CPPUNIT_ASSERT_EQUAL( 2, order[1] );
+    CPPUNIT_ASSERT_EQUAL( 3, order[2] );
+    CPPUNIT_ASSERT_EQUAL( 0, order[3] );
+
+    wxHeaderCtrl::MoveColumnInOrderArray(order, 1, 3);
+    m_header->SetColumnsOrder(order);    // finally [2 3 0 1]
+    order = m_header->GetColumnsOrder();
+    CPPUNIT_ASSERT_EQUAL( 2, order[0] );
+    CPPUNIT_ASSERT_EQUAL( 3, order[1] );
+    CPPUNIT_ASSERT_EQUAL( 0, order[2] );
+    CPPUNIT_ASSERT_EQUAL( 1, order[3] );
+}
+