]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/testsuite.cpp
Change the syntax of FOREACH macros to be less dumb.
[user/henk/code/inspircd.git] / src / testsuite.cpp
index 59e6102e7bcc6ea09d849dbadeeb827c8e5d4f04..b27f6e18c991d7e685a6ba202230f525d6acd669 100644 (file)
  */
 
 
-/* $Core */
-
 #include "inspircd.h"
 #include "testsuite.h"
 #include "threadengine.h"
 #include <iostream>
 
-using namespace std;
-
 class TestSuiteThread : public Thread
 {
  public:
@@ -43,7 +39,7 @@ class TestSuiteThread : public Thread
        {
                while (GetExitFlag() == false)
                {
-                       cout << "Test suite thread run...\n";
+                       std::cout << "Test suite thread run...\n";
                        sleep(5);
                }
        }
@@ -51,26 +47,26 @@ class TestSuiteThread : public Thread
 
 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";
-               cout << "(8) UID generation 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;
@@ -78,61 +74,61 @@ TestSuite::TestSuite()
                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':
-                               cout << (DoGenerateUIDTests() ? "\nSUCCESS!\n" : "\nFAILURE\n");
+                               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", "*");
@@ -203,7 +199,7 @@ bool TestSuite::DoWildTests()
 }
 
 
-#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()
 {
@@ -234,7 +230,7 @@ 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;
                }
        }
@@ -272,7 +268,7 @@ bool TestSuite::DoSpaceSepStreamTests()
                                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;
                }
        }
@@ -284,22 +280,22 @@ bool TestSuite::DoThreadTests()
        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
@@ -308,96 +304,85 @@ bool TestSuite::DoThreadTests()
                }
                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()
 {
-       bool success = RealGenerateUIDTests();
-
-       // Reset the UID generation state so running the tests multiple times won't mess things up
-       for (unsigned int i = 0; i < 3; i++)
-               ServerInstance->current_uid[i] = ServerInstance->Config->sid[i];
-       for (unsigned int i = 3; i < UUID_LENGTH-1; i++)
-               ServerInstance->current_uid[i] = '9';
-
-       ServerInstance->current_uid[UUID_LENGTH-1] = '\0';
+       const unsigned int UUID_LENGTH = UIDGenerator::UUID_LENGTH;
+       UIDGenerator uidgen;
+       uidgen.init(ServerInstance->Config->GetSID());
+       std::string first_uid = uidgen.GetUID();
 
-       return success;
-}
-
-bool TestSuite::RealGenerateUIDTests()
-{
-       std::string first_uid = ServerInstance->GetUID();
-       if (first_uid.length() != UUID_LENGTH-1)
+       if (first_uid.length() != UUID_LENGTH)
        {
-               cout << "GENERATEUID: Generated UID is " << first_uid.length() << " characters long instead of " << UUID_LENGTH-1 << endl;
+               std::cout << "GENERATEUID: Generated UID is " << first_uid.length() << " characters long instead of " << UUID_LENGTH-1 << std::endl;
                return false;
        }
 
-       if (ServerInstance->current_uid[UUID_LENGTH-1] != '\0')
+       if (uidgen.current_uid.c_str()[UUID_LENGTH] != '\0')
        {
-               cout << "GENERATEUID: The null terminator is missing from the end of current_uid" << endl;
+               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 - 4, 'A');
+       std::string correct_uid = ServerInstance->Config->sid + std::string(UUID_LENGTH - 3, 'A');
        if (first_uid != correct_uid)
        {
-               cout << "GENERATEUID: Generated an invalid first UID: " << first_uid << " instead of " << correct_uid << endl;
+               std::cout << "GENERATEUID: Generated an invalid first UID: " << first_uid << " instead of " << correct_uid << std::endl;
                return false;
        }
 
        // Set current_uid to be ...Z99999
-       ServerInstance->current_uid[3] = 'Z';
-       for (unsigned int i = 4; i < UUID_LENGTH-1; i++)
-               ServerInstance->current_uid[i] = '9';
+       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(ServerInstance->current_uid);
-       std::string generated_uid = ServerInstance->GetUID();
+       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 - 5, 'A');
+       correct_uid = ServerInstance->Config->sid + "0" + std::string(UUID_LENGTH - 4, 'A');
 
        if (generated_uid != correct_uid)
        {
-               cout << "GENERATEUID: Generated an invalid UID after incrementing " << before_increment << ": " << generated_uid << " instead of " << correct_uid << endl;
+               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-1; i++)
-               ServerInstance->current_uid[i] = '9';
+       for (unsigned int i = 3; i < UUID_LENGTH; i++)
+               uidgen.current_uid[i] = '9';
 
-       before_increment.assign(ServerInstance->current_uid);
-       generated_uid = ServerInstance->GetUID();
+       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)
        {
-               cout << "GENERATEUID: Generated an invalid UID after incrementing " << before_increment << ": " << generated_uid << " instead of " << first_uid << endl;
+               std::cout << "GENERATEUID: Generated an invalid UID after incrementing " << before_increment << ": " << generated_uid << " instead of " << first_uid << std::endl;
                return false;
        }
 
@@ -406,6 +391,6 @@ bool TestSuite::RealGenerateUIDTests()
 
 TestSuite::~TestSuite()
 {
-       cout << "\n\n*** END OF TEST SUITE ***\n";
+       std::cout << "\n\n*** END OF TEST SUITE ***\n";
 }