summaryrefslogtreecommitdiffstats
path: root/kio/tests/dataprotocoltest.cpp
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2013-01-27 01:04:16 -0600
committerTimothy Pearson <[email protected]>2013-01-27 01:04:16 -0600
commit5159cd2beb2e87806a5b54e9991b7895285c9d3e (patch)
tree9b70e8be47a390f8f4d56ead812ab0c9dad88709 /kio/tests/dataprotocoltest.cpp
parentc17cb900dcf52b8bd6dc300d4f103392900ec2b4 (diff)
downloadtdelibs-5159cd2beb2e87806a5b54e9991b7895285c9d3e.tar.gz
tdelibs-5159cd2beb2e87806a5b54e9991b7895285c9d3e.zip
Rename a number of libraries and executables to avoid conflicts with KDE4
Diffstat (limited to 'kio/tests/dataprotocoltest.cpp')
-rw-r--r--kio/tests/dataprotocoltest.cpp287
1 files changed, 0 insertions, 287 deletions
diff --git a/kio/tests/dataprotocoltest.cpp b/kio/tests/dataprotocoltest.cpp
deleted file mode 100644
index dfacd92e4..000000000
--- a/kio/tests/dataprotocoltest.cpp
+++ /dev/null
@@ -1,287 +0,0 @@
-// testing the data kioslave
-// (C) 2002, 2003 Leo Savernik
-//
-// invoke "make dataprotocoltest" to generate the binary inside KDE CVS
-// invoke "make test" to generate the binary outside KDE CVS
-
-// fix the symptoms, not the illness ;-)
-#ifdef QT_NO_ASCII_CAST
-# undef QT_NO_ASCII_CAST
-#endif
-
-#ifdef DATAKIOSLAVE
-# undef DATAKIOSLAVE
-#endif
-#ifndef TESTKIO
-# define TESTKIO
-#endif
-
-#include <kio/global.h>
-
-#include <tqcstring.h>
-#include <tqstring.h>
-
-#include <iostream.h>
-
-class KURL;
-
-class TestSlave {
-public:
- TestSlave() {
- }
- virtual ~TestSlave() {
- }
-
- virtual void get(const KURL &) = 0;
- virtual void mimetype(const KURL &) = 0;
-
- void mimeType(const TQString &type) {
- testStrings("MIME Type: ",mime_type_expected,type);
- }
-
- void totalSize(TDEIO::filesize_t bytes) {
-// cout << "content size: " << bytes << " bytes" << endl;
- }
-
- void setMetaData(const TQString &key, const TQString &value) {
-// meta_data[key] = value;
-// cout << "� " << key << " = " << value << endl;
- TQString prefix = "Metadata[\""+key+"\"]: ";
- TDEIO::MetaData::Iterator it = attributes_expected.find(key);
- if (it != attributes_expected.end()) {
- testStrings(prefix,it.data(),value);
- // remove key from map
- attributes_expected.remove(it);
- } else {
- cout << endl << prefix << " no such key expected";
- total++;
- }
- }
-
- void sendMetaData() {
- // check here if attributes_expected contains any excess keys
- TDEIO::MetaData::ConstIterator it = attributes_expected.begin();
- TDEIO::MetaData::ConstIterator end = attributes_expected.end();
- for (; it != end; ++it) {
- cout << endl << "Metadata[\"" << it.key()
- << "\"] was expected but not defined";
- total++;
- }
- }
-
- void data(const TQByteArray &a) {
- if (a.isEmpty())
-/* cout << "<no more data>" << endl*/;
- else {
- testStrings("Content: ",content_expected,a);
- }/*end if*/
- }
-
- void finished() {
- }
-
- void dispatchLoop() {
- // dummy to make kde_main happy
- }
-
- // == stuff for regression testing
-private:
- int testcaseno; // number of testcase
- bool failure; // true if any testcase failed
- TQMap<int,bool> failed_testcases;
-
- // -- testcase related members
- TQString mime_type_expected; // expected mime type
- /** contains all attributes and values the testcase has to set */
- TDEIO::MetaData attributes_expected;
- /** contains the content as it is expected to be returned */
- TQByteArray content_expected;
- int passed; // # of passed tests
- int total; // # of total tests
-
- /**
- * compares two strings, printing an error message if they don't match.
- * @param prefix prefix string for output in case of mismatch
- * @param templat template string
- * @param s string to compare to template
- * @param casesensitive true if case sensitive compare (currently not used)
- */
- void testStrings(const TQString &prefix, const TQString &templat,
- const TQString &s, bool /*casesensitive*/ = true) {
- if (templat == s)
- passed++;
- else {
- cout << endl << prefix << "expected \"" << templat << "\", found \""
- << s << "\"";
- failure = true;
- }/*end if*/
- total++;
- }
-
-public:
- /** begins a testrun over all testcases */
- void initTestrun() {
- testcaseno = 0;
- failure = false;
- }
-
- /** reuturns true if any testcase failed
- */
- bool hasFailedTestcases() const { return failure; }
-
- /**
- * sets up a new testcase
- * @param name screen name for testcase
- */
- void beginTestcase(const char *name) {
- passed = 0;
- total = 0;
- testcaseno++;
- cout << "Testcase " << testcaseno << ": [" << name << "] ";
- }
-
- /**
- * sets the mime type that this testcase is expected to return
- */
- void setExpectedMimeType(const TQString &mime_type) {
- mime_type_expected = mime_type;
- }
-
- /**
- * sets all attribute-value pairs the testcase must deliver.
- */
- void setExpectedAttributes(const TDEIO::MetaData &attres) {
- attributes_expected = attres;
- }
-
- /**
- * sets content as expected to be delivered by the testcase.
- */
- void setExpectedContent(const TQByteArray &content) {
- content_expected = content;
- }
-
- /**
- * closes testcase, printing out stats
- */
- void endTestcase() {
- bool failed = passed < total;
- if (failed) {
- failure = true;
- failed_testcases[testcaseno] = true;
- cout << endl;
- }
- cout << "(" << passed << " of " << total << ") " << (failed ? "failed"
- : "passed") << endl;
- }
-
- void endTestrun() {
- if (failure) {
- TQMap<int,bool>::ConstIterator it = failed_testcases.begin();
- for (; it != failed_testcases.end(); ++it) {
- cout << "Testcase " << it.key() << " failed" << endl;
- }
- }
- }
-};
-
-#include "dataprotocol.cpp" // we need access to static data & functions
-
-// == general functionality
-const struct {
-const char * const name;
-const char * const exp_mime_type; // 0 means "text/plain"
-const struct {
- const char * const key;
- const char * const value;
-} exp_attrs[10]; // ended with a key==0, value==0 pair
-const char * const exp_content;
-const char * const url;
-} testcases[] = {
- // -----------------------------------------------------------------
- { "escape resolving", 0, {}, "blah blah", "data:,blah%20blah" },
- // --------------------
- { "mime type, escape resolving", "text/html", {},
- "<div style=\"border:thin orange solid;padding:1ex;background-color:"
- "yellow;color:black\">Rich <b>text</b></div>",
- "data:text/html,<div%20style=\"border:thin%20orange%20solid;"
- "padding:1ex;background-color:yellow;color:black\">Rich%20<b>text</b>"
- "</div>" },
- // -------------------- whitespace test I
- { "whitespace test I", "text/css", {
- { "charset", "iso-8859-15" }, { 0,0 } },
- " body { color: yellow; background:darkblue; font-weight:bold }",
- "data:text/css ; charset = iso-8859-15 , body { color: yellow; "
- "background:darkblue; font-weight:bold }" },
- // -------------------- out of spec argument order, base64 decoding,
- // whitespace test II
- { "out of spec argument order, base64 decoding, whitespace test II",
- 0, {
- { "charset", "iso-8859-1" }, { 0,0 } },
- "paaaaaaaasd!!\n",
- "data: ; base64 ; charset = \"iso-8859-1\" ,cGFhYWFhYWFhc2QhIQo=" },
- // -------------------- arbitrary keys, reserved names as keys,
- // whitespace test III
- { "arbitrary keys, reserved names as keys, whitespace test III", 0, {
- { "base64", "nospace" }, { "key", "onespaceinner" },
- { "key2", "onespaceouter" }, { "charset", "utf8" },
- { "<<empty>>", "" }, { 0,0 } },
- "Die, Allied Schweinehund (C) 1990 Wolfenstein 3D",
- "data: ;base64=nospace;key = onespaceinner; key2=onespaceouter ;"
- " charset = utf8 ; <<empty>>= ,Die, Allied Schweinehund "
- "(C) 1990 Wolfenstein 3D" },
- // -------------------- string literal with escaped chars, testing
- // delimiters within string
- { "string literal with escaped chars, testing delimiters within "
- "string", 0, {
- { "fortune-cookie", "Master Leep say: \"Rabbit is humble, "
- "Rabbit is gentle; follow the Rabbit\"" }, { 0,0 } },
- "(C) 1997 Shadow Warrior ;-)",
- "data:;fortune-cookie=\"Master Leep say: \\\"Rabbit is humble, "
- "Rabbit is gentle; follow the Rabbit\\\"\",(C) 1997 Shadow Warrior "
- ";-)" },
-};
-
-#if 0
-// == charset tests
- // -------------------- string
-const QChar
-const TQChar * const charset_urls[] = {
-#endif
-
-int main(int /*argc*/,char* /*argv*/[]) {
- DataProtocol kio_data;
-
- kio_data.initTestrun();
- for (uint i = 0; i < sizeof testcases/sizeof testcases[0]; i++) {
- kio_data.beginTestcase(testcases[i].name);
- kio_data.setExpectedMimeType(testcases[i].exp_mime_type != 0
- ? testcases[i].exp_mime_type : "text/plain");
-
- bool has_charset = false;
- MetaData exp_attrs;
- if (testcases[i].exp_attrs != 0) {
- for (uint j = 0; testcases[i].exp_attrs[j].key != 0; j++) {
- exp_attrs[testcases[i].exp_attrs[j].key] = testcases[i].exp_attrs[j].value;
- if (strcmp(testcases[i].exp_attrs[j].key,"charset") == 0)
- has_charset = true;
- }/*next j*/
- }
- if (!has_charset) exp_attrs["charset"] = "us-ascii";
- kio_data.setExpectedAttributes(exp_attrs);
-
- TQByteArray exp_content;
- uint exp_content_len = strlen(testcases[i].exp_content);
- exp_content.setRawData(testcases[i].exp_content,exp_content_len);
- kio_data.setExpectedContent(exp_content);
-
- kio_data.get(testcases[i].url);
-
- kio_data.endTestcase();
- exp_content.resetRawData(testcases[i].exp_content,exp_content_len);
- }/*next i*/
- kio_data.endTestrun();
-
- return kio_data.hasFailedTestcases() ? 1 : 0;
-}
-