Merge branch 'drop-cppunit-window-test'

Get rid of CppUnit compatibility macros in wxWindow unit tests.

See https://github.com/wxWidgets/wxWidgets/pull/1568
This commit is contained in:
Vadim Zeitlin
2019-09-28 17:46:08 +02:00

View File

@@ -28,98 +28,50 @@
#include "wx/cshelp.h" #include "wx/cshelp.h"
#include "wx/tooltip.h" #include "wx/tooltip.h"
class WindowTestCase : public CppUnit::TestCase class WindowTestCase
{ {
public: public:
WindowTestCase() { } WindowTestCase()
: m_window(new wxWindow(wxTheApp->GetTopWindow(), wxID_ANY))
{
}
void setUp() wxOVERRIDE; ~WindowTestCase()
void tearDown() wxOVERRIDE; {
wxTheApp->GetTopWindow()->DestroyChildren();
}
private: protected:
CPPUNIT_TEST_SUITE( WindowTestCase ); wxWindow* const m_window;
CPPUNIT_TEST( ShowHideEvent );
WXUISIM_TEST( KeyEvent );
CPPUNIT_TEST( FocusEvent );
CPPUNIT_TEST( Mouse );
CPPUNIT_TEST( Properties );
#if wxUSE_TOOLTIPS
CPPUNIT_TEST( ToolTip );
#endif // wxUSE_TOOLTIPS
CPPUNIT_TEST( Help );
CPPUNIT_TEST( Parent );
CPPUNIT_TEST( Siblings );
CPPUNIT_TEST( Children );
CPPUNIT_TEST( Focus );
CPPUNIT_TEST( Positioning );
CPPUNIT_TEST( PositioningBeyondShortLimit );
CPPUNIT_TEST( Show );
CPPUNIT_TEST( Enable );
CPPUNIT_TEST( FindWindowBy );
CPPUNIT_TEST_SUITE_END();
void ShowHideEvent();
void KeyEvent();
void FocusEvent();
void Mouse();
void Properties();
#if wxUSE_TOOLTIPS
void ToolTip();
#endif // wxUSE_TOOLTIPS
void Help();
void Parent();
void Siblings();
void Children();
void Focus();
void Positioning();
void PositioningBeyondShortLimit();
void Show();
void Enable();
void FindWindowBy();
wxWindow *m_window;
wxDECLARE_NO_COPY_CLASS(WindowTestCase); wxDECLARE_NO_COPY_CLASS(WindowTestCase);
}; };
// register in the unnamed registry so that these tests are run by default TEST_CASE_METHOD(WindowTestCase, "Window::ShowHideEvent", "[window]")
CPPUNIT_TEST_SUITE_REGISTRATION( WindowTestCase );
// also include in its own registry so that these tests can be run alone
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( WindowTestCase, "WindowTestCase" );
void WindowTestCase::setUp()
{
m_window = new wxWindow(wxTheApp->GetTopWindow(), wxID_ANY);
}
void WindowTestCase::tearDown()
{
wxTheApp->GetTopWindow()->DestroyChildren();
}
void WindowTestCase::ShowHideEvent()
{ {
#if defined(__WXMSW__) #if defined(__WXMSW__)
EventCounter show(m_window, wxEVT_SHOW); EventCounter show(m_window, wxEVT_SHOW);
CPPUNIT_ASSERT(m_window->IsShown()); CHECK(m_window->IsShown());
m_window->Show(false); m_window->Show(false);
CPPUNIT_ASSERT(!m_window->IsShown()); CHECK(!m_window->IsShown());
m_window->Show(); m_window->Show();
CPPUNIT_ASSERT(m_window->IsShown()); CHECK(m_window->IsShown());
CPPUNIT_ASSERT_EQUAL(2, show.GetCount()); CHECK( show.GetCount() == 2 );
#endif // __WXMSW__ #endif // __WXMSW__
} }
void WindowTestCase::KeyEvent() TEST_CASE_METHOD(WindowTestCase, "Window::KeyEvent", "[window]")
{ {
#if wxUSE_UIACTIONSIMULATOR #if wxUSE_UIACTIONSIMULATOR
if ( !EnableUITests() )
return;
EventCounter keydown(m_window, wxEVT_KEY_DOWN); EventCounter keydown(m_window, wxEVT_KEY_DOWN);
EventCounter keyup(m_window, wxEVT_KEY_UP); EventCounter keyup(m_window, wxEVT_KEY_UP);
EventCounter keychar(m_window, wxEVT_CHAR); EventCounter keychar(m_window, wxEVT_CHAR);
@@ -133,13 +85,13 @@ void WindowTestCase::KeyEvent()
sim.Char(WXK_SHIFT); sim.Char(WXK_SHIFT);
wxYield(); wxYield();
CPPUNIT_ASSERT_EQUAL(5, keydown.GetCount()); CHECK( keydown.GetCount() == 5 );
CPPUNIT_ASSERT_EQUAL(5, keyup.GetCount()); CHECK( keyup.GetCount() == 5 );
CPPUNIT_ASSERT_EQUAL(4, keychar.GetCount()); CHECK( keychar.GetCount() == 4 );
#endif #endif
} }
void WindowTestCase::FocusEvent() TEST_CASE_METHOD(WindowTestCase, "Window::FocusEvent", "[window]")
{ {
#ifndef __WXOSX__ #ifndef __WXOSX__
if ( IsAutomaticTest() ) if ( IsAutomaticTest() )
@@ -154,7 +106,7 @@ void WindowTestCase::FocusEvent()
m_window->SetFocus(); m_window->SetFocus();
CPPUNIT_ASSERT(setfocus.WaitEvent(500)); CHECK(setfocus.WaitEvent(500));
CHECK_FOCUS_IS( m_window ); CHECK_FOCUS_IS( m_window );
wxButton* button = new wxButton(wxTheApp->GetTopWindow(), wxID_ANY); wxButton* button = new wxButton(wxTheApp->GetTopWindow(), wxID_ANY);
@@ -162,140 +114,140 @@ void WindowTestCase::FocusEvent()
wxYield(); wxYield();
button->SetFocus(); button->SetFocus();
CPPUNIT_ASSERT_EQUAL(1, killfocus.GetCount()); CHECK( killfocus.GetCount() == 1 );
CPPUNIT_ASSERT(!m_window->HasFocus()); CHECK(!m_window->HasFocus());
#endif #endif
} }
void WindowTestCase::Mouse() TEST_CASE_METHOD(WindowTestCase, "Window::Mouse", "[window]")
{ {
wxCursor cursor(wxCURSOR_CHAR); wxCursor cursor(wxCURSOR_CHAR);
m_window->SetCursor(cursor); m_window->SetCursor(cursor);
CPPUNIT_ASSERT(m_window->GetCursor().IsOk()); CHECK(m_window->GetCursor().IsOk());
//A plain window doesn't have a caret //A plain window doesn't have a caret
CPPUNIT_ASSERT(!m_window->GetCaret()); CHECK(!m_window->GetCaret());
wxCaret* caret = new wxCaret(m_window, 16, 16); wxCaret* caret = new wxCaret(m_window, 16, 16);
m_window->SetCaret(caret); m_window->SetCaret(caret);
CPPUNIT_ASSERT(m_window->GetCaret()->IsOk()); CHECK(m_window->GetCaret()->IsOk());
m_window->CaptureMouse(); m_window->CaptureMouse();
CPPUNIT_ASSERT(m_window->HasCapture()); CHECK(m_window->HasCapture());
m_window->ReleaseMouse(); m_window->ReleaseMouse();
CPPUNIT_ASSERT(!m_window->HasCapture()); CHECK(!m_window->HasCapture());
} }
void WindowTestCase::Properties() TEST_CASE_METHOD(WindowTestCase, "Window::Properties", "[window]")
{ {
m_window->SetLabel("label"); m_window->SetLabel("label");
CPPUNIT_ASSERT_EQUAL("label", m_window->GetLabel()); CHECK( m_window->GetLabel() == "label" );
m_window->SetName("name"); m_window->SetName("name");
CPPUNIT_ASSERT_EQUAL("name", m_window->GetName()); CHECK( m_window->GetName() == "name" );
//As we used wxID_ANY we should have a negative id //As we used wxID_ANY we should have a negative id
CPPUNIT_ASSERT(m_window->GetId() < 0); CHECK(m_window->GetId() < 0);
m_window->SetId(wxID_HIGHEST + 10); m_window->SetId(wxID_HIGHEST + 10);
CPPUNIT_ASSERT_EQUAL(wxID_HIGHEST + 10, m_window->GetId()); CHECK( m_window->GetId() == wxID_HIGHEST + 10 );
} }
#if wxUSE_TOOLTIPS #if wxUSE_TOOLTIPS
void WindowTestCase::ToolTip() TEST_CASE_METHOD(WindowTestCase, "Window::ToolTip", "[window]")
{ {
CPPUNIT_ASSERT(!m_window->GetToolTip()); CHECK(!m_window->GetToolTip());
CPPUNIT_ASSERT_EQUAL("", m_window->GetToolTipText()); CHECK( m_window->GetToolTipText() == "" );
m_window->SetToolTip("text tip"); m_window->SetToolTip("text tip");
CPPUNIT_ASSERT_EQUAL("text tip", m_window->GetToolTipText()); CHECK( m_window->GetToolTipText() == "text tip" );
m_window->UnsetToolTip(); m_window->UnsetToolTip();
CPPUNIT_ASSERT(!m_window->GetToolTip()); CHECK(!m_window->GetToolTip());
CPPUNIT_ASSERT_EQUAL("", m_window->GetToolTipText()); CHECK( m_window->GetToolTipText() == "" );
wxToolTip* tip = new wxToolTip("other tip"); wxToolTip* tip = new wxToolTip("other tip");
m_window->SetToolTip(tip); m_window->SetToolTip(tip);
CPPUNIT_ASSERT_EQUAL(tip, m_window->GetToolTip()); CHECK( m_window->GetToolTip() == tip );
CPPUNIT_ASSERT_EQUAL("other tip", m_window->GetToolTipText()); CHECK( m_window->GetToolTipText() == "other tip" );
} }
#endif // wxUSE_TOOLTIPS #endif // wxUSE_TOOLTIPS
void WindowTestCase::Help() TEST_CASE_METHOD(WindowTestCase, "Window::Help", "[window]")
{ {
wxHelpProvider::Set(new wxSimpleHelpProvider()); wxHelpProvider::Set(new wxSimpleHelpProvider());
CPPUNIT_ASSERT_EQUAL("", m_window->GetHelpText()); CHECK( m_window->GetHelpText() == "" );
m_window->SetHelpText("helptext"); m_window->SetHelpText("helptext");
CPPUNIT_ASSERT_EQUAL("helptext", m_window->GetHelpText()); CHECK( m_window->GetHelpText() == "helptext" );
} }
void WindowTestCase::Parent() TEST_CASE_METHOD(WindowTestCase, "Window::Parent", "[window]")
{ {
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL), m_window->GetGrandParent()); CHECK( m_window->GetGrandParent() == static_cast<wxWindow*>(NULL) );
CPPUNIT_ASSERT_EQUAL(wxTheApp->GetTopWindow(), m_window->GetParent()); CHECK( m_window->GetParent() == wxTheApp->GetTopWindow() );
} }
void WindowTestCase::Siblings() TEST_CASE_METHOD(WindowTestCase, "Window::Siblings", "[window]")
{ {
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL), m_window->GetNextSibling()); CHECK( m_window->GetNextSibling() == static_cast<wxWindow*>(NULL) );
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL), m_window->GetPrevSibling()); CHECK( m_window->GetPrevSibling() == static_cast<wxWindow*>(NULL) );
wxWindow* newwin = new wxWindow(wxTheApp->GetTopWindow(), wxID_ANY); wxWindow* newwin = new wxWindow(wxTheApp->GetTopWindow(), wxID_ANY);
CPPUNIT_ASSERT_EQUAL(newwin, m_window->GetNextSibling()); CHECK( m_window->GetNextSibling() == newwin );
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL), m_window->GetPrevSibling()); CHECK( m_window->GetPrevSibling() == static_cast<wxWindow*>(NULL) );
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL), newwin->GetNextSibling()); CHECK( newwin->GetNextSibling() == static_cast<wxWindow*>(NULL) );
CPPUNIT_ASSERT_EQUAL(m_window, newwin->GetPrevSibling()); CHECK( newwin->GetPrevSibling() == m_window );
wxDELETE(newwin); wxDELETE(newwin);
} }
void WindowTestCase::Children() TEST_CASE_METHOD(WindowTestCase, "Window::Children", "[window]")
{ {
CPPUNIT_ASSERT_EQUAL(0, m_window->GetChildren().GetCount()); CHECK( m_window->GetChildren().GetCount() == 0 );
wxWindow* child1 = new wxWindow(m_window, wxID_ANY); wxWindow* child1 = new wxWindow(m_window, wxID_ANY);
CPPUNIT_ASSERT_EQUAL(1, m_window->GetChildren().GetCount()); CHECK( m_window->GetChildren().GetCount() == 1 );
m_window->RemoveChild(child1); m_window->RemoveChild(child1);
CPPUNIT_ASSERT_EQUAL(0, m_window->GetChildren().GetCount()); CHECK( m_window->GetChildren().GetCount() == 0 );
child1->SetId(wxID_HIGHEST + 1); child1->SetId(wxID_HIGHEST + 1);
child1->SetName("child1"); child1->SetName("child1");
m_window->AddChild(child1); m_window->AddChild(child1);
CPPUNIT_ASSERT_EQUAL(1, m_window->GetChildren().GetCount()); CHECK( m_window->GetChildren().GetCount() == 1 );
CPPUNIT_ASSERT_EQUAL(child1, m_window->FindWindow(wxID_HIGHEST + 1)); CHECK( m_window->FindWindow(wxID_HIGHEST + 1) == child1 );
CPPUNIT_ASSERT_EQUAL(child1, m_window->FindWindow("child1")); CHECK( m_window->FindWindow("child1") == child1 );
m_window->DestroyChildren(); m_window->DestroyChildren();
CPPUNIT_ASSERT_EQUAL(0, m_window->GetChildren().GetCount()); CHECK( m_window->GetChildren().GetCount() == 0 );
} }
void WindowTestCase::Focus() TEST_CASE_METHOD(WindowTestCase, "Window::Focus", "[window]")
{ {
#ifndef __WXOSX__ #ifndef __WXOSX__
CPPUNIT_ASSERT(!m_window->HasFocus()); CHECK(!m_window->HasFocus());
if ( m_window->AcceptsFocus() ) if ( m_window->AcceptsFocus() )
{ {
@@ -314,25 +266,23 @@ void WindowTestCase::Focus()
#endif #endif
} }
void WindowTestCase::Positioning() TEST_CASE_METHOD(WindowTestCase, "Window::Positioning", "[window]")
{ {
//Some basic tests for consistency //Some basic tests for consistency
int x, y; int x, y;
m_window->GetPosition(&x, &y); m_window->GetPosition(&x, &y);
CPPUNIT_ASSERT_EQUAL(x, m_window->GetPosition().x); CHECK( m_window->GetPosition().x == x );
CPPUNIT_ASSERT_EQUAL(y, m_window->GetPosition().y); CHECK( m_window->GetPosition().y == y );
CPPUNIT_ASSERT_EQUAL(m_window->GetPosition(), CHECK( m_window->GetRect().GetTopLeft() == m_window->GetPosition() );
m_window->GetRect().GetTopLeft());
m_window->GetScreenPosition(&x, &y); m_window->GetScreenPosition(&x, &y);
CPPUNIT_ASSERT_EQUAL(x, m_window->GetScreenPosition().x); CHECK( m_window->GetScreenPosition().x == x );
CPPUNIT_ASSERT_EQUAL(y, m_window->GetScreenPosition().y); CHECK( m_window->GetScreenPosition().y == y );
CPPUNIT_ASSERT_EQUAL(m_window->GetScreenPosition(), CHECK( m_window->GetScreenRect().GetTopLeft() == m_window->GetScreenPosition() );
m_window->GetScreenRect().GetTopLeft());
} }
void WindowTestCase::PositioningBeyondShortLimit() TEST_CASE_METHOD(WindowTestCase, "Window::PositioningBeyondShortLimit", "[window]")
{ {
#ifdef __WXMSW__ #ifdef __WXMSW__
//Positioning under MSW is limited to short relative coordinates //Positioning under MSW is limited to short relative coordinates
@@ -343,19 +293,19 @@ void WindowTestCase::PositioningBeyondShortLimit()
wxWindow* w = new wxWindow(m_window, wxID_ANY, wxWindow* w = new wxWindow(m_window, wxID_ANY,
wxPoint(0, SHRT_MAX + commonDim), wxPoint(0, SHRT_MAX + commonDim),
wxSize(commonDim, commonDim)); wxSize(commonDim, commonDim));
CPPUNIT_ASSERT_EQUAL(SHRT_MAX + commonDim, w->GetPosition().y); CHECK( w->GetPosition().y == SHRT_MAX + commonDim );
w->Move(0, 0); w->Move(0, 0);
// //
//Test window moving beyond SHRT_MAX //Test window moving beyond SHRT_MAX
w->Move(0, SHRT_MAX + commonDim); w->Move(0, SHRT_MAX + commonDim);
CPPUNIT_ASSERT_EQUAL(SHRT_MAX + commonDim, w->GetPosition().y); CHECK( w->GetPosition().y == SHRT_MAX + commonDim );
// //
//Test window moving below SHRT_MIN //Test window moving below SHRT_MIN
w->Move(0, SHRT_MIN - commonDim); w->Move(0, SHRT_MIN - commonDim);
CPPUNIT_ASSERT_EQUAL(SHRT_MIN - commonDim, w->GetPosition().y); CHECK( w->GetPosition().y == SHRT_MIN - commonDim );
// //
//Test deferred move beyond SHRT_MAX //Test deferred move beyond SHRT_MAX
@@ -369,66 +319,63 @@ void WindowTestCase::PositioningBeyondShortLimit()
sizer->Add(w); sizer->Add(w);
m_window->SetSizer(sizer); m_window->SetSizer(sizer);
m_window->Layout(); m_window->Layout();
CPPUNIT_ASSERT_EQUAL(SHRT_MAX + commonDim, w->GetPosition().y); CHECK( w->GetPosition().y == SHRT_MAX + commonDim );
#endif #endif
} }
void WindowTestCase::Show() TEST_CASE_METHOD(WindowTestCase, "Window::Show", "[window]")
{ {
CPPUNIT_ASSERT(m_window->IsShown()); CHECK(m_window->IsShown());
m_window->Hide(); m_window->Hide();
CPPUNIT_ASSERT(!m_window->IsShown()); CHECK(!m_window->IsShown());
m_window->Show(); m_window->Show();
CPPUNIT_ASSERT(m_window->IsShown()); CHECK(m_window->IsShown());
m_window->Show(false); m_window->Show(false);
CPPUNIT_ASSERT(!m_window->IsShown()); CHECK(!m_window->IsShown());
m_window->ShowWithEffect(wxSHOW_EFFECT_BLEND); m_window->ShowWithEffect(wxSHOW_EFFECT_BLEND);
CPPUNIT_ASSERT(m_window->IsShown()); CHECK(m_window->IsShown());
m_window->HideWithEffect(wxSHOW_EFFECT_BLEND); m_window->HideWithEffect(wxSHOW_EFFECT_BLEND);
CPPUNIT_ASSERT(!m_window->IsShown()); CHECK(!m_window->IsShown());
} }
void WindowTestCase::Enable() TEST_CASE_METHOD(WindowTestCase, "Window::Enable", "[window]")
{ {
CPPUNIT_ASSERT(m_window->IsEnabled()); CHECK(m_window->IsEnabled());
m_window->Disable(); m_window->Disable();
CPPUNIT_ASSERT(!m_window->IsEnabled()); CHECK(!m_window->IsEnabled());
m_window->Enable(); m_window->Enable();
CPPUNIT_ASSERT(m_window->IsEnabled()); CHECK(m_window->IsEnabled());
m_window->Enable(false); m_window->Enable(false);
CPPUNIT_ASSERT(!m_window->IsEnabled()); CHECK(!m_window->IsEnabled());
} }
void WindowTestCase::FindWindowBy() TEST_CASE_METHOD(WindowTestCase, "Window::FindWindowBy", "[window]")
{ {
m_window->SetId(wxID_HIGHEST + 1); m_window->SetId(wxID_HIGHEST + 1);
m_window->SetName("name"); m_window->SetName("name");
m_window->SetLabel("label"); m_window->SetLabel("label");
CPPUNIT_ASSERT_EQUAL(m_window, wxWindow::FindWindowById(wxID_HIGHEST + 1)); CHECK( wxWindow::FindWindowById(wxID_HIGHEST + 1) == m_window );
CPPUNIT_ASSERT_EQUAL(m_window, wxWindow::FindWindowByName("name")); CHECK( wxWindow::FindWindowByName("name") == m_window );
CPPUNIT_ASSERT_EQUAL(m_window, wxWindow::FindWindowByLabel("label")); CHECK( wxWindow::FindWindowByLabel("label") == m_window );
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL), CHECK( wxWindow::FindWindowById(wxID_HIGHEST + 3) == NULL );
wxWindow::FindWindowById(wxID_HIGHEST + 3)); CHECK( wxWindow::FindWindowByName("noname") == NULL );
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL), CHECK( wxWindow::FindWindowByLabel("nolabel") == NULL );
wxWindow::FindWindowByName("noname"));
CPPUNIT_ASSERT_EQUAL(static_cast<wxWindow*>(NULL),
wxWindow::FindWindowByLabel("nolabel"));
} }