X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/232fdc630c42eb165f7659981043e794be03b3b7..239e6af724de1df0cfc338a927417650d1d8b39b:/tests/controls/gridtest.cpp diff --git a/tests/controls/gridtest.cpp b/tests/controls/gridtest.cpp index fca5d58340..a871ad9e7a 100644 --- a/tests/controls/gridtest.cpp +++ b/tests/controls/gridtest.cpp @@ -95,7 +95,7 @@ private: // register in the unnamed registry so that these tests are run by default CPPUNIT_TEST_SUITE_REGISTRATION( GridTestCase ); -// 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( GridTestCase, "GridTestCase" ); //initialise the static variable @@ -126,12 +126,9 @@ void GridTestCase::tearDown() void GridTestCase::CellEdit() { #if wxUSE_UIACTIONSIMULATOR - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - - EventCounter count(m_grid, wxEVT_GRID_CELL_CHANGING); - EventCounter count1(m_grid, wxEVT_GRID_CELL_CHANGED); - EventCounter count2(m_grid, wxEVT_GRID_EDITOR_CREATED); + EventCounter changing(m_grid, wxEVT_GRID_CELL_CHANGING); + EventCounter changed(m_grid, wxEVT_GRID_CELL_CHANGED); + EventCounter created(m_grid, wxEVT_GRID_EDITOR_CREATED); wxUIActionSimulator sim; @@ -144,31 +141,28 @@ void GridTestCase::CellEdit() wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_EDITOR_CREATED)); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_CHANGING)); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_CHANGED)); + CPPUNIT_ASSERT_EQUAL(1, created.GetCount()); + CPPUNIT_ASSERT_EQUAL(1, changing.GetCount()); + CPPUNIT_ASSERT_EQUAL(1, changed.GetCount()); #endif } void GridTestCase::CellClick() { #if wxUSE_UIACTIONSIMULATOR - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - - EventCounter count(m_grid, wxEVT_GRID_CELL_LEFT_CLICK); - EventCounter count1(m_grid, wxEVT_GRID_CELL_LEFT_DCLICK); - EventCounter count2(m_grid, wxEVT_GRID_CELL_RIGHT_CLICK); - EventCounter count3(m_grid, wxEVT_GRID_CELL_RIGHT_DCLICK); + EventCounter lclick(m_grid, wxEVT_GRID_CELL_LEFT_CLICK); + EventCounter ldclick(m_grid, wxEVT_GRID_CELL_LEFT_DCLICK); + EventCounter rclick(m_grid, wxEVT_GRID_CELL_RIGHT_CLICK); + EventCounter rdclick(m_grid, wxEVT_GRID_CELL_RIGHT_DCLICK); wxUIActionSimulator sim; wxRect rect = m_grid->CellToRect(0, 0); wxPoint point = m_grid->CalcScrolledPosition(rect.GetPosition()); - point = frame->ClientToScreen(point + wxPoint(m_grid->GetRowLabelSize(), - m_grid->GetColLabelSize()) - + wxPoint(2, 2)); + point = m_grid->ClientToScreen(point + wxPoint(m_grid->GetRowLabelSize(), + m_grid->GetColLabelSize()) + + wxPoint(2, 2)); sim.MouseMove(point); wxYield(); @@ -176,44 +170,43 @@ void GridTestCase::CellClick() sim.MouseClick(); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_LEFT_CLICK)); + CPPUNIT_ASSERT_EQUAL(1, lclick.GetCount()); + lclick.Clear(); sim.MouseDblClick(); wxYield(); //A double click event sends a single click event first //test to ensure this still happens in the future - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_LEFT_CLICK)); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_LEFT_DCLICK)); + CPPUNIT_ASSERT_EQUAL(1, lclick.GetCount()); + CPPUNIT_ASSERT_EQUAL(1, ldclick.GetCount()); sim.MouseClick(wxMOUSE_BTN_RIGHT); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_RIGHT_CLICK)); + CPPUNIT_ASSERT_EQUAL(1, rclick.GetCount()); + rclick.Clear(); sim.MouseDblClick(wxMOUSE_BTN_RIGHT); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_RIGHT_CLICK)); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_CELL_RIGHT_DCLICK)); + CPPUNIT_ASSERT_EQUAL(1, rclick.GetCount()); + CPPUNIT_ASSERT_EQUAL(1, rdclick.GetCount()); #endif } void GridTestCase::CellSelect() { #if wxUSE_UIACTIONSIMULATOR - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - - EventCounter count(m_grid, wxEVT_GRID_SELECT_CELL); + EventCounter cell(m_grid, wxEVT_GRID_SELECT_CELL); wxUIActionSimulator sim; wxRect rect = m_grid->CellToRect(0, 0); wxPoint point = m_grid->CalcScrolledPosition(rect.GetPosition()); - point = frame->ClientToScreen(point + wxPoint(m_grid->GetRowLabelSize(), - m_grid->GetColLabelSize()) - + wxPoint(4, 4)); + point = m_grid->ClientToScreen(point + wxPoint(m_grid->GetRowLabelSize(), + m_grid->GetColLabelSize()) + + wxPoint(4, 4)); sim.MouseMove(point); wxYield(); @@ -221,7 +214,9 @@ void GridTestCase::CellSelect() sim.MouseClick(); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_SELECT_CELL)); + CPPUNIT_ASSERT_EQUAL(1, cell.GetCount()); + + cell.Clear(); m_grid->SetGridCursor(1, 1); m_grid->GoToCell(1, 0); @@ -232,20 +227,17 @@ void GridTestCase::CellSelect() sim.MouseDblClick(); wxYield(); - CPPUNIT_ASSERT_EQUAL(3, frame->GetEventCount(wxEVT_GRID_SELECT_CELL)); + CPPUNIT_ASSERT_EQUAL(3, cell.GetCount()); #endif } void GridTestCase::LabelClick() { -#if wxUSE_UIACTIONSIMULATOR && !defined(__WXGTK__) - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - - EventCounter count(m_grid, wxEVT_GRID_LABEL_LEFT_CLICK); - EventCounter count1(m_grid, wxEVT_GRID_LABEL_LEFT_DCLICK); - EventCounter count2(m_grid, wxEVT_GRID_LABEL_RIGHT_CLICK); - EventCounter count3(m_grid, wxEVT_GRID_LABEL_RIGHT_DCLICK); +#if wxUSE_UIACTIONSIMULATOR + EventCounter lclick(m_grid, wxEVT_GRID_LABEL_LEFT_CLICK); + EventCounter ldclick(m_grid, wxEVT_GRID_LABEL_LEFT_DCLICK); + EventCounter rclick(m_grid, wxEVT_GRID_LABEL_RIGHT_CLICK); + EventCounter rdclick(m_grid, wxEVT_GRID_LABEL_RIGHT_DCLICK); wxUIActionSimulator sim; @@ -258,20 +250,18 @@ void GridTestCase::LabelClick() sim.MouseClick(); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_LABEL_LEFT_CLICK)); + CPPUNIT_ASSERT_EQUAL(1, lclick.GetCount()); sim.MouseDblClick(); wxYield(); - //A double click event sends a single click event first - //test to ensure this still happens in the future - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_LABEL_LEFT_CLICK)); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_LABEL_LEFT_DCLICK)); + CPPUNIT_ASSERT_EQUAL(1, ldclick.GetCount()); sim.MouseClick(wxMOUSE_BTN_RIGHT); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_LABEL_RIGHT_CLICK)); + CPPUNIT_ASSERT_EQUAL(1, rclick.GetCount()); + rclick.Clear(); sim.MouseDblClick(wxMOUSE_BTN_RIGHT); wxYield(); @@ -280,25 +270,22 @@ void GridTestCase::LabelClick() { //Right double click not supported with native headers so we get two //right click events - CPPUNIT_ASSERT_EQUAL(2, frame->GetEventCount(wxEVT_GRID_LABEL_RIGHT_CLICK)); + CPPUNIT_ASSERT_EQUAL(2, rclick.GetCount()); } else { - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_LABEL_RIGHT_CLICK)); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_LABEL_RIGHT_DCLICK)); + CPPUNIT_ASSERT_EQUAL(1, rclick.GetCount()); + CPPUNIT_ASSERT_EQUAL(1, rdclick.GetCount()); } #endif } void GridTestCase::SortClick() { -#if wxUSE_UIACTIONSIMULATOR && !defined(__WXGTK__) +#if wxUSE_UIACTIONSIMULATOR m_grid->SetSortingColumn(0); - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - - EventCounter count(m_grid, wxEVT_GRID_COL_SORT); + EventCounter sort(m_grid, wxEVT_GRID_COL_SORT); wxUIActionSimulator sim; @@ -311,20 +298,15 @@ void GridTestCase::SortClick() sim.MouseClick(); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount()); - - m_grid->SetSortingColumn(wxNOT_FOUND); + CPPUNIT_ASSERT_EQUAL(1, sort.GetCount()); #endif } void GridTestCase::Size() { #if wxUSE_UIACTIONSIMULATOR && !defined(__WXGTK__) - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - - EventCounter count(m_grid, wxEVT_GRID_COL_SIZE); - EventCounter count1(m_grid, wxEVT_GRID_ROW_SIZE); + EventCounter colsize(m_grid, wxEVT_GRID_COL_SIZE); + EventCounter rowsize(m_grid, wxEVT_GRID_ROW_SIZE); wxUIActionSimulator sim; @@ -343,7 +325,7 @@ void GridTestCase::Size() sim.MouseUp(); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_COL_SIZE)); + CPPUNIT_ASSERT_EQUAL(1, colsize.GetCount()); pt = m_grid->ClientToScreen(wxPoint(5, m_grid->GetColLabelSize() + m_grid->GetRowSize(0))); @@ -351,17 +333,14 @@ void GridTestCase::Size() sim.MouseDragDrop(pt.x, pt.y, pt.x, pt.y + 50); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_ROW_SIZE)); + CPPUNIT_ASSERT_EQUAL(1, rowsize.GetCount()); #endif } void GridTestCase::RangeSelect() { #if wxUSE_UIACTIONSIMULATOR - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - - EventCounter count(m_grid, wxEVT_GRID_RANGE_SELECT); + EventCounter select(m_grid, wxEVT_GRID_RANGE_SELECT); wxUIActionSimulator sim; @@ -382,7 +361,7 @@ void GridTestCase::RangeSelect() sim.MouseUp(); wxYield(); - CPPUNIT_ASSERT_EQUAL(1, frame->GetEventCount(wxEVT_GRID_RANGE_SELECT)); + CPPUNIT_ASSERT_EQUAL(1, select.GetCount()); #endif } @@ -592,16 +571,9 @@ void GridTestCase::SelectionMode() m_grid->SetSelectionMode(wxGrid::wxGridSelectRows); m_grid->SelectBlock(3, 1, 3, 1); - wxGridCellCoordsArray topleft = m_grid->GetSelectionBlockTopLeft(); - wxGridCellCoordsArray bottomright = m_grid->GetSelectionBlockBottomRight(); - - CPPUNIT_ASSERT_EQUAL(1, topleft.Count()); - CPPUNIT_ASSERT_EQUAL(1, bottomright.Count()); - - CPPUNIT_ASSERT_EQUAL(0, topleft.Item(0).GetCol()); - CPPUNIT_ASSERT_EQUAL(3, topleft.Item(0).GetRow()); - CPPUNIT_ASSERT_EQUAL(1, bottomright.Item(0).GetCol()); - CPPUNIT_ASSERT_EQUAL(3, bottomright.Item(0).GetRow()); + wxArrayInt selectedRows = m_grid->GetSelectedRows(); + CPPUNIT_ASSERT_EQUAL(1, selectedRows.Count()); + CPPUNIT_ASSERT_EQUAL(3, selectedRows[0]); CPPUNIT_ASSERT_EQUAL(wxGrid::wxGridSelectRows, m_grid->GetSelectionMode()); @@ -612,16 +584,9 @@ void GridTestCase::SelectionMode() m_grid->SetSelectionMode(wxGrid::wxGridSelectColumns); m_grid->SelectBlock(3, 1, 3, 1); - topleft = m_grid->GetSelectionBlockTopLeft(); - bottomright = m_grid->GetSelectionBlockBottomRight(); - - CPPUNIT_ASSERT_EQUAL(1, topleft.Count()); - CPPUNIT_ASSERT_EQUAL(1, bottomright.Count()); - - CPPUNIT_ASSERT_EQUAL(1, topleft.Item(0).GetCol()); - CPPUNIT_ASSERT_EQUAL(0, topleft.Item(0).GetRow()); - CPPUNIT_ASSERT_EQUAL(1, bottomright.Item(0).GetCol()); - CPPUNIT_ASSERT_EQUAL(9, bottomright.Item(0).GetRow()); + wxArrayInt selectedCols = m_grid->GetSelectedCols(); + CPPUNIT_ASSERT_EQUAL(1, selectedCols.Count()); + CPPUNIT_ASSERT_EQUAL(1, selectedCols[0]); CPPUNIT_ASSERT_EQUAL(wxGrid::wxGridSelectColumns, m_grid->GetSelectionMode()); @@ -649,11 +614,13 @@ void GridTestCase::CellFormatting() CPPUNIT_ASSERT_EQUAL(back, m_grid->GetCellTextColour(0, 0)); +#if WXWIN_COMPATIBILITY_2_8 m_grid->SetCellAlignment(wxALIGN_CENTRE, 0, 0); m_grid->GetCellAlignment(0, 0, &cellhoriz, &cellvert); CPPUNIT_ASSERT_EQUAL(static_cast(wxALIGN_CENTRE), cellhoriz); CPPUNIT_ASSERT_EQUAL(static_cast(wxALIGN_CENTRE), cellvert); +#endif // WXWIN_COMPATIBILITY_2_8 m_grid->SetCellAlignment(0, 0, wxALIGN_LEFT, wxALIGN_BOTTOM); m_grid->GetCellAlignment(0, 0, &cellhoriz, &cellvert); @@ -661,23 +628,20 @@ void GridTestCase::CellFormatting() CPPUNIT_ASSERT_EQUAL(static_cast(wxALIGN_LEFT), cellhoriz); CPPUNIT_ASSERT_EQUAL(static_cast(wxALIGN_BOTTOM), cellvert); +#if WXWIN_COMPATIBILITY_2_8 m_grid->SetCellTextColour(*wxRED, 0, 0); - CPPUNIT_ASSERT_EQUAL(*wxRED, m_grid->GetCellTextColour(0, 0)); +#endif // WXWIN_COMPATIBILITY_2_8 m_grid->SetCellTextColour(0, 0, *wxGREEN); - CPPUNIT_ASSERT_EQUAL(*wxGREEN, m_grid->GetCellTextColour(0, 0)); } void GridTestCase::Editable() { #if wxUSE_UIACTIONSIMULATOR - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - //As the grid is not editable we shouldn't create an editor - EventCounter count(m_grid, wxEVT_GRID_EDITOR_CREATED); + EventCounter created(m_grid, wxEVT_GRID_EDITOR_CREATED); wxUIActionSimulator sim; @@ -697,18 +661,15 @@ void GridTestCase::Editable() sim.Char(WXK_RETURN); wxYield(); - CPPUNIT_ASSERT_EQUAL(0, frame->GetEventCount()); + CPPUNIT_ASSERT_EQUAL(0, created.GetCount()); #endif } void GridTestCase::ReadOnly() { #if wxUSE_UIACTIONSIMULATOR - wxTestableFrame* frame = wxStaticCast(wxTheApp->GetTopWindow(), - wxTestableFrame); - //As the cell is readonly we shouldn't create an editor - EventCounter count(m_grid, wxEVT_GRID_EDITOR_CREATED); + EventCounter created(m_grid, wxEVT_GRID_EDITOR_CREATED); wxUIActionSimulator sim; @@ -731,7 +692,7 @@ void GridTestCase::ReadOnly() sim.Char(WXK_RETURN); wxYield(); - CPPUNIT_ASSERT_EQUAL(0, frame->GetEventCount()); + CPPUNIT_ASSERT_EQUAL(0, created.GetCount()); #endif }