Unit tests update
This commit is contained in:
parent
a0bf6bd00c
commit
27cefbf99b
|
@ -1834,6 +1834,9 @@ FString FString::replace (const FString& from, const FString& to)
|
||||||
if ( from.isNull() || to.isNull() )
|
if ( from.isNull() || to.isNull() )
|
||||||
return s;
|
return s;
|
||||||
|
|
||||||
|
if ( from.isEmpty() || to.isEmpty() )
|
||||||
|
return s;
|
||||||
|
|
||||||
p = s.string;
|
p = s.string;
|
||||||
from_length = from.getLength();
|
from_length = from.getLength();
|
||||||
to_length = to.getLength();
|
to_length = to.getLength();
|
||||||
|
@ -2132,7 +2135,7 @@ FString FString::replace (const wchar_t from, const FString& to)
|
||||||
if ( ! (string && *string) )
|
if ( ! (string && *string) )
|
||||||
return s;
|
return s;
|
||||||
|
|
||||||
if ( to.isNull() )
|
if ( to.isNull() || to.isEmpty() )
|
||||||
return s;
|
return s;
|
||||||
|
|
||||||
p = s.string;
|
p = s.string;
|
||||||
|
@ -2322,6 +2325,9 @@ FString FString::expandTabs (int tabstop) const
|
||||||
{
|
{
|
||||||
uInt len = tab_split[i].getLength();
|
uInt len = tab_split[i].getLength();
|
||||||
uInt tab_len = uInt(tabstop);
|
uInt tab_len = uInt(tabstop);
|
||||||
|
if ( i == last - 1 )
|
||||||
|
outstr += tab_split[i];
|
||||||
|
else
|
||||||
outstr += tab_split[i] + FString(tab_len - (len % tab_len), L' ');
|
outstr += tab_split[i] + FString(tab_len - (len % tab_len), L' ');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -83,6 +83,7 @@ class FStringTest : public CPPUNIT_NS::TestFixture
|
||||||
void subStringTest();
|
void subStringTest();
|
||||||
void insertTest();
|
void insertTest();
|
||||||
void replaceTest();
|
void replaceTest();
|
||||||
|
void controlCodesTest();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
FString* s;
|
FString* s;
|
||||||
|
@ -115,6 +116,7 @@ class FStringTest : public CPPUNIT_NS::TestFixture
|
||||||
CPPUNIT_TEST (subStringTest);
|
CPPUNIT_TEST (subStringTest);
|
||||||
CPPUNIT_TEST (insertTest);
|
CPPUNIT_TEST (insertTest);
|
||||||
CPPUNIT_TEST (replaceTest);
|
CPPUNIT_TEST (replaceTest);
|
||||||
|
CPPUNIT_TEST (controlCodesTest);
|
||||||
|
|
||||||
// End of test suite definition
|
// End of test suite definition
|
||||||
CPPUNIT_TEST_SUITE_END();
|
CPPUNIT_TEST_SUITE_END();
|
||||||
|
@ -436,32 +438,13 @@ void FStringTest::additionAssignmentTest()
|
||||||
void FStringTest::additionTest()
|
void FStringTest::additionTest()
|
||||||
{
|
{
|
||||||
const FString s1("abc");
|
const FString s1("abc");
|
||||||
FString s2 = s1 + FString("def");
|
CPPUNIT_ASSERT ( s1 + FString("def") == L"abcdef" );
|
||||||
CPPUNIT_ASSERT ( s2 == L"abcdef" );
|
CPPUNIT_ASSERT ( s1 + std::wstring(L"def") == L"abcdef" );
|
||||||
|
CPPUNIT_ASSERT ( s1 + const_cast<wchar_t*>(L"def") == L"abcdef" );
|
||||||
s2.clear();
|
CPPUNIT_ASSERT ( s1 + std::string("def") == L"abcdef" );
|
||||||
s2 = s1 + std::wstring(L"def");
|
CPPUNIT_ASSERT ( s1 + const_cast<char*>("def") == L"abcdef" );
|
||||||
CPPUNIT_ASSERT ( s2 == L"abcdef" );
|
CPPUNIT_ASSERT ( s1 + wchar_t(L'd') == L"abcd" );
|
||||||
|
CPPUNIT_ASSERT ( s1 + char('d') == L"abcd" );
|
||||||
s2.clear();
|
|
||||||
s2 = s1 + const_cast<wchar_t*>(L"def");
|
|
||||||
CPPUNIT_ASSERT ( s2 == L"abcdef" );
|
|
||||||
|
|
||||||
s2.clear();
|
|
||||||
s2 = s1 + std::string("def");
|
|
||||||
CPPUNIT_ASSERT ( s2 == L"abcdef" );
|
|
||||||
|
|
||||||
s2.clear();
|
|
||||||
s2 = s1 + const_cast<char*>("def");
|
|
||||||
CPPUNIT_ASSERT ( s2 == L"abcdef" );
|
|
||||||
|
|
||||||
s2.clear();
|
|
||||||
s2 = s1 + wchar_t(L'd');
|
|
||||||
CPPUNIT_ASSERT ( s2 == L"abcd" );
|
|
||||||
|
|
||||||
s2.clear();
|
|
||||||
s2 = s1 + char('d');
|
|
||||||
CPPUNIT_ASSERT ( s2 == L"abcd" );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
|
@ -919,8 +902,11 @@ void FStringTest::formatTest()
|
||||||
fnum2.setFormatedNumber(-9223372036854775807);
|
fnum2.setFormatedNumber(-9223372036854775807);
|
||||||
CPPUNIT_ASSERT ( fnum2 == "-9 223 372 036 854 775 807" );
|
CPPUNIT_ASSERT ( fnum2 == "-9 223 372 036 854 775 807" );
|
||||||
|
|
||||||
fnum2.setFormatedNumber(-9223372036854775807, '\0');
|
fnum2.setFormatedNumber(long(9223372036854775807), '\0');
|
||||||
CPPUNIT_ASSERT ( fnum2 == "-9 223 372 036 854 775 807" );
|
CPPUNIT_ASSERT ( fnum2 == "9 223 372 036 854 775 807" );
|
||||||
|
|
||||||
|
fnum2.setFormatedNumber(uLong(9223372036854775807), '\0');
|
||||||
|
CPPUNIT_ASSERT ( fnum2 == "9 223 372 036 854 775 807" );
|
||||||
#else
|
#else
|
||||||
// 32-bit architecture
|
// 32-bit architecture
|
||||||
fnum1.setFormatedNumber(0xffffffff, '\'');
|
fnum1.setFormatedNumber(0xffffffff, '\'');
|
||||||
|
@ -929,8 +915,11 @@ void FStringTest::formatTest()
|
||||||
fnum2.setFormatedNumber(-2147483647);
|
fnum2.setFormatedNumber(-2147483647);
|
||||||
CPPUNIT_ASSERT ( fnum2 == "-2 147 483 647" );
|
CPPUNIT_ASSERT ( fnum2 == "-2 147 483 647" );
|
||||||
|
|
||||||
fnum2.setFormatedNumber(-2147483647, '\0');
|
fnum2.setFormatedNumber(long(2147483647), '\0');
|
||||||
CPPUNIT_ASSERT ( fnum2 == "-2 147 483 647" );
|
CPPUNIT_ASSERT ( fnum2 == "2 147 483 647" );
|
||||||
|
|
||||||
|
fnum2.setFormatedNumber(uLong(2147483647), '\0');
|
||||||
|
CPPUNIT_ASSERT ( fnum2 == "2 147 483 647" );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1433,6 +1422,68 @@ void FStringTest::replaceTest()
|
||||||
s = "A big ball and a small ball";
|
s = "A big ball and a small ball";
|
||||||
CPPUNIT_ASSERT ( s.replace("ball", "globe")
|
CPPUNIT_ASSERT ( s.replace("ball", "globe")
|
||||||
== "A big globe and a small globe" );
|
== "A big globe and a small globe" );
|
||||||
|
|
||||||
|
s = "ABC";
|
||||||
|
FString empty;
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from1, empty) == "ABC" );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from3, empty) == "ABC" );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from5, to5) == "ABC" );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(empty, to1) == "ABC" );
|
||||||
|
|
||||||
|
empty = "";
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from1, empty) == "ABC" );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from3, empty) == "ABC" );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from5, to5) == "ABC" );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(empty, to1) == "ABC" );
|
||||||
|
|
||||||
|
s.clear();
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from1, to1).isNull() );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from1, to1).isEmpty() );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from5, to5).isNull() );
|
||||||
|
CPPUNIT_ASSERT ( s.replace(from5, to5).isEmpty() );
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
void FStringTest::controlCodesTest()
|
||||||
|
{
|
||||||
|
FString bs_str = "t\b\bTesT\bt";
|
||||||
|
CPPUNIT_ASSERT ( bs_str.removeBackspaces() == "Test" );
|
||||||
|
bs_str = "ABC\b\b\b\b";
|
||||||
|
CPPUNIT_ASSERT ( bs_str.removeBackspaces() == "" );
|
||||||
|
CPPUNIT_ASSERT ( bs_str.removeBackspaces().isEmpty() );
|
||||||
|
|
||||||
|
FString del_str = "apple \177\177\177pietree";
|
||||||
|
CPPUNIT_ASSERT ( del_str.removeDel() == "apple tree" );
|
||||||
|
del_str = "\177\177\177\177ABC";
|
||||||
|
CPPUNIT_ASSERT ( del_str.removeDel() == "" );
|
||||||
|
CPPUNIT_ASSERT ( del_str.removeDel().isEmpty() );
|
||||||
|
|
||||||
|
FString tab_str = "one line";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "one line" );
|
||||||
|
tab_str = "one\ttwo";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "one two" );
|
||||||
|
tab_str = "one\t\btwo";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "one \btwo" );
|
||||||
|
tab_str = "1\t2\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "1 2 2" );
|
||||||
|
tab_str = "12\t22\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "12 22 2" );
|
||||||
|
tab_str = "123\t222\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "123 222 2" );
|
||||||
|
tab_str = "1234\t2222\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "1234 2222 2" );
|
||||||
|
tab_str = "12345\t22222\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "12345 22222 2" );
|
||||||
|
tab_str = "123456\t222222\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "123456 222222 2" );
|
||||||
|
tab_str = "1234567\t2222222\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "1234567 2222222 2" );
|
||||||
|
tab_str = "12345678\t22222222\t2";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs()
|
||||||
|
== "12345678 22222222 2" );
|
||||||
|
tab_str = "12345678\t2";
|
||||||
|
std::cout << "\n<<" << tab_str.expandTabs() << ">>\n";
|
||||||
|
CPPUNIT_ASSERT ( tab_str.expandTabs() == "12345678 2" );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Put the test suite in the registry
|
// Put the test suite in the registry
|
||||||
|
|
Loading…
Reference in New Issue