Upgrade accelerator entry unit tests
* Convert to the Catch framework * Add a test for proper display name parsing
This commit is contained in:
@@ -20,73 +20,81 @@
|
||||
#endif // WX_PRECOMP
|
||||
|
||||
#include "wx/accel.h"
|
||||
#include "wx/scopedptr.h"
|
||||
|
||||
class AccelEntryTestCase : public CppUnit::TestCase
|
||||
{
|
||||
public:
|
||||
AccelEntryTestCase() {}
|
||||
|
||||
private:
|
||||
CPPUNIT_TEST_SUITE( AccelEntryTestCase );
|
||||
CPPUNIT_TEST( Create );
|
||||
CPPUNIT_TEST( ToFromString );
|
||||
CPPUNIT_TEST_SUITE_END();
|
||||
|
||||
void Create();
|
||||
void ToFromString();
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(AccelEntryTestCase);
|
||||
};
|
||||
|
||||
// register in the unnamed registry so that these tests are run by default
|
||||
CPPUNIT_TEST_SUITE_REGISTRATION( AccelEntryTestCase );
|
||||
|
||||
// also include in its own registry so that these tests can be run alone
|
||||
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( AccelEntryTestCase, "AccelEntryTestCase" );
|
||||
|
||||
namespace
|
||||
{
|
||||
|
||||
void CheckAccelEntry(const wxAcceleratorEntry& accel, int keycode, int flags)
|
||||
{
|
||||
CPPUNIT_ASSERT_EQUAL( keycode, accel.GetKeyCode() );
|
||||
CPPUNIT_ASSERT_EQUAL( flags, accel.GetFlags() );
|
||||
REQUIRE( keycode == accel.GetKeyCode() );
|
||||
REQUIRE( flags == accel.GetFlags() );
|
||||
}
|
||||
|
||||
} // anonymous namespace
|
||||
|
||||
void AccelEntryTestCase::Create()
|
||||
|
||||
/*
|
||||
* Test the creation of accelerator keys using the Create function
|
||||
*/
|
||||
TEST_CASE( "wxAcceleratorEntry::Create", "[accelentry]" )
|
||||
{
|
||||
wxScopedPtr<wxAcceleratorEntry>
|
||||
pa(wxAcceleratorEntry::Create("Foo\tCtrl+Z"));
|
||||
CPPUNIT_ASSERT( pa );
|
||||
CPPUNIT_ASSERT( pa->IsOk() );
|
||||
wxAcceleratorEntry* pa;
|
||||
|
||||
SECTION( "Correct behavior" )
|
||||
{
|
||||
pa = wxAcceleratorEntry::Create("Foo\tCtrl+Z");
|
||||
|
||||
REQUIRE( pa );
|
||||
REQUIRE( pa->IsOk() );
|
||||
CheckAccelEntry(*pa, 'Z', wxACCEL_CTRL);
|
||||
|
||||
|
||||
// There must be a TAB in the string passed to Create()
|
||||
pa.reset(wxAcceleratorEntry::Create("Shift-Q"));
|
||||
CPPUNIT_ASSERT( !pa );
|
||||
|
||||
pa.reset(wxAcceleratorEntry::Create("Bar\tShift-Q"));
|
||||
CPPUNIT_ASSERT( pa );
|
||||
CPPUNIT_ASSERT( pa->IsOk() );
|
||||
CheckAccelEntry(*pa, 'Q', wxACCEL_SHIFT);
|
||||
|
||||
|
||||
pa.reset(wxAcceleratorEntry::Create("bloordyblop"));
|
||||
CPPUNIT_ASSERT( !pa );
|
||||
}
|
||||
|
||||
void AccelEntryTestCase::ToFromString()
|
||||
SECTION( "Tab missing" )
|
||||
{
|
||||
pa = wxAcceleratorEntry::Create("Shift-Q");
|
||||
|
||||
REQUIRE( !pa );
|
||||
}
|
||||
|
||||
SECTION( "No accelerator key specified" )
|
||||
{
|
||||
pa = wxAcceleratorEntry::Create("bloordyblop");
|
||||
|
||||
REQUIRE( !pa );
|
||||
}
|
||||
|
||||
SECTION( "Display name parsing" )
|
||||
{
|
||||
pa = wxAcceleratorEntry::Create("Test\tBackSpace");
|
||||
|
||||
REQUIRE( pa );
|
||||
REQUIRE( pa->IsOk() );
|
||||
CheckAccelEntry(*pa, WXK_BACK, wxACCEL_NORMAL);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Test the creation of accelerator keys from strings and also the
|
||||
* creation of strings from an accelerator key
|
||||
*/
|
||||
TEST_CASE( "wxAcceleratorEntry::StringTests", "[accelentry]" )
|
||||
{
|
||||
wxAcceleratorEntry a(wxACCEL_ALT, 'X');
|
||||
CPPUNIT_ASSERT_EQUAL( "Alt+X", a.ToString() );
|
||||
|
||||
CPPUNIT_ASSERT( a.FromString("Alt+Shift+F1") );
|
||||
CheckAccelEntry(a, WXK_F1, wxACCEL_ALT | wxACCEL_SHIFT);
|
||||
|
||||
CPPUNIT_ASSERT( !a.FromString("bloordyblop") );
|
||||
SECTION( "Create string from key" )
|
||||
{
|
||||
REQUIRE( "Alt+X" == a.ToString() );
|
||||
}
|
||||
|
||||
SECTION( "Create from valid string" )
|
||||
{
|
||||
REQUIRE( a.FromString("Alt+Shift+F1") );
|
||||
CheckAccelEntry(a, WXK_F1, wxACCEL_ALT | wxACCEL_SHIFT);
|
||||
}
|
||||
|
||||
SECTION( "Create from invalid string" )
|
||||
{
|
||||
REQUIRE( !a.FromString("bloordyblop") );
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user