added ToLong/ULong/Double() tests
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@35466 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
731fa21e8c
commit
4f7ee81a08
@ -53,6 +53,9 @@ private:
|
|||||||
CPPUNIT_TEST( CaseChanges );
|
CPPUNIT_TEST( CaseChanges );
|
||||||
CPPUNIT_TEST( Compare );
|
CPPUNIT_TEST( Compare );
|
||||||
CPPUNIT_TEST( CompareNoCase );
|
CPPUNIT_TEST( CompareNoCase );
|
||||||
|
CPPUNIT_TEST( ToLong );
|
||||||
|
CPPUNIT_TEST( ToULong );
|
||||||
|
CPPUNIT_TEST( ToDouble );
|
||||||
CPPUNIT_TEST_SUITE_END();
|
CPPUNIT_TEST_SUITE_END();
|
||||||
|
|
||||||
void String();
|
void String();
|
||||||
@ -75,6 +78,9 @@ private:
|
|||||||
void CaseChanges();
|
void CaseChanges();
|
||||||
void Compare();
|
void Compare();
|
||||||
void CompareNoCase();
|
void CompareNoCase();
|
||||||
|
void ToLong();
|
||||||
|
void ToULong();
|
||||||
|
void ToDouble();
|
||||||
|
|
||||||
#if wxUSE_WCHAR_T
|
#if wxUSE_WCHAR_T
|
||||||
// test if converting s using the given encoding gives ws and vice versa
|
// test if converting s using the given encoding gives ws and vice versa
|
||||||
@ -635,3 +641,94 @@ void StringTestCase::CompareNoCase()
|
|||||||
CPPUNIT_CNCNEQ_ASSERT( s1, neq3 );
|
CPPUNIT_CNCNEQ_ASSERT( s1, neq3 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StringTestCase::ToLong()
|
||||||
|
{
|
||||||
|
long l;
|
||||||
|
static const struct ToLongData
|
||||||
|
{
|
||||||
|
const wxChar *str;
|
||||||
|
long value;
|
||||||
|
bool ok;
|
||||||
|
} longData[] =
|
||||||
|
{
|
||||||
|
{ _T("1"), 1, true },
|
||||||
|
{ _T("0"), 0, true },
|
||||||
|
{ _T("a"), 0, false },
|
||||||
|
{ _T("12345"), 12345, true },
|
||||||
|
{ _T("-1"), -1, true },
|
||||||
|
{ _T("--1"), 0, false },
|
||||||
|
};
|
||||||
|
|
||||||
|
size_t n;
|
||||||
|
for ( n = 0; n < WXSIZEOF(longData); n++ )
|
||||||
|
{
|
||||||
|
const ToLongData& ld = longData[n];
|
||||||
|
CPPUNIT_ASSERT_EQUAL( ld.ok, wxString(ld.str).ToLong(&l) );
|
||||||
|
if ( ld.ok )
|
||||||
|
CPPUNIT_ASSERT_EQUAL( ld.value, l );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void StringTestCase::ToULong()
|
||||||
|
{
|
||||||
|
unsigned long ul;
|
||||||
|
static const struct ToULongData
|
||||||
|
{
|
||||||
|
const wxChar *str;
|
||||||
|
unsigned long value;
|
||||||
|
bool ok;
|
||||||
|
} ulongData[] =
|
||||||
|
{
|
||||||
|
{ _T("1"), 1, true },
|
||||||
|
{ _T("0"), 0, true },
|
||||||
|
{ _T("a"), 0, false },
|
||||||
|
{ _T("12345"), 12345, true },
|
||||||
|
// this is surprizing but consistent with strtoul() behaviour
|
||||||
|
{ _T("-1"), ULONG_MAX, true },
|
||||||
|
};
|
||||||
|
|
||||||
|
size_t n;
|
||||||
|
for ( n = 0; n < WXSIZEOF(ulongData); n++ )
|
||||||
|
{
|
||||||
|
const ToULongData& uld = ulongData[n];
|
||||||
|
CPPUNIT_ASSERT_EQUAL( uld.ok, wxString(uld.str).ToULong(&ul) );
|
||||||
|
if ( uld.ok )
|
||||||
|
CPPUNIT_ASSERT_EQUAL( uld.value, ul );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void StringTestCase::ToDouble()
|
||||||
|
{
|
||||||
|
double d;
|
||||||
|
static const struct ToDoubleData
|
||||||
|
{
|
||||||
|
const wxChar *str;
|
||||||
|
double value;
|
||||||
|
bool ok;
|
||||||
|
} doubleData[] =
|
||||||
|
{
|
||||||
|
{ _T("1"), 1, true },
|
||||||
|
{ _T("1.23"), 1.23, true },
|
||||||
|
{ _T(".1"), .1, true },
|
||||||
|
{ _T("1."), 1, true },
|
||||||
|
{ _T("1.."), 0, false },
|
||||||
|
{ _T("0"), 0, true },
|
||||||
|
{ _T("a"), 0, false },
|
||||||
|
{ _T("12345"), 12345, true },
|
||||||
|
{ _T("-1"), -1, true },
|
||||||
|
{ _T("--1"), 0, false },
|
||||||
|
};
|
||||||
|
|
||||||
|
// we need to use decimal point, not comma or whatever is its value for the
|
||||||
|
// current locale
|
||||||
|
wxSetlocale(LC_ALL, _T("C"));
|
||||||
|
|
||||||
|
size_t n;
|
||||||
|
for ( n = 0; n < WXSIZEOF(doubleData); n++ )
|
||||||
|
{
|
||||||
|
const ToDoubleData& ld = doubleData[n];
|
||||||
|
CPPUNIT_ASSERT_EQUAL( ld.ok, wxString(ld.str).ToDouble(&d) );
|
||||||
|
if ( ld.ok )
|
||||||
|
CPPUNIT_ASSERT_EQUAL( ld.value, d );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user