2008-09-22 12:03:45 -04:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: tests/misc/misctests.cpp
|
|
|
|
// Purpose: test miscellaneous GUI functions
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Created: 2008-09-22
|
|
|
|
// Copyright: (c) 2008 Vadim Zeitlin
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// headers
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#include "testprec.h"
|
|
|
|
|
|
|
|
|
2012-03-03 19:29:17 -05:00
|
|
|
#include "wx/defs.h"
|
|
|
|
|
2008-09-22 13:33:41 -04:00
|
|
|
#ifndef WX_PRECOMP
|
|
|
|
#include "wx/gdicmn.h"
|
2011-04-23 10:53:38 -04:00
|
|
|
#include "wx/filefn.h"
|
2008-09-22 13:33:41 -04:00
|
|
|
#endif // !PCH
|
|
|
|
|
2012-03-03 19:29:17 -05:00
|
|
|
#include "wx/app.h"
|
|
|
|
#include "wx/button.h"
|
2009-08-30 13:25:42 -04:00
|
|
|
#include "wx/clipbrd.h"
|
|
|
|
#include "wx/dataobj.h"
|
2012-10-03 03:58:56 -04:00
|
|
|
#include "wx/panel.h"
|
2008-09-22 12:03:45 -04:00
|
|
|
|
2012-10-02 20:16:30 -04:00
|
|
|
#include "asserthelper.h"
|
|
|
|
|
2008-09-22 12:03:45 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// test class
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class MiscGUIFuncsTestCase : public CppUnit::TestCase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
MiscGUIFuncsTestCase() { }
|
|
|
|
|
|
|
|
private:
|
|
|
|
CPPUNIT_TEST_SUITE( MiscGUIFuncsTestCase );
|
|
|
|
CPPUNIT_TEST( DisplaySize );
|
2009-08-30 13:25:42 -04:00
|
|
|
CPPUNIT_TEST( URLDataObject );
|
2011-04-23 10:53:38 -04:00
|
|
|
CPPUNIT_TEST( ParseFileDialogFilter );
|
2012-10-02 20:16:30 -04:00
|
|
|
CPPUNIT_TEST( ClientToScreen );
|
2012-03-03 19:29:17 -05:00
|
|
|
CPPUNIT_TEST( FindWindowAtPoint );
|
2008-09-22 12:03:45 -04:00
|
|
|
CPPUNIT_TEST_SUITE_END();
|
|
|
|
|
|
|
|
void DisplaySize();
|
2009-08-30 13:25:42 -04:00
|
|
|
void URLDataObject();
|
2011-04-23 10:53:38 -04:00
|
|
|
void ParseFileDialogFilter();
|
2012-10-02 20:16:30 -04:00
|
|
|
void ClientToScreen();
|
2012-03-03 19:29:17 -05:00
|
|
|
void FindWindowAtPoint();
|
2008-09-22 12:03:45 -04:00
|
|
|
|
2015-04-23 07:49:01 -04:00
|
|
|
wxDECLARE_NO_COPY_CLASS(MiscGUIFuncsTestCase);
|
2008-09-22 12:03:45 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
// register in the unnamed registry so that these tests are run by default
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION( MiscGUIFuncsTestCase );
|
|
|
|
|
2011-04-30 06:57:04 -04:00
|
|
|
// also include in its own registry so that these tests can be run alone
|
2008-09-22 12:03:45 -04:00
|
|
|
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( MiscGUIFuncsTestCase, "MiscGUIFuncsTestCase" );
|
|
|
|
|
|
|
|
void MiscGUIFuncsTestCase::DisplaySize()
|
|
|
|
{
|
|
|
|
// test that different (almost) overloads return the same results
|
|
|
|
int w, h;
|
|
|
|
wxDisplaySize(&w, &h);
|
|
|
|
wxSize sz = wxGetDisplaySize();
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL( w, sz.x );
|
|
|
|
CPPUNIT_ASSERT_EQUAL( h, sz.y );
|
|
|
|
|
|
|
|
// test that passing NULL works as expected, e.g. doesn't crash
|
|
|
|
wxDisplaySize(NULL, NULL);
|
|
|
|
wxDisplaySize(&w, NULL);
|
|
|
|
wxDisplaySize(NULL, &h);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL( w, sz.x );
|
|
|
|
CPPUNIT_ASSERT_EQUAL( h, sz.y );
|
|
|
|
|
|
|
|
// test that display PPI is something reasonable
|
|
|
|
sz = wxGetDisplayPPI();
|
Replace CppUnit with Catch for unit tests
Drop the legacy CppUnit testing framework used for the unit tests.
Replacing it with Catch has the advantage of not requiring CppUnit
libraries to be installed on the system in order to be able to run
tests (Catch is header-only and a copy of it is now included in the
main repository itself) and, in the future, of being able to write
the tests in a much more natural way.
For now, however, avoid changing the existing tests code as much as
[reasonably] possible to avoid introducing bugs in them and provide
the CppUnit compatibility macros in the new wx/catch_cppunit.h header
which allow to preserve the 99% of the existing code unchanged. Some
of the required changes are:
- Decompose asserts using "a && b" conditions into multiple asserts
checking "a" and "b" independently. This would have been better
even with CppUnit (to know which part of condition exactly failed)
and is required with Catch.
- Use extra parentheses around such conditions when they can't be
easily decomposed in the arrays test, due to the use of macros.
This is not ideal from the point of view of messages given when
the tests fail but will do for now.
- Rewrite asserts using "a || b" as a combination of condition
checks and assert macros. Again, this is better anyhow, and is
required with Catch. Incidentally, this allowed to fix a bug in
the "exec" unit test which didn't leave enough time for the new
process to be launched before trying to kill it.
- Remove multiple CPPUNIT_TEST_SUITE_NAMED_REGISTRATION() macros,
our emulation of this macro can be used only once.
- Provide string conversions using Catch-specific StringMaker for
a couple of types.
- Replace custom wxImage comparison with a Catch-specific matcher
class.
- Remove most of test running logic from test.cpp, in particular don't
parse command line ourselves any longer but use Catch built-in
command line parser. This is a source of a minor regression:
previously, both "Foo" and "FooTestCase" could be used as the name of
the test to run, but now only the latter is accepted.
2017-11-01 14:15:24 -04:00
|
|
|
CPPUNIT_ASSERT( sz.x < 1000 );
|
|
|
|
CPPUNIT_ASSERT( sz.y < 1000 );
|
2008-09-22 12:03:45 -04:00
|
|
|
}
|
|
|
|
|
2009-08-30 13:25:42 -04:00
|
|
|
void MiscGUIFuncsTestCase::URLDataObject()
|
|
|
|
{
|
2018-09-18 13:14:12 -04:00
|
|
|
#if wxUSE_DATAOBJ
|
2009-08-30 13:25:42 -04:00
|
|
|
// this tests for buffer overflow, see #11102
|
|
|
|
const char * const
|
|
|
|
url = "http://something.long.to.overwrite.plenty.memory.example.com";
|
|
|
|
wxURLDataObject * const dobj = new wxURLDataObject(url);
|
|
|
|
CPPUNIT_ASSERT_EQUAL( url, dobj->GetURL() );
|
|
|
|
|
|
|
|
wxClipboardLocker lockClip;
|
|
|
|
CPPUNIT_ASSERT( wxTheClipboard->SetData(dobj) );
|
|
|
|
wxTheClipboard->Flush();
|
2018-09-18 13:14:12 -04:00
|
|
|
#endif // wxUSE_DATAOBJ
|
2009-08-30 13:25:42 -04:00
|
|
|
}
|
|
|
|
|
2011-04-23 10:53:38 -04:00
|
|
|
void MiscGUIFuncsTestCase::ParseFileDialogFilter()
|
|
|
|
{
|
|
|
|
wxArrayString descs,
|
|
|
|
filters;
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL
|
|
|
|
(
|
|
|
|
1,
|
|
|
|
wxParseCommonDialogsFilter("Image files|*.jpg;*.png", descs, filters)
|
|
|
|
);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL( "Image files", descs[0] );
|
|
|
|
CPPUNIT_ASSERT_EQUAL( "*.jpg;*.png", filters[0] );
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL
|
|
|
|
(
|
|
|
|
2,
|
|
|
|
wxParseCommonDialogsFilter
|
|
|
|
(
|
|
|
|
"All files (*.*)|*.*|Python source (*.py)|*.py",
|
|
|
|
descs, filters
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL( "*.*", filters[0] );
|
|
|
|
CPPUNIT_ASSERT_EQUAL( "*.py", filters[1] );
|
|
|
|
|
|
|
|
// Test some invalid ones too.
|
|
|
|
WX_ASSERT_FAILS_WITH_ASSERT
|
|
|
|
(
|
|
|
|
wxParseCommonDialogsFilter
|
|
|
|
(
|
|
|
|
"All files (*.*)|*.*|Python source (*.py)|*.py|",
|
|
|
|
descs, filters
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-10-02 20:16:30 -04:00
|
|
|
void MiscGUIFuncsTestCase::ClientToScreen()
|
|
|
|
{
|
|
|
|
wxWindow* const tlw = wxTheApp->GetTopWindow();
|
|
|
|
CPPUNIT_ASSERT( tlw );
|
|
|
|
|
|
|
|
wxPanel* const
|
|
|
|
p1 = new wxPanel(tlw, wxID_ANY, wxPoint(0, 0), wxSize(100, 50));
|
|
|
|
wxPanel* const
|
|
|
|
p2 = new wxPanel(tlw, wxID_ANY, wxPoint(0, 50), wxSize(100, 50));
|
|
|
|
wxWindow* const
|
|
|
|
b = new wxWindow(p2, wxID_ANY, wxPoint(10, 10), wxSize(30, 10));
|
|
|
|
|
|
|
|
// We need this to realize the windows created above under wxGTK.
|
|
|
|
wxYield();
|
|
|
|
|
|
|
|
const wxPoint tlwOrig = tlw->ClientToScreen(wxPoint(0, 0));
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL
|
|
|
|
(
|
|
|
|
tlwOrig + wxPoint(0, 50),
|
|
|
|
p2->ClientToScreen(wxPoint(0, 0))
|
|
|
|
);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL
|
|
|
|
(
|
|
|
|
tlwOrig + wxPoint(10, 60),
|
|
|
|
b->ClientToScreen(wxPoint(0, 0))
|
|
|
|
);
|
|
|
|
|
|
|
|
p1->Destroy();
|
|
|
|
p2->Destroy();
|
|
|
|
}
|
|
|
|
|
2012-10-02 20:16:07 -04:00
|
|
|
namespace
|
|
|
|
{
|
|
|
|
|
|
|
|
// This class is used as a test window here. We can't use a real wxButton
|
|
|
|
// because we can't create other windows as its children in wxGTK.
|
|
|
|
class TestButton : public wxWindow
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
TestButton(wxWindow* parent, const wxString& label, const wxPoint& pos)
|
|
|
|
: wxWindow(parent, wxID_ANY, pos, wxSize(100, 50))
|
|
|
|
{
|
|
|
|
SetLabel(label);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// Helper function returning the label of the window at the given point or
|
|
|
|
// "NONE" if there is no window there.
|
|
|
|
wxString GetLabelOfWindowAtPoint(wxWindow* parent, int x, int y)
|
|
|
|
{
|
|
|
|
wxWindow* const
|
|
|
|
win = wxFindWindowAtPoint(parent->ClientToScreen(wxPoint(x, y)));
|
|
|
|
return win ? win->GetLabel() : wxString("NONE");
|
|
|
|
}
|
|
|
|
|
|
|
|
} // anonymous namespace
|
|
|
|
|
2012-03-03 19:29:17 -05:00
|
|
|
void MiscGUIFuncsTestCase::FindWindowAtPoint()
|
|
|
|
{
|
|
|
|
wxWindow* const parent = wxTheApp->GetTopWindow();
|
|
|
|
CPPUNIT_ASSERT( parent );
|
|
|
|
|
2012-10-02 20:16:07 -04:00
|
|
|
// Set a label to allow distinguishing it from the other windows in the
|
|
|
|
// assertion messages.
|
|
|
|
parent->SetLabel("parent");
|
|
|
|
|
2012-10-02 20:16:53 -04:00
|
|
|
wxWindow* btn1 = new TestButton(parent, "1", wxPoint(10, 10));
|
|
|
|
wxWindow* btn2 = new TestButton(parent, "2", wxPoint(10, 90));
|
|
|
|
wxWindow* btn3 = new TestButton(btn2, "3", wxPoint(20, 20));
|
|
|
|
|
|
|
|
// We need this to realize the windows created above under wxGTK.
|
|
|
|
wxYield();
|
|
|
|
|
2012-10-02 20:16:07 -04:00
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE
|
2012-03-03 19:29:17 -05:00
|
|
|
(
|
|
|
|
"No window for a point outside of the window",
|
2012-10-02 20:16:07 -04:00
|
|
|
"NONE",
|
|
|
|
GetLabelOfWindowAtPoint(parent, 900, 900)
|
2012-03-03 19:29:17 -05:00
|
|
|
);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE
|
|
|
|
(
|
|
|
|
"Point over a child control corresponds to it",
|
2012-10-02 20:16:07 -04:00
|
|
|
btn1->GetLabel(),
|
|
|
|
GetLabelOfWindowAtPoint(parent, 11, 11)
|
2012-03-03 19:29:17 -05:00
|
|
|
);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE
|
|
|
|
(
|
|
|
|
"Point outside of any child control returns the TLW itself",
|
2012-10-02 20:16:07 -04:00
|
|
|
parent->GetLabel(),
|
|
|
|
GetLabelOfWindowAtPoint(parent, 5, 5)
|
2012-03-03 19:29:17 -05:00
|
|
|
);
|
|
|
|
|
|
|
|
btn2->Disable();
|
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE
|
|
|
|
(
|
|
|
|
"Point over a disabled child control still corresponds to it",
|
2012-10-02 20:16:07 -04:00
|
|
|
btn2->GetLabel(),
|
|
|
|
GetLabelOfWindowAtPoint(parent, 11, 91)
|
2012-03-03 19:29:17 -05:00
|
|
|
);
|
|
|
|
|
|
|
|
btn2->Hide();
|
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE
|
|
|
|
(
|
|
|
|
"Point over a hidden child control doesn't take it into account",
|
2012-10-02 20:16:07 -04:00
|
|
|
parent->GetLabel(),
|
|
|
|
GetLabelOfWindowAtPoint(parent, 11, 91)
|
2012-03-03 19:29:17 -05:00
|
|
|
);
|
2012-03-11 11:27:40 -04:00
|
|
|
|
2012-09-13 13:12:42 -04:00
|
|
|
btn2->Show();
|
2012-10-02 20:16:53 -04:00
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE
|
|
|
|
(
|
|
|
|
"Point over child control corresponds to the child",
|
|
|
|
btn3->GetLabel(),
|
|
|
|
GetLabelOfWindowAtPoint(parent, 31, 111)
|
|
|
|
);
|
|
|
|
|
2012-09-13 13:12:42 -04:00
|
|
|
btn3->Disable();
|
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE
|
|
|
|
(
|
2012-10-02 20:16:53 -04:00
|
|
|
"Point over disabled child controls still corresponds to this child",
|
2012-10-02 20:16:07 -04:00
|
|
|
btn3->GetLabel(),
|
2012-10-02 20:16:53 -04:00
|
|
|
GetLabelOfWindowAtPoint(parent, 31, 111)
|
2012-09-13 13:12:42 -04:00
|
|
|
);
|
|
|
|
|
2012-10-02 20:16:53 -04:00
|
|
|
btn1->Destroy();
|
|
|
|
btn2->Destroy();
|
|
|
|
// btn3 was already deleted when its parent was
|
2012-03-03 19:29:17 -05:00
|
|
|
}
|