*/
-/* $Core */
-
#include "inspircd.h"
#include "testsuite.h"
#include "threadengine.h"
#include <iostream>
-using namespace std;
-
class TestSuiteThread : public Thread
{
public:
{
while (GetExitFlag() == false)
{
- cout << "Test suite thread run...\n";
+ std::cout << "Test suite thread run...\n";
sleep(5);
}
}
TestSuite::TestSuite()
{
- cout << "\n\n*** STARTING TESTSUITE ***\n";
+ std::cout << "\n\n*** STARTING TESTSUITE ***\n";
std::string modname;
char choice;
while (1)
{
- cout << "(1) Call all module OnRunTestSuite() methods\n";
- cout << "(2) Load a module\n";
- cout << "(3) Unload a module\n";
- cout << "(4) Threading tests\n";
- cout << "(5) Wildcard and CIDR tests\n";
- cout << "(6) Comma sepstream tests\n";
- cout << "(7) Space sepstream tests\n";
+ std::cout << "(1) Call all module OnRunTestSuite() methods\n";
+ std::cout << "(2) Load a module\n";
+ std::cout << "(3) Unload a module\n";
+ std::cout << "(4) Threading tests\n";
+ std::cout << "(5) Wildcard and CIDR tests\n";
+ std::cout << "(6) Comma sepstream tests\n";
+ std::cout << "(7) Space sepstream tests\n";
+ std::cout << "(8) UID generation tests\n";
- cout << endl << "(X) Exit test suite\n";
+ std::cout << std::endl << "(X) Exit test suite\n";
- cout << "\nChoices (Enter one or more options as a list then press enter, e.g. 15X): ";
- cin >> choice;
+ std::cout << "\nChoices (Enter one or more options as a list then press enter, e.g. 15X): ";
+ std::cin >> choice;
if (!choice)
continue;
switch (choice)
{
case '1':
- FOREACH_MOD(I_OnRunTestSuite, OnRunTestSuite());
+ FOREACH_MOD(OnRunTestSuite, ());
break;
case '2':
- cout << "Enter module filename to load: ";
- cin >> modname;
- cout << (ServerInstance->Modules->Load(modname.c_str()) ? "\nSUCCESS!\n" : "\nFAILURE\n");
+ std::cout << "Enter module filename to load: ";
+ std::cin >> modname;
+ std::cout << (ServerInstance->Modules->Load(modname.c_str()) ? "\nSUCCESS!\n" : "\nFAILURE\n");
break;
case '3':
- cout << "Enter module filename to unload: ";
- cin >> modname;
+ std::cout << "Enter module filename to unload: ";
+ std::cin >> modname;
{
Module* m = ServerInstance->Modules->Find(modname);
- cout << (ServerInstance->Modules->Unload(m) ? "\nSUCCESS!\n" : "\nFAILURE\n");
+ std::cout << (ServerInstance->Modules->Unload(m) ? "\nSUCCESS!\n" : "\nFAILURE\n");
ServerInstance->AtomicActions.Run();
}
break;
case '4':
- cout << (DoThreadTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
+ std::cout << (DoThreadTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
break;
case '5':
- cout << (DoWildTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
+ std::cout << (DoWildTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
break;
case '6':
- cout << (DoCommaSepStreamTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
+ std::cout << (DoCommaSepStreamTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
break;
case '7':
- cout << (DoSpaceSepStreamTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
+ std::cout << (DoSpaceSepStreamTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
+ break;
+ case '8':
+ std::cout << (DoGenerateUIDTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
break;
case 'X':
return;
break;
default:
- cout << "Invalid option\n";
+ std::cout << "Invalid option\n";
break;
}
- cout << endl;
+ std::cout << std::endl;
}
}
/* Test that x matches y with match() */
-#define WCTEST(x, y) cout << "match(\"" << x << "\",\"" << y "\") " << ((passed = (InspIRCd::Match(x, y, NULL))) ? " SUCCESS!\n" : " FAILURE\n")
+#define WCTEST(x, y) std::cout << "match(\"" << x << "\",\"" << y "\") " << ((passed = (InspIRCd::Match(x, y, NULL))) ? " SUCCESS!\n" : " FAILURE\n")
/* Test that x does not match y with match() */
-#define WCTESTNOT(x, y) cout << "!match(\"" << x << "\",\"" << y "\") " << ((passed = ((!InspIRCd::Match(x, y, NULL)))) ? " SUCCESS!\n" : " FAILURE\n")
+#define WCTESTNOT(x, y) std::cout << "!match(\"" << x << "\",\"" << y "\") " << ((passed = ((!InspIRCd::Match(x, y, NULL)))) ? " SUCCESS!\n" : " FAILURE\n")
/* Test that x matches y with match() and cidr enabled */
-#define CIDRTEST(x, y) cout << "match(\"" << x << "\",\"" << y "\", true) " << ((passed = (InspIRCd::MatchCIDR(x, y, NULL))) ? " SUCCESS!\n" : " FAILURE\n")
+#define CIDRTEST(x, y) std::cout << "match(\"" << x << "\",\"" << y "\", true) " << ((passed = (InspIRCd::MatchCIDR(x, y, NULL))) ? " SUCCESS!\n" : " FAILURE\n")
/* Test that x does not match y with match() and cidr enabled */
-#define CIDRTESTNOT(x, y) cout << "!match(\"" << x << "\",\"" << y "\", true) " << ((passed = ((!InspIRCd::MatchCIDR(x, y, NULL)))) ? " SUCCESS!\n" : " FAILURE\n")
+#define CIDRTESTNOT(x, y) std::cout << "!match(\"" << x << "\",\"" << y "\", true) " << ((passed = ((!InspIRCd::MatchCIDR(x, y, NULL)))) ? " SUCCESS!\n" : " FAILURE\n")
bool TestSuite::DoWildTests()
{
- cout << "\n\nWildcard and CIDR tests\n\n";
+ std::cout << "\n\nWildcard and CIDR tests\n\n";
bool passed = false;
WCTEST("foobar", "*");
}
-#define STREQUALTEST(x, y) cout << "==(\"" << x << ",\"" << y "\") " << ((passed = (x == y)) ? "SUCCESS\n" : "FAILURE\n")
+#define STREQUALTEST(x, y) std::cout << "==(\"" << x << ",\"" << y "\") " << ((passed = (x == y)) ? "SUCCESS\n" : "FAILURE\n")
bool TestSuite::DoCommaSepStreamTests()
{
STREQUALTEST(item, "stream");
break;
default:
- cout << "COMMASEPSTREAM: FAILURE: Got an index too many! " << idx << " items\n";
+ std::cout << "COMMASEPSTREAM: FAILURE: Got an index too many! " << idx << " items\n";
break;
}
}
STREQUALTEST(item, "stream");
break;
default:
- cout << "SPACESEPSTREAM: FAILURE: Got an index too many! " << idx << " items\n";
+ std::cout << "SPACESEPSTREAM: FAILURE: Got an index too many! " << idx << " items\n";
break;
}
}
std::string anything;
ThreadEngine* te = NULL;
- cout << "Creating new ThreadEngine class...\n";
+ std::cout << "Creating new ThreadEngine class...\n";
try
{
te = new ThreadEngine;
}
catch (...)
{
- cout << "Creation failed, test failure.\n";
+ std::cout << "Creation failed, test failure.\n";
return false;
}
- cout << "Creation success, type " << te->GetName() << "\n";
+ std::cout << "Creation success, type " << te->GetName() << "\n";
- cout << "Allocate: new TestSuiteThread...\n";
+ std::cout << "Allocate: new TestSuiteThread...\n";
TestSuiteThread* tst = new TestSuiteThread();
- cout << "ThreadEngine::Create on TestSuiteThread...\n";
+ std::cout << "ThreadEngine::Create on TestSuiteThread...\n";
try
{
try
}
catch (CoreException &ce)
{
- cout << "Failure: " << ce.GetReason() << endl;
+ std::cout << "Failure: " << ce.GetReason() << std::endl;
}
}
catch (...)
{
- cout << "Failure, unhandled exception\n";
+ std::cout << "Failure, unhandled exception\n";
}
- cout << "Type any line and press enter to end test.\n";
- cin >> anything;
+ std::cout << "Type any line and press enter to end test.\n";
+ std::cin >> anything;
/* Thread engine auto frees thread on delete */
- cout << "Waiting for thread to exit... " << flush;
+ std::cout << "Waiting for thread to exit... " << std::flush;
delete tst;
- cout << "Done!\n";
+ std::cout << "Done!\n";
- cout << "Delete ThreadEngine... ";
+ std::cout << "Delete ThreadEngine... ";
delete te;
- cout << "Done!\n";
+ std::cout << "Done!\n";
+
+ return true;
+}
+
+bool TestSuite::DoGenerateUIDTests()
+{
+ const unsigned int UUID_LENGTH = UIDGenerator::UUID_LENGTH;
+ UIDGenerator uidgen;
+ uidgen.init(ServerInstance->Config->GetSID());
+ std::string first_uid = uidgen.GetUID();
+
+ if (first_uid.length() != UUID_LENGTH)
+ {
+ std::cout << "GENERATEUID: Generated UID is " << first_uid.length() << " characters long instead of " << UUID_LENGTH-1 << std::endl;
+ return false;
+ }
+
+ if (uidgen.current_uid.c_str()[UUID_LENGTH] != '\0')
+ {
+ std::cout << "GENERATEUID: The null terminator is missing from the end of current_uid" << std::endl;
+ return false;
+ }
+
+ // The correct UID when generating one for the first time is ...AAAAAA
+ std::string correct_uid = ServerInstance->Config->sid + std::string(UUID_LENGTH - 3, 'A');
+ if (first_uid != correct_uid)
+ {
+ std::cout << "GENERATEUID: Generated an invalid first UID: " << first_uid << " instead of " << correct_uid << std::endl;
+ return false;
+ }
+
+ // Set current_uid to be ...Z99999
+ uidgen.current_uid[3] = 'Z';
+ for (unsigned int i = 4; i < UUID_LENGTH; i++)
+ uidgen.current_uid[i] = '9';
+
+ // Store the UID we'll be incrementing so we can display what's wrong later if necessary
+ std::string before_increment(uidgen.current_uid);
+ std::string generated_uid = uidgen.GetUID();
+
+ // Correct UID after incrementing ...Z99999 is ...0AAAAA
+ correct_uid = ServerInstance->Config->sid + "0" + std::string(UUID_LENGTH - 4, 'A');
+
+ if (generated_uid != correct_uid)
+ {
+ std::cout << "GENERATEUID: Generated an invalid UID after incrementing " << before_increment << ": " << generated_uid << " instead of " << correct_uid << std::endl;
+ return false;
+ }
+
+ // Set current_uid to be ...999999 to see if it rolls over correctly
+ for (unsigned int i = 3; i < UUID_LENGTH; i++)
+ uidgen.current_uid[i] = '9';
+
+ before_increment.assign(uidgen.current_uid);
+ generated_uid = uidgen.GetUID();
+
+ // Correct UID after rolling over is the first UID we've generated (...AAAAAA)
+ if (generated_uid != first_uid)
+ {
+ std::cout << "GENERATEUID: Generated an invalid UID after incrementing " << before_increment << ": " << generated_uid << " instead of " << first_uid << std::endl;
+ return false;
+ }
return true;
}
TestSuite::~TestSuite()
{
- cout << "\n\n*** END OF TEST SUITE ***\n";
+ std::cout << "\n\n*** END OF TEST SUITE ***\n";
}