[Orxonox-commit 4970] r9639 - in code/branches/core6/test/core: . class

landauf at orxonox.net landauf at orxonox.net
Sun Aug 11 18:30:05 CEST 2013


Author: landauf
Date: 2013-08-11 18:30:05 +0200 (Sun, 11 Aug 2013)
New Revision: 9639

Added:
   code/branches/core6/test/core/class/IdentifierClassHierarchyTest.cc
Modified:
   code/branches/core6/test/core/CMakeLists.txt
   code/branches/core6/test/core/class/IdentifierExternalClassHierarchyTest.cc
   code/branches/core6/test/core/class/IdentifierSimpleClassHierarchyTest.cc
Log:
added tests

Modified: code/branches/core6/test/core/CMakeLists.txt
===================================================================
--- code/branches/core6/test/core/CMakeLists.txt	2013-08-11 15:52:29 UTC (rev 9638)
+++ code/branches/core6/test/core/CMakeLists.txt	2013-08-11 16:30:05 UTC (rev 9639)
@@ -9,6 +9,7 @@
     ${GMOCK_MAIN}
     class/IdentifiableTest.cc
     class/IdentifierTest.cc
+    class/IdentifierClassHierarchyTest.cc
     class/IdentifierSimpleClassHierarchyTest.cc
     class/IdentifierExternalClassHierarchyTest.cc
     class/OrxonoxClassTest.cc

Added: code/branches/core6/test/core/class/IdentifierClassHierarchyTest.cc
===================================================================
--- code/branches/core6/test/core/class/IdentifierClassHierarchyTest.cc	                        (rev 0)
+++ code/branches/core6/test/core/class/IdentifierClassHierarchyTest.cc	2013-08-11 16:30:05 UTC (rev 9639)
@@ -0,0 +1,231 @@
+#include <gtest/gtest.h>
+#include "core/CoreIncludes.h"
+#include "core/class/Identifiable.h"
+#include "core/class/OrxonoxClass.h"
+#include "core/class/OrxonoxInterface.h"
+
+namespace orxonox
+{
+    //                 +------ Class0
+    // BaseClass <-----+---------------------+--- Class1
+    //                 +---------------------+-+- Class2a
+    //                 +---------------------+-+- Class2b
+    //                 +-+-+-- Class3        | |
+    //                   | |                 | |
+    // BaseInterface1 <--+---- Interface1 <--´ |
+    //                     |                   |
+    // BaseInterface2 <----+-- Interface2 <----´
+
+    namespace
+    {
+        class BaseInterface1 : public OrxonoxInterface
+            { public: BaseInterface1() { RegisterRootObject(BaseInterface1); } };
+
+        class BaseInterface2 : public OrxonoxInterface
+            { public: BaseInterface2() { RegisterRootObject(BaseInterface2); } };
+
+        class Interface1 : public BaseInterface1
+            { public: Interface1() { RegisterObject(Interface1); } };
+
+        class Interface2 : public BaseInterface2
+            { public: Interface2() { RegisterObject(Interface2); } };
+
+        class BaseClass : public OrxonoxClass
+            { public: BaseClass() { RegisterRootObject(BaseClass); } };
+
+        class Class0 : public BaseClass
+            { public: Class0() { RegisterObject(Class0); } };
+
+        class Class1 : public BaseClass, public Interface1
+            { public: Class1() { RegisterObject(Class1); } };
+
+        class Class2a : public BaseClass, public Interface1, Interface2
+            { public: Class2a() { RegisterObject(Class2a); } };
+
+        class Class2b : public BaseClass, public Interface2, Interface1
+            { public: Class2b() { RegisterObject(Class2b); } };
+
+        class Class3 : public BaseClass, public BaseInterface1, BaseInterface2
+            { public: Class3() { RegisterObject(Class3); } };
+
+        // Fixture
+        class IdentifierClassHierarchyTest : public ::testing::Test
+        {
+            public:
+                virtual void SetUp()
+                {
+                    registerClass("BaseInterface1", new ClassFactoryNoArgs<BaseInterface1>());
+                    registerClass("BaseInterface2", new ClassFactoryNoArgs<BaseInterface2>());
+                    registerClass("Interface1", new ClassFactoryNoArgs<Interface1>());
+                    registerClass("Interface2", new ClassFactoryNoArgs<Interface2>());
+                    registerClass("BaseClass", new ClassFactoryNoArgs<BaseClass>());
+                    registerClass("Class0", new ClassFactoryNoArgs<Class0>());
+                    registerClass("Class1", new ClassFactoryNoArgs<Class1>());
+                    registerClass("Class2a", new ClassFactoryNoArgs<Class2a>());
+                    registerClass("Class2b", new ClassFactoryNoArgs<Class2b>());
+                    registerClass("Class3", new ClassFactoryNoArgs<Class3>());
+
+                    IdentifierManager::createClassHierarchy();
+                }
+
+                virtual void TearDown()
+                {
+                    IdentifierManager::destroyAllIdentifiers();
+                }
+        };
+    }
+
+    TEST(IdentifierClassHierarchyTest_NoFixture, NoInitialization)
+    {
+        {
+            Identifier* identifier = Class(BaseInterface1);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(BaseInterface2);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(Interface1);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(Interface2);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(BaseClass);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(Class0);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(Class1);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(Class2a);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(Class2b);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+        {
+            Identifier* identifier = Class(Class3);
+            EXPECT_EQ(0u, identifier->getChildren().size());
+            EXPECT_EQ(0u, identifier->getParents().size());
+        }
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestBaseInterface1)
+    {
+        Identifier* identifier = Class(BaseInterface1);
+
+        EXPECT_EQ(2u, identifier->getDirectChildren().size());
+        EXPECT_EQ(5u, identifier->getChildren().size());
+        EXPECT_EQ(0u, identifier->getDirectParents().size());
+        EXPECT_EQ(0u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestBaseInterface2)
+    {
+        Identifier* identifier = Class(BaseInterface2);
+
+        EXPECT_EQ(2u, identifier->getDirectChildren().size());
+        EXPECT_EQ(4u, identifier->getChildren().size());
+        EXPECT_EQ(0u, identifier->getDirectParents().size());
+        EXPECT_EQ(0u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestInterface1)
+    {
+        Identifier* identifier = Class(Interface1);
+
+        EXPECT_EQ(3u, identifier->getDirectChildren().size());
+        EXPECT_EQ(3u, identifier->getChildren().size());
+        EXPECT_EQ(1u, identifier->getDirectParents().size());
+        EXPECT_EQ(1u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestInterface2)
+    {
+        Identifier* identifier = Class(Interface2);
+
+        EXPECT_EQ(2u, identifier->getDirectChildren().size());
+        EXPECT_EQ(2u, identifier->getChildren().size());
+        EXPECT_EQ(1u, identifier->getDirectParents().size());
+        EXPECT_EQ(1u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestBaseClass)
+    {
+        Identifier* identifier = Class(BaseClass);
+
+        EXPECT_EQ(5u, identifier->getDirectChildren().size());
+        EXPECT_EQ(5u, identifier->getChildren().size());
+        EXPECT_EQ(0u, identifier->getDirectParents().size());
+        EXPECT_EQ(0u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestClass0)
+    {
+        Identifier* identifier = Class(Class0);
+
+        EXPECT_EQ(0u, identifier->getDirectChildren().size());
+        EXPECT_EQ(0u, identifier->getChildren().size());
+        EXPECT_EQ(1u, identifier->getDirectParents().size());
+        EXPECT_EQ(1u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestClass1)
+    {
+        Identifier* identifier = Class(Class1);
+
+        EXPECT_EQ(0u, identifier->getDirectChildren().size());
+        EXPECT_EQ(0u, identifier->getChildren().size());
+        EXPECT_EQ(2u, identifier->getDirectParents().size());
+        EXPECT_EQ(3u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestClass2a)
+    {
+        Identifier* identifier = Class(Class2a);
+
+        EXPECT_EQ(0u, identifier->getDirectChildren().size());
+        EXPECT_EQ(0u, identifier->getChildren().size());
+        EXPECT_EQ(3u, identifier->getDirectParents().size());
+        EXPECT_EQ(5u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestClass2b)
+    {
+        Identifier* identifier = Class(Class2b);
+
+        EXPECT_EQ(0u, identifier->getDirectChildren().size());
+        EXPECT_EQ(0u, identifier->getChildren().size());
+        EXPECT_EQ(3u, identifier->getDirectParents().size());
+        EXPECT_EQ(5u, identifier->getParents().size());
+    }
+
+    TEST_F(IdentifierClassHierarchyTest, TestClass3)
+    {
+        Identifier* identifier = Class(Class3);
+
+        EXPECT_EQ(0u, identifier->getDirectChildren().size());
+        EXPECT_EQ(0u, identifier->getChildren().size());
+        EXPECT_EQ(3u, identifier->getDirectParents().size());
+        EXPECT_EQ(3u, identifier->getParents().size());
+    }
+}


Property changes on: code/branches/core6/test/core/class/IdentifierClassHierarchyTest.cc
___________________________________________________________________
Added: svn:eol-style
   + native

Modified: code/branches/core6/test/core/class/IdentifierExternalClassHierarchyTest.cc
===================================================================
--- code/branches/core6/test/core/class/IdentifierExternalClassHierarchyTest.cc	2013-08-11 15:52:29 UTC (rev 9638)
+++ code/branches/core6/test/core/class/IdentifierExternalClassHierarchyTest.cc	2013-08-11 16:30:05 UTC (rev 9639)
@@ -24,6 +24,7 @@
                     registerClass("Interface", new ClassFactoryNoArgs<Interface>());
                     registerClass("BaseClass", new ClassFactoryNoArgs<BaseClass>());
                     registerClass("RealClass", new ClassFactoryNoArgs<RealClass>());
+
                     IdentifierManager::createClassHierarchy();
                 }
 

Modified: code/branches/core6/test/core/class/IdentifierSimpleClassHierarchyTest.cc
===================================================================
--- code/branches/core6/test/core/class/IdentifierSimpleClassHierarchyTest.cc	2013-08-11 15:52:29 UTC (rev 9638)
+++ code/branches/core6/test/core/class/IdentifierSimpleClassHierarchyTest.cc	2013-08-11 16:30:05 UTC (rev 9639)
@@ -26,6 +26,7 @@
                     registerClass("Interface", new ClassFactoryNoArgs<Interface>());
                     registerClass("BaseClass", new ClassFactoryNoArgs<BaseClass>());
                     registerClass("RealClass", new ClassFactoryNoArgs<RealClass>());
+
                     IdentifierManager::createClassHierarchy();
                 }
 




More information about the Orxonox-commit mailing list