#include #include #include using namespace Passenger; using namespace std; namespace tut { struct DataStructures_StringKeyTableTest { StringKeyTable table; string *value; DataStructures_StringKeyTableTest() { value = NULL; } }; DEFINE_TEST_GROUP(DataStructures_StringKeyTableTest); TEST_METHOD(1) { set_test_name("Initial state"); ensure_equals(table.size(), 0u); ensure_equals(table.arraySize(), (unsigned int) StringKeyTable::DEFAULT_SIZE); } TEST_METHOD(2) { set_test_name("On an empty StringKeyTable, iterators reach the end immediately"); StringKeyTable::Iterator it(table); ensure_equals(*it, NULL); } TEST_METHOD(3) { set_test_name("On an empty StringKeyTable, lookups return NULL"); ensure(!table.lookup("hello", &value)); ensure_equals(value, NULL); ensure(!table.lookup("?", &value)); ensure_equals(value, NULL); ensure(!table.lookupRandom(NULL, &value)); ensure_equals(value, NULL); } TEST_METHOD(4) { set_test_name("Insertions work"); table.insert("Content-Length", "5"); ensure_equals(table.size(), 1u); ensure(!table.lookup("hello", &value)); ensure_equals("(1)", value, NULL); ensure(!table.lookup("Host", &value)); ensure_equals("(2)", value, NULL); ensure(table.lookup("Content-Length", &value)); ensure_equals("(3)", *value, "5"); table.insert("Host", "foo.com"); ensure_equals(table.size(), 2u); ensure(!table.lookup("hello", &value)); ensure_equals("(5)", value, NULL); ensure(table.lookup("Host", &value)); ensure_equals("(6)", *value, "foo.com"); ensure(table.lookup("Content-Length", &value)); ensure_equals("(7)", *value, "5"); } TEST_METHOD(5) { set_test_name("Large amounts of insertions"); table.insert("Host", "foo.com"); table.insert("Content-Length", "5"); table.insert("Accept", "text/html"); table.insert("Accept-Encoding", "gzip"); table.insert("Accept-Language", "nl"); table.insert("User-Agent", "Mozilla"); table.insert("Set-Cookie", "foo=bar"); table.insert("Connection", "keep-alive"); table.insert("Cache-Control", "no-cache"); table.insert("Pragma", "no-cache"); ensure(!table.lookup("MyHeader", &value)); ensure(table.lookup("Host", &value)); ensure_equals(*value, "foo.com"); ensure(table.lookup("Content-Length", &value)); ensure_equals(*value, "5"); ensure(table.lookup("Accept", &value)); ensure_equals(*value, "text/html"); ensure(table.lookup("Accept-Encoding", &value)); ensure_equals(*value, "gzip"); ensure(table.lookup("Accept-Language", &value)); ensure_equals(*value, "nl"); ensure(table.lookup("User-Agent", &value)); ensure_equals(*value, "Mozilla"); ensure(table.lookup("Set-Cookie", &value)); ensure_equals(*value, "foo=bar"); ensure(table.lookup("Connection", &value)); ensure_equals(*value, "keep-alive"); ensure(table.lookup("Cache-Control", &value)); ensure_equals(*value, "no-cache"); ensure(table.lookup("Pragma", &value)); ensure_equals(*value, "no-cache"); } TEST_METHOD(6) { set_test_name("Iterators work"); table.insert("Content-Length", "5"); table.insert("Host", "foo.com"); StringKeyTable::Iterator it(table); ensure(*it != NULL); if (it.getKey() == "Content-Length") { ensure_equals(it.getKey(), "Content-Length"); it.next(); ensure_equals(it.getKey(), "Host"); } else { ensure_equals(it.getKey(), "Host"); it.next(); ensure_equals(it.getKey(), "Content-Length"); } it.next(); ensure_equals(*it, NULL); } TEST_METHOD(7) { set_test_name("Dynamically growing the bucket on insert"); table = StringKeyTable(4); ensure_equals(table.size(), 0u); ensure_equals(table.arraySize(), 4u); table.insert("Host", "foo.com"); table.insert("Content-Length", "5"); ensure_equals(table.size(), 2u); ensure_equals(table.arraySize(), 4u); table.insert("Accept", "text/html"); ensure_equals(table.size(), 3u); ensure_equals(table.arraySize(), 8u); ensure(!table.lookup("MyHeader", &value)); ensure_equals(value, NULL); ensure(table.lookup("Host", &value)); ensure_equals(*value, "foo.com"); ensure(table.lookup("Content-Length", &value)); ensure_equals(*value, "5"); ensure(table.lookup("Accept", &value)); ensure_equals(*value, "text/html"); } TEST_METHOD(8) { set_test_name("Clearing"); table.insert("Host", "foo.com"); table.insert("Content-Length", "5"); table.insert("Accept", "text/html"); table.clear(); ensure_equals(table.size(), 0u); ensure_equals(table.arraySize(), (unsigned int) StringKeyTable::DEFAULT_SIZE); ensure(!table.lookup("Host", &value)); ensure_equals(value, NULL); ensure(!table.lookup("Content-Length", &value)); ensure_equals(value, NULL); ensure(!table.lookup("Accept", &value)); ensure_equals(value, NULL); } TEST_METHOD(9) { set_test_name("lookupRandom() works"); HashedStaticString key; table.insert("a", "1"); ensure(table.lookupRandom(&key, &value)); ensure_equals(key, "a"); ensure_equals(*value, "1"); table.insert("b", "2"); ensure(table.lookupRandom(&key, &value)); ensure_equals(key, "b"); ensure_equals(*value, "2"); table.insert("c", "3"); ensure(table.lookupRandom(&key, &value)); ensure_equals(key, "c"); ensure_equals(*value, "3"); ensure(table.erase("b")); ensure(table.lookupRandom(&key, &value)); ensure_equals(key, "c"); ensure_equals(*value, "3"); ensure(table.erase("c")); ensure(table.lookupRandom(&key, &value)); ensure_equals(key, "a"); ensure_equals(*value, "1"); ensure(table.erase("a")); ensure(!table.lookupRandom(&key, &value)); } }