summaryrefslogtreecommitdiff
path: root/test/core
diff options
context:
space:
mode:
authorAndreas Stöckel <astoecke@techfak.uni-bielefeld.de>2014-12-16 02:10:53 +0100
committerAndreas Stöckel <astoecke@techfak.uni-bielefeld.de>2014-12-16 02:10:53 +0100
commitabbfae912b8d54106dbcbb7260c10e3a204c9f93 (patch)
tree8081a182e815484543e43e1133dc0596edc5228f /test/core
parent84cbdcaba520f89eb3ddbdaf1fe2ab3db412501a (diff)
added possibility to register a ManagedType for a class derived from Managed, improved Managed readData function
Diffstat (limited to 'test/core')
-rw-r--r--test/core/managed/ManagedTest.cpp76
1 files changed, 74 insertions, 2 deletions
diff --git a/test/core/managed/ManagedTest.cpp b/test/core/managed/ManagedTest.cpp
index 707aeb9..e21adb6 100644
--- a/test/core/managed/ManagedTest.cpp
+++ b/test/core/managed/ManagedTest.cpp
@@ -30,12 +30,12 @@ TEST(Managed, data)
Rooted<Managed> n{new Managed{mgr}};
- Managed *m1 = new Managed{mgr};
+ Rooted<Managed> m1{new Managed{mgr}};
n->storeData("info", m1);
ASSERT_TRUE(n->hasDataKey("info"));
ASSERT_FALSE(n->hasDataKey("test"));
- Managed *m2 = new Managed{mgr};
+ Rooted<Managed> m2{new Managed{mgr}};
n->storeData("test", m2);
ASSERT_TRUE(n->hasDataKey("info"));
ASSERT_TRUE(n->hasDataKey("test"));
@@ -44,6 +44,78 @@ TEST(Managed, data)
ASSERT_FALSE(n->deleteData("info"));
ASSERT_FALSE(n->hasDataKey("info"));
ASSERT_TRUE(n->hasDataKey("test"));
+
+ n->storeData("info2", m1);
+
+ std::map<std::string, Rooted<Managed>> m = n->readData();
+ ASSERT_TRUE(m.find("info2") != m.end());
+ ASSERT_TRUE(m.find("test") != m.end());
+
+ ASSERT_EQ(m1, m.find("info2")->second);
+ ASSERT_EQ(m2, m.find("test")->second);
+}
+
+class TypeTestManaged1 : public Managed {
+ using Managed::Managed;
+};
+
+class TypeTestManaged2 : public Managed {
+ using Managed::Managed;
+};
+
+class TypeTestManaged3 : public Managed {
+ using Managed::Managed;
+};
+
+class TypeTestManaged4 : public Managed {
+ using Managed::Managed;
+};
+
+class TypeTestManaged5 : public Managed {
+ using Managed::Managed;
+};
+
+ManagedType Type1("Type1", typeid(TypeTestManaged1));
+ManagedType Type2("Type2", typeid(TypeTestManaged2));
+ManagedType Type3("Type3", typeid(TypeTestManaged3), {&Type1});
+ManagedType Type4("Type2", typeid(TypeTestManaged4), {&Type3, &Type2});
+
+TEST(ManagedType, isa) {
+ ASSERT_TRUE(Type1.isa(Type1));
+ ASSERT_FALSE(Type1.isa(Type2));
+ ASSERT_FALSE(Type1.isa(Type3));
+ ASSERT_FALSE(Type1.isa(Type4));
+
+ ASSERT_FALSE(Type2.isa(Type1));
+ ASSERT_TRUE(Type2.isa(Type2));
+ ASSERT_FALSE(Type2.isa(Type3));
+ ASSERT_FALSE(Type2.isa(Type4));
+
+ ASSERT_TRUE(Type3.isa(Type1));
+ ASSERT_FALSE(Type3.isa(Type2));
+ ASSERT_TRUE(Type3.isa(Type3));
+ ASSERT_FALSE(Type3.isa(Type4));
+
+ ASSERT_TRUE(Type4.isa(Type1));
+ ASSERT_TRUE(Type4.isa(Type2));
+ ASSERT_TRUE(Type4.isa(Type3));
+ ASSERT_TRUE(Type4.isa(Type4));
+}
+
+TEST(Managed, type) {
+ Manager mgr(1);
+
+ Rooted<TypeTestManaged1> m1{new TypeTestManaged1(mgr)};
+ Rooted<TypeTestManaged2> m2{new TypeTestManaged2(mgr)};
+ Rooted<TypeTestManaged3> m3{new TypeTestManaged3(mgr)};
+ Rooted<TypeTestManaged4> m4{new TypeTestManaged4(mgr)};
+ Rooted<TypeTestManaged5> m5{new TypeTestManaged5(mgr)};
+
+ ASSERT_EQ(&Type1, &m1->type());
+ ASSERT_EQ(&Type2, &m2->type());
+ ASSERT_EQ(&Type3, &m3->type());
+ ASSERT_EQ(&Type4, &m4->type());
+ ASSERT_EQ(&ManagedType::None, &m5->type());
}
}