diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | ce4a32fe52ef09d8f5ff1dd22c001110902b60a2 (patch) | |
tree | 5ac38a06f3dde268dc7927dc155896926aaf7012 /kdecore/tests/kstringhandlertest.cpp | |
download | tdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.tar.gz tdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdelibs@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kdecore/tests/kstringhandlertest.cpp')
-rw-r--r-- | kdecore/tests/kstringhandlertest.cpp | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/kdecore/tests/kstringhandlertest.cpp b/kdecore/tests/kstringhandlertest.cpp new file mode 100644 index 000000000..75695309d --- /dev/null +++ b/kdecore/tests/kstringhandlertest.cpp @@ -0,0 +1,97 @@ +#include "kstringhandler.h" +#include <iostream> +using std::cout; +using std::endl; + +bool check(const QString &txt, const QString &a, const QString &b) +{ + if ( a != b ) { + cout << "ERROR: Tested " << txt.latin1() << ", expected" << endl; + cout << "'" << b.latin1() << "' (" << b.length() << " chars)" << endl; + cout << "but got" << endl; + cout << "'" << a.latin1() << "' (" << a.length() << " chars)" << endl; + exit( 1 ); + } + return true; +} + +int main(int argc, char *argv[]) +{ + QString test = "The quick brown fox jumped over the lazy bridge. "; + + check("word(test, 3)", + KStringHandler::word(test, 2), + "brown"); + check("word(test, \"3:5\")", + KStringHandler::word(test, "2:4"), + "brown fox jumped"); + check("insword(test, \"very\", 1)", + KStringHandler::insword(test, "very", 1), + "The very quick brown fox jumped over the lazy bridge. "); + check("setword(test, \"very\", 1)", + KStringHandler::setword(test, "very", 1), + "The very brown fox jumped over the lazy bridge. "); + check("remrange(test, \"4:6\")", + KStringHandler::remrange(test, "4:6"), + "The quick brown fox lazy bridge. " ); + check("remrange(test, \"4:8\")", + KStringHandler::remrange(test, "4:8"), + "The quick brown fox "); + check("remword(test, 4)", + KStringHandler::remword(test, 4), + "The quick brown fox over the lazy bridge. "); + check("remword(test, \"lazy\")", + KStringHandler::remword(test, "lazy"), + "The quick brown fox jumped over the bridge. "); + check("capwords(test)", + KStringHandler::capwords(test), + "The Quick Brown Fox Jumped Over The Lazy Bridge. "); + check("reverse(test)", + KStringHandler::reverse(test), + " bridge. lazy the over jumped fox brown quick The"); + QString result; + result = KStringHandler::ljust(test, 70); + if (result.length() != 70) + { + printf("Length = %d, expected 70.\n", result.length()); + exit(1); + } + check("ljust(test, 70)", + result, + "The quick brown fox jumped over the lazy bridge. "); + result = KStringHandler::rjust(test, 70); + if (result.length() != 70) + { + printf("Length = %d, expected 70.\n", result.length()); + exit(1); + } + check("rjust(test, 70)", + result, + " The quick brown fox jumped over the lazy bridge."); + result = KStringHandler::center(test, 70); + if (result.length() != 70) + { + printf("Length = %d, expected 70.\n", result.length()); + exit(1); + } + check("center(test, 70)", + result, + " The quick brown fox jumped over the lazy bridge. "); + + test = "Click on http://foo@bar:www.kde.org/yoyo/dyne.html#a1 for info."; + check( "tagURLs()", KStringHandler::tagURLs( test ), + "Click on <a href=\"http://foo@bar:www.kde.org/yoyo/dyne.html#a1\">http://foo@bar:www.kde.org/yoyo/dyne.html#a1</a> for info." ); + + test = "http://www.foo.org/story$806"; + check( "tagURLs()", KStringHandler::tagURLs( test ), + "<a href=\"http://www.foo.org/story$806\">http://www.foo.org/story$806</a>" ); + +#if 0 + // XFAIL - i.e. this needs to be fixed, but has never been + test = "<a href=www.foo.com>"; + check( "tagURLs()", KStringHandler::tagURLs( test ), + "<a href=<a href=\"www.foo.com\">www.foo.com</a>>" ); +#endif + + cout << "All OK!" << endl; +} |