Packets: Fix VariantParser invalid parser access bug
[senf.git] / Utils / singleton.test.cc
index fb134af..781d434 100644 (file)
@@ -1,8 +1,8 @@
 // $Id$
 //
-// Copyright (C) 2007 
-// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
-// Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
+// Copyright (C) 2007
+// Fraunhofer Institute for Open Communication Systems (FOKUS)
+// Competence Center NETwork research (NET), St. Augustin, GERMANY
 //     Stefan Bund <g0dil@berlios.de>
 //
 // This program is free software; you can redistribute it and/or modify
 //#include "singleton.test.ih"
 
 // Custom includes
+#include <iostream>
 #include "singleton.hh"
 
-#include <boost/test/auto_unit_test.hpp>
+#include "../Utils/auto_unit_test.hh"
 #include <boost/test/test_tools.hpp>
 
 #define prefix_
 ///////////////////////////////cc.p////////////////////////////////////////
 
 namespace {
-    
+
     class Test : public senf::singleton<Test>
     {
         friend class senf::singleton<Test>;
-        
+
         Test() : foo_(1234) {}
 
         int foo_;
 
     public:
         using senf::singleton<Test>::instance;
+        using senf::singleton<Test>::alive;
 
         int foo() { return foo_; }
     };
@@ -55,6 +57,73 @@ namespace {
 BOOST_AUTO_UNIT_TEST(sInGlEtOn)
 {
     BOOST_CHECK_EQUAL( Test::instance().foo(), 1234 );
+    BOOST_CHECK( Test::alive() );
+}
+
+namespace {
+
+    bool test1Dead (false);
+    bool test2Dead (false);
+
+    bool test1Alive (false);
+    bool test2Alive (false);
+
+    struct AliveTest1 : public senf::singleton<AliveTest1>
+    {
+        friend class senf::singleton<AliveTest1>;
+        using senf::singleton<AliveTest1>::alive;
+        using senf::singleton<AliveTest1>::instance;
+        AliveTest1();
+        ~AliveTest1();
+    };
+
+    struct AliveTest2 : public senf::singleton<AliveTest2>
+    {
+        friend class senf::singleton<AliveTest2>;
+        using senf::singleton<AliveTest2>::alive;
+        using senf::singleton<AliveTest2>::instance;
+        AliveTest2();
+        ~AliveTest2();
+    };
+
+    AliveTest1::AliveTest1() 
+    {
+        test2Alive = AliveTest2::alive();
+    }
+
+    AliveTest1::~AliveTest1()
+    {
+        if (test2Dead) {
+            assert( ! AliveTest2::alive() );
+            std::cerr << "singleton alive test ok\n";
+        }
+        test1Dead = true;
+    }
+
+    AliveTest2::AliveTest2()
+    {
+        test1Alive = AliveTest1::alive();
+    }
+
+    AliveTest2::~AliveTest2()
+    {
+        if (test1Dead) {
+            assert( ! AliveTest1::alive() );
+            std::cerr << "singleton alive test ok\n";
+        }
+        test2Dead = true;
+    }
+
+}
+
+BOOST_AUTO_UNIT_TEST(singletonAlive)
+{
+    (void) AliveTest1::instance();
+    (void) AliveTest2::instance();
+
+    BOOST_CHECK( (test1Alive && !test2Alive) || (!test1Alive && test2Alive) );
+    BOOST_CHECK( AliveTest1::alive() );
+    BOOST_CHECK( AliveTest2::alive() );
 }
 
 ///////////////////////////////cc.e////////////////////////////////////////