2005-09-23 20:14:10 +00:00
|
|
|
#include <string>
|
|
|
|
#include "sh_list.h"
|
2005-10-13 20:46:52 +00:00
|
|
|
#include "sh_stack.h"
|
2005-09-23 20:14:10 +00:00
|
|
|
#include "sh_tinyhash.h"
|
2005-10-12 20:25:15 +00:00
|
|
|
#include "testevents.h"
|
2005-09-23 20:14:10 +00:00
|
|
|
|
|
|
|
// TEST LIST
|
|
|
|
// Tests sh_list, sh_tinyhash, sh_vector
|
|
|
|
|
2005-12-23 23:00:55 +00:00
|
|
|
// :TODO: vector test, list insert test
|
2005-09-23 20:14:10 +00:00
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
struct Hmm
|
|
|
|
{
|
|
|
|
Hmm *m_This;
|
|
|
|
int m_Int;
|
2005-10-03 18:31:44 +00:00
|
|
|
Hmm(const Hmm &other) : m_Int(other.m_Int)
|
2005-09-23 20:14:10 +00:00
|
|
|
{
|
2005-10-03 18:31:44 +00:00
|
|
|
m_This = this;
|
2005-09-23 20:14:10 +00:00
|
|
|
}
|
2005-10-03 18:31:44 +00:00
|
|
|
Hmm(int i) : m_Int(i)
|
2005-09-23 20:14:10 +00:00
|
|
|
{
|
2005-10-03 18:31:44 +00:00
|
|
|
m_This = this;
|
2005-09-23 20:14:10 +00:00
|
|
|
}
|
2005-10-03 18:31:44 +00:00
|
|
|
Hmm() : m_Int(0)
|
2005-09-23 20:14:10 +00:00
|
|
|
{
|
2005-10-03 18:31:44 +00:00
|
|
|
m_This = this;
|
2005-09-23 20:14:10 +00:00
|
|
|
}
|
|
|
|
void operator = (const Hmm &other)
|
|
|
|
{
|
|
|
|
m_Int = other.m_Int;
|
|
|
|
}
|
|
|
|
operator int () const
|
|
|
|
{
|
|
|
|
return m_Int;
|
|
|
|
}
|
|
|
|
};
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
#define LIST_THIS_CHECK(lst, err) \
|
|
|
|
for (ListType::iterator iter = lst.begin(); iter != lst.end(); ++iter) \
|
|
|
|
CHECK_COND(&(*iter) == iter->m_This, err);
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
bool DoTestList(std::string &error)
|
|
|
|
{
|
|
|
|
typedef SourceHook::List<Hmm> ListType;
|
|
|
|
ListType lst;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(lst.empty(), "Part1");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
for (int i = 1; i <= 100; ++i)
|
|
|
|
lst.push_back(i);
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
LIST_THIS_CHECK(lst, "PartA1");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(!lst.empty(), "Part2");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
lst.clear();
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(lst.empty(), "Part3");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
for (int i = 1; i <= 100; ++i)
|
|
|
|
lst.push_back(i);
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(lst.back() == 100, "Part4");
|
|
|
|
LIST_THIS_CHECK(lst, "PartA2");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
int ver = 1;
|
|
|
|
for (ListType::iterator iter = lst.begin(); iter != lst.end(); ++iter)
|
|
|
|
CHECK_COND(*iter == ver++, "Part5");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(ver == 101, "Part 6");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
ListType::iterator iter50 = lst.find(50);
|
|
|
|
CHECK_COND(*iter50 == 50, "Part7");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
iter50 = lst.erase(iter50);
|
|
|
|
CHECK_COND(*iter50 == 51, "Part8");
|
|
|
|
CHECK_COND(*--iter50 == 49, "Part8.2");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
lst.remove(80);
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
ver = 1;
|
|
|
|
for (ListType::iterator iter = lst.begin(); iter != lst.end(); ++iter)
|
|
|
|
{
|
|
|
|
CHECK_COND(*iter == ver++, "Part9");
|
|
|
|
if (ver == 50 || ver == 80)
|
|
|
|
++ver;
|
|
|
|
}
|
|
|
|
CHECK_COND(ver == 101, "Part10");
|
|
|
|
LIST_THIS_CHECK(lst, "PartA3");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
ListType lst2;
|
|
|
|
lst = lst2;
|
|
|
|
CHECK_COND(lst.empty(), "Part11");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
for (int i = 1; i <= 100; ++i)
|
|
|
|
lst.push_back(i);
|
|
|
|
lst2 = lst;
|
|
|
|
CHECK_COND(lst2.size() == 100, "Part11.2");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
LIST_THIS_CHECK(lst, "PartA4");
|
|
|
|
LIST_THIS_CHECK(lst2, "PartA5");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
ver = 1;
|
|
|
|
for (ListType::iterator iter = lst2.begin(); iter != lst2.end(); ++iter)
|
|
|
|
CHECK_COND(*iter == ver++, "Part12");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
lst.clear();
|
|
|
|
for (int i = 401; i <= 500; ++i)
|
|
|
|
lst.push_back(i);
|
|
|
|
lst = lst2;
|
|
|
|
CHECK_COND(lst2.size() == 100, "Part13");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
ver = 1;
|
|
|
|
for (ListType::iterator iter = lst.begin(); iter != lst.end(); ++iter)
|
|
|
|
CHECK_COND(*iter == ver++, "Part14");
|
|
|
|
|
|
|
|
LIST_THIS_CHECK(lst, "PartA6");
|
|
|
|
LIST_THIS_CHECK(lst2, "PartA7");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
return true;
|
|
|
|
}
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
bool DoTestTinyHash(std::string &error)
|
|
|
|
{
|
|
|
|
const int mymax = 5000;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
typedef SourceHook::THash<int, int> HashType;
|
|
|
|
HashType hash;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
for (int i = 1; i <= mymax; ++i)
|
|
|
|
hash[i] = i + 5000;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
for (int i = 1; i <= mymax; ++i)
|
|
|
|
CHECK_COND(hash[i] == i + 5000, "Part1");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
// Find
|
|
|
|
int ver = 1;
|
2005-10-03 18:31:44 +00:00
|
|
|
HashType::iterator iter;
|
|
|
|
for (iter = hash.begin(); iter != hash.end(); ++iter)
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(iter->key == ver && iter->val == (ver++) + 5000, "Part2");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(ver == mymax+1, "Part2.1");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-10-03 18:31:44 +00:00
|
|
|
iter = hash.find(300);
|
2005-09-23 20:14:10 +00:00
|
|
|
CHECK_COND(iter != hash.end() && iter->val == 300+5000, "Part3.1");
|
|
|
|
iter = hash.find(mymax+200);
|
|
|
|
CHECK_COND(iter == hash.end(), "Part3.2");
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
HashType hash2;
|
|
|
|
for (int i = 1; i <= mymax; ++i)
|
|
|
|
hash2[i] = i + 5000;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
|
|
|
hash2.erase(mymax - 100);
|
|
|
|
CHECK_COND(hash2.find(mymax - 101) != hash2.end(), "Part 4.1");
|
|
|
|
CHECK_COND(hash2.find(mymax - 99) != hash2.end(), "Part 4.2");
|
|
|
|
CHECK_COND(hash2.find(mymax - 100) == hash2.end(), "Part 4.3");
|
|
|
|
hash2.erase(mymax - 99);
|
|
|
|
CHECK_COND(hash2.find(mymax - 101) != hash2.end(), "Part 4.4");
|
|
|
|
CHECK_COND(hash2.find(mymax - 99) == hash2.end(), "Part 4.5");
|
|
|
|
CHECK_COND(hash2.find(mymax - 100) == hash2.end(), "Part 4.6");
|
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
return true;
|
|
|
|
}
|
2005-10-13 20:46:52 +00:00
|
|
|
|
|
|
|
bool DoTestStack(std::string &error)
|
|
|
|
{
|
|
|
|
typedef SourceHook::CStack<int> IntStack;
|
|
|
|
IntStack stk;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
CHECK_COND(stk.size() == 0 && stk.empty(), "A0");
|
|
|
|
|
|
|
|
for (i = 0; i < 5000; ++i)
|
|
|
|
stk.push(i);
|
|
|
|
|
|
|
|
CHECK_COND(stk.front() == 4999, "1");
|
|
|
|
CHECK_COND(stk.size() == 5000 && !stk.empty(), "A1");
|
|
|
|
|
|
|
|
IntStack::iterator iter;
|
|
|
|
i = 0;
|
|
|
|
for (iter = stk.begin(); iter != stk.end(); ++iter, ++i)
|
|
|
|
CHECK_COND(*iter == i, "2");
|
|
|
|
|
|
|
|
i = 0;
|
|
|
|
for (iter = stk.begin(); iter != stk.end(); iter++, ++i)
|
|
|
|
CHECK_COND(*iter == i, "3");
|
|
|
|
|
|
|
|
--iter;
|
|
|
|
iter--;
|
|
|
|
*iter = 'g'+'a'+'b'+'e'+'n';
|
|
|
|
stk.pop();
|
|
|
|
|
|
|
|
CHECK_COND(stk.size() == 4999 && !stk.empty(), "A2");
|
|
|
|
CHECK_COND(stk.front() == 'g'+'a'+'b'+'e'+'n', "4");
|
|
|
|
|
|
|
|
IntStack stk2(stk);
|
|
|
|
CHECK_COND(stk2.size() == 4999 && !stk2.empty(), "A3");
|
|
|
|
|
|
|
|
IntStack::iterator iter2 = stk2.begin();
|
|
|
|
for (iter = stk.begin(); iter != stk.end(); ++iter, iter2++)
|
|
|
|
CHECK_COND(*iter == *iter2, "5");
|
|
|
|
|
|
|
|
while (!stk2.empty())
|
|
|
|
stk2.pop();
|
|
|
|
CHECK_COND(stk2.size() == 0 && stk2.empty(), "A4");
|
|
|
|
stk = stk2;
|
|
|
|
CHECK_COND(stk.size() == 0 && stk.empty(), "A5");
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2005-09-23 20:14:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool TestList(std::string &error)
|
|
|
|
{
|
|
|
|
if (!DoTestList(error))
|
|
|
|
return false;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
if (!DoTestTinyHash(error))
|
|
|
|
return false;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-10-13 20:46:52 +00:00
|
|
|
if (!DoTestStack(error))
|
|
|
|
return false;
|
2005-10-03 17:20:22 +00:00
|
|
|
|
2005-09-23 20:14:10 +00:00
|
|
|
return true;
|
|
|
|
}
|