/*
Ousía
Copyright (C) 2014, 2015 Benjamin Paaßen, Andreas Stöckel
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*/
#include
#include
#include
#include
#include "TestManaged.hpp"
namespace ousia {
TEST(Managed, data)
{
Manager mgr{1};
Rooted n{new Managed{mgr}};
Rooted m1{new Managed{mgr}};
n->storeData("info", m1);
ASSERT_TRUE(n->hasDataKey("info"));
ASSERT_FALSE(n->hasDataKey("test"));
Rooted m2{new Managed{mgr}};
n->storeData("test", m2);
ASSERT_TRUE(n->hasDataKey("info"));
ASSERT_TRUE(n->hasDataKey("test"));
ASSERT_TRUE(n->deleteData("info"));
ASSERT_FALSE(n->deleteData("info"));
ASSERT_FALSE(n->hasDataKey("info"));
ASSERT_TRUE(n->hasDataKey("test"));
n->storeData("info2", m1);
std::map> 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;
};
static const Rtti Type1 = RttiBuilder("Type1");
static const Rtti Type2 = RttiBuilder("Type2");
static const Rtti Type3 = RttiBuilder("Type3").parent(&Type1);
static const Rtti Type4 =
RttiBuilder("Type4").parent({&Type3, &Type2});
TEST(Managed, type)
{
Manager mgr(1);
Rooted m1{new TypeTestManaged1(mgr)};
Rooted m2{new TypeTestManaged2(mgr)};
Rooted m3{new TypeTestManaged3(mgr)};
Rooted m4{new TypeTestManaged4(mgr)};
Rooted 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(&RttiTypes::None, m5->type());
ASSERT_EQ(&Type1, typeOf());
ASSERT_EQ(&Type1, typeOf(*m1));
}
class TestManagedEventOwner : public TestManaged {
public:
using TestManaged::TestManaged;
int triggered = false;
};
static void handleEvent(const Event &ev, Managed *owner, void *data)
{
static_cast(owner)->triggered++;
}
TEST(Managed, events)
{
Manager mgr(1);
std::array a;
{
Rooted n{new TestManaged(mgr, a[0])};
Rooted e1{new TestManagedEventOwner(mgr, a[1])};
Rooted e2{new TestManagedEventOwner(mgr, a[2])};
Rooted e3{new TestManagedEventOwner(mgr, a[3])};
ASSERT_EQ(0U, n->registerEvent(EventType::UPDATE, handleEvent, e1));
ASSERT_EQ(1U,
n->registerEvent(EventType::NAME_CHANGE, handleEvent, e2));
ASSERT_EQ(2U,
n->registerEvent(EventType::NAME_CHANGE, handleEvent, e3));
ASSERT_EQ(0, e1->triggered);
ASSERT_EQ(0, e2->triggered);
ASSERT_EQ(0, e3->triggered);
{
Event ev{EventType::ADD_CHILD};
ASSERT_FALSE(n->triggerEvent(ev));
}
{
Event ev{EventType::UPDATE};
ASSERT_TRUE(n->triggerEvent(ev));
ASSERT_EQ(1, e1->triggered);
ASSERT_EQ(0, e2->triggered);
ASSERT_EQ(0, e3->triggered);
}
{
Event ev{EventType::NAME_CHANGE};
ASSERT_TRUE(n->triggerEvent(ev));
ASSERT_EQ(1, e1->triggered);
ASSERT_EQ(1, e2->triggered);
ASSERT_EQ(1, e3->triggered);
}
ASSERT_TRUE(n->unregisterEvent(1));
ASSERT_FALSE(n->unregisterEvent(1));
{
Event ev{EventType::NAME_CHANGE};
ASSERT_TRUE(n->triggerEvent(ev));
ASSERT_EQ(1, e1->triggered);
ASSERT_EQ(2, e3->triggered);
}
ASSERT_TRUE(n->unregisterEvent(0));
ASSERT_FALSE(n->unregisterEvent(0));
{
Event ev{EventType::UPDATE};
ASSERT_FALSE(n->triggerEvent(ev));
ASSERT_EQ(2, e3->triggered);
}
ASSERT_TRUE(n->unregisterEvent(2));
ASSERT_FALSE(n->unregisterEvent(2));
{
Event ev{EventType::NAME_CHANGE};
ASSERT_FALSE(n->triggerEvent(ev));
}
}
}
TEST(Managed, eventMemMgmt)
{
Manager mgr(1);
std::array a;
{
Rooted n{new TestManaged(mgr, a[0])};
{
Rooted e1{
new TestManagedEventOwner(mgr, a[1])};
ASSERT_EQ(0U, n->registerEvent(EventType::UPDATE, handleEvent, e1));
ASSERT_EQ(0, e1->triggered);
{
Event ev{EventType::UPDATE};
ASSERT_TRUE(n->triggerEvent(ev));
ASSERT_EQ(1, e1->triggered);
}
}
{
Event ev{EventType::UPDATE};
ASSERT_FALSE(n->triggerEvent(ev));
}
}
}
}