aboutsummaryrefslogtreecommitdiff
path: root/test/common
diff options
context:
space:
mode:
authorMax Horn2010-04-10 23:12:22 +0000
committerMax Horn2010-04-10 23:12:22 +0000
commitfcee4f2ad753c06b4c58fc21c69b0d4e7f0c4967 (patch)
tree400c4c4f620a47842190aeb0c446ca458e176598 /test/common
parentf4d7bdc9374ace439bff3d6b430e92c9cdd6cd44 (diff)
downloadscummvm-rg350-fcee4f2ad753c06b4c58fc21c69b0d4e7f0c4967.tar.gz
scummvm-rg350-fcee4f2ad753c06b4c58fc21c69b0d4e7f0c4967.tar.bz2
scummvm-rg350-fcee4f2ad753c06b4c58fc21c69b0d4e7f0c4967.zip
Part of patch #2982224: "GSoC: Added unit test and unified error message display"
svn-id: r48613
Diffstat (limited to 'test/common')
-rw-r--r--test/common/tokenizer.h59
1 files changed, 59 insertions, 0 deletions
diff --git a/test/common/tokenizer.h b/test/common/tokenizer.h
new file mode 100644
index 0000000000..3f4b042c00
--- /dev/null
+++ b/test/common/tokenizer.h
@@ -0,0 +1,59 @@
+#include <cxxtest/TestSuite.h>
+#include "common/util.h"
+#include "common/tokenizer.h"
+
+class TokenizerTestSuite : public CxxTest::TestSuite {
+public:
+ void test_nextToken() {
+
+ // test Common::StringTokenizer class
+
+ // test normal behavior
+ Common::StringTokenizer strTokenizer("Now, this is a test!", " ,!");
+ Common::String tokenArray[] = {"Now", "this", "is", "a", "test"};
+
+ for (int i = 0; i < ARRAYSIZE(tokenArray); i++ ) {
+ // make sure nextToken works correctly
+ TS_ASSERT_EQUALS(tokenArray[i], strTokenizer.nextToken());
+ }
+
+ // test edgy conditions:
+
+ // Empty String
+ Common::StringTokenizer s1("");
+ TS_ASSERT_EQUALS("", s1.nextToken());
+
+ // Empty Delimiter
+ Common::StringTokenizer s2("test String", "");
+ TS_ASSERT_EQUALS("test String", s2.nextToken());
+
+ // String is the delimiter
+ Common::StringTokenizer s3("abc", "abc");
+ TS_ASSERT_EQUALS("", s3.nextToken());
+ // Tokenizer should be empty
+ TS_ASSERT(s3.empty());
+
+ // consecutive delimiters in the string
+ Common::StringTokenizer s4("strstr,after all!!", "str, !");
+ TS_ASSERT_EQUALS("af", s4.nextToken());
+ }
+
+ void test_resetAndEmpty() {
+ Common::StringTokenizer strTokenizer("Just, another test!", " ,!");
+
+ // test reset()
+ Common::String token1 = strTokenizer.nextToken(); //Just
+ strTokenizer.reset();
+ Common::String token2 = strTokenizer.nextToken(); //Just
+
+ TS_ASSERT_EQUALS(token1,token2);
+
+ // test empty()
+ TS_ASSERT(!strTokenizer.empty());
+ strTokenizer.nextToken(); //another
+ strTokenizer.nextToken(); //test
+ TS_ASSERT(strTokenizer.empty());
+ }
+
+};
+