1 ///////////////////////////////////////////////////////////////////////////////
2 // Name: tests/strings/strings.cpp
3 // Purpose: wxStringTokenizer unit test
4 // Author: Vadim Zeitlin
5 // Created: 2005-12-20 (extacted from strings.cpp)
7 // Copyright: (c) 2004-2005 Vadim Zeitlin
8 ///////////////////////////////////////////////////////////////////////////////
10 // ----------------------------------------------------------------------------
12 // ----------------------------------------------------------------------------
24 #include "wx/tokenzr.h"
26 // ----------------------------------------------------------------------------
28 // ----------------------------------------------------------------------------
30 class TokenizerTestCase
: public CppUnit::TestCase
33 TokenizerTestCase() { }
36 CPPUNIT_TEST_SUITE( TokenizerTestCase
);
37 CPPUNIT_TEST( GetCount
);
38 CPPUNIT_TEST( GetPosition
);
39 CPPUNIT_TEST( LastDelimiter
);
40 CPPUNIT_TEST( StrtokCompat
);
41 CPPUNIT_TEST_SUITE_END();
48 DECLARE_NO_COPY_CLASS(TokenizerTestCase
)
51 // register in the unnamed registry so that these tests are run by default
52 CPPUNIT_TEST_SUITE_REGISTRATION( TokenizerTestCase
);
54 // also include in it's own registry so that these tests can be run alone
55 CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( TokenizerTestCase
, "TokenizerTestCase" );
57 // ----------------------------------------------------------------------------
59 // ----------------------------------------------------------------------------
61 static const struct TokenizerTestData
63 // the string to tokenize
66 // the delimiters to use
70 wxStringTokenizerMode mode
;
72 // expected number of tokens
77 { _T(""), _T(" "), wxTOKEN_DEFAULT
, 0 },
78 { _T(""), _T(" "), wxTOKEN_RET_EMPTY
, 0 },
79 { _T(""), _T(" "), wxTOKEN_RET_EMPTY_ALL
, 0 },
80 { _T(""), _T(" "), wxTOKEN_RET_DELIMS
, 0 },
81 { _T(":"), _T(":"), wxTOKEN_RET_EMPTY
, 1 },
82 { _T(":"), _T(":"), wxTOKEN_RET_DELIMS
, 1 },
83 { _T(":"), _T(":"), wxTOKEN_RET_EMPTY_ALL
, 2 },
84 { _T("::"), _T(":"), wxTOKEN_RET_EMPTY
, 1 },
85 { _T("::"), _T(":"), wxTOKEN_RET_DELIMS
, 1 },
86 { _T("::"), _T(":"), wxTOKEN_RET_EMPTY_ALL
, 3 },
88 { _T("Hello, world"), _T(" "), wxTOKEN_DEFAULT
, 2 },
89 { _T("Hello, world "), _T(" "), wxTOKEN_DEFAULT
, 2 },
90 { _T("Hello, world"), _T(","), wxTOKEN_DEFAULT
, 2 },
91 { _T("Hello, world!"), _T(",!"), wxTOKEN_DEFAULT
, 2 },
92 { _T("Hello,, world!"), _T(",!"), wxTOKEN_DEFAULT
, 3 },
93 { _T("Hello,, world!"), _T(",!"), wxTOKEN_STRTOK
, 2 },
94 { _T("Hello, world!"), _T(",!"), wxTOKEN_RET_EMPTY_ALL
, 3 },
96 { _T("username:password:uid:gid:gecos:home:shell"),
97 _T(":"), wxTOKEN_DEFAULT
, 7 },
99 { _T("1:2::3:"), _T(":"), wxTOKEN_DEFAULT
, 4 },
100 { _T("1:2::3:"), _T(":"), wxTOKEN_RET_EMPTY
, 4 },
101 { _T("1:2::3:"), _T(":"), wxTOKEN_RET_EMPTY_ALL
, 5 },
102 { _T("1:2::3:"), _T(":"), wxTOKEN_RET_DELIMS
, 4 },
103 { _T("1:2::3:"), _T(":"), wxTOKEN_STRTOK
, 3 },
105 { _T("1:2::3::"), _T(":"), wxTOKEN_DEFAULT
, 4 },
106 { _T("1:2::3::"), _T(":"), wxTOKEN_RET_EMPTY
, 4 },
107 { _T("1:2::3::"), _T(":"), wxTOKEN_RET_EMPTY_ALL
, 6 },
108 { _T("1:2::3::"), _T(":"), wxTOKEN_RET_DELIMS
, 4 },
109 { _T("1:2::3::"), _T(":"), wxTOKEN_STRTOK
, 3 },
111 { _T("1 \t3\t4 6 "), wxDEFAULT_DELIMITERS
, wxTOKEN_DEFAULT
, 4 },
112 { _T("1 \t3\t4 6 "), wxDEFAULT_DELIMITERS
, wxTOKEN_STRTOK
, 4 },
113 { _T("1 \t3\t4 6 "), wxDEFAULT_DELIMITERS
, wxTOKEN_RET_EMPTY
, 6 },
114 { _T("1 \t3\t4 6 "), wxDEFAULT_DELIMITERS
, wxTOKEN_RET_EMPTY_ALL
, 9 },
116 { _T("01/02/99"), _T("/-"), wxTOKEN_DEFAULT
, 3 },
117 { _T("01-02/99"), _T("/-"), wxTOKEN_RET_DELIMS
, 3 },
120 // helper function returning the string showing the index for which the test
121 // fails in the diagnostic message
122 static std::string
Nth(size_t n
)
124 return wxString::Format(_T("for loop index %lu"), (unsigned long)n
).mb_str();
127 // ----------------------------------------------------------------------------
129 // ----------------------------------------------------------------------------
131 void TokenizerTestCase::GetCount()
133 for ( size_t n
= 0; n
< WXSIZEOF(gs_testData
); n
++ )
135 const TokenizerTestData
& ttd
= gs_testData
[n
];
137 wxStringTokenizer
tkz(ttd
.str
, ttd
.delims
, ttd
.mode
);
138 CPPUNIT_ASSERT_EQUAL_MESSAGE( Nth(n
), ttd
.count
, tkz
.CountTokens() );
141 while ( tkz
.HasMoreTokens() )
147 CPPUNIT_ASSERT_EQUAL_MESSAGE( Nth(n
), ttd
.count
, count
);
151 // call this with the string to tokenize, delimeters to use and the expected
152 // positions (i.e. results of GetPosition()) after each GetNextToken() call,
153 // terminate positions with 0
155 DoTestGetPosition(const wxChar
*s
, const wxChar
*delims
, int pos
, ...)
157 wxStringTokenizer
tkz(s
, delims
);
159 CPPUNIT_ASSERT_EQUAL( (size_t)0, tkz
.GetPosition() );
168 CPPUNIT_ASSERT( !tkz
.HasMoreTokens() );
174 CPPUNIT_ASSERT_EQUAL( (size_t)pos
, tkz
.GetPosition() );
176 pos
= va_arg(ap
, int);
182 void TokenizerTestCase::GetPosition()
184 DoTestGetPosition(_T("foo"), _T("_"), 3, 0);
185 DoTestGetPosition(_T("foo_bar"), _T("_"), 4, 7, 0);
186 DoTestGetPosition(_T("foo_bar_"), _T("_"), 4, 8, 0);
189 void TokenizerTestCase::LastDelimiter()
191 wxStringTokenizer
tkz(_T("a+-b=c"), _T("+-="));
194 CPPUNIT_ASSERT_EQUAL( _T('+'), tkz
.GetLastDelimiter() );
197 CPPUNIT_ASSERT_EQUAL( _T('-'), tkz
.GetLastDelimiter() );
200 CPPUNIT_ASSERT_EQUAL( _T('='), tkz
.GetLastDelimiter() );
203 CPPUNIT_ASSERT_EQUAL( _T('\0'), tkz
.GetLastDelimiter() );
206 void TokenizerTestCase::StrtokCompat()
208 for ( size_t n
= 0; n
< WXSIZEOF(gs_testData
); n
++ )
210 const TokenizerTestData
& ttd
= gs_testData
[n
];
211 if ( ttd
.mode
!= wxTOKEN_STRTOK
)
221 wxChar
*s
= wxStrtok(buf
.data(), ttd
.delims
, &last
);
223 wxStringTokenizer
tkz(ttd
.str
, ttd
.delims
, ttd
.mode
);
224 while ( tkz
.HasMoreTokens() )
226 CPPUNIT_ASSERT_EQUAL( wxString(s
), tkz
.GetNextToken() );
227 s
= wxStrtok(NULL
, ttd
.delims
, &last
);