#include "scalar_properties.h"
+CPPUNIT_TEST_SUITE_REGISTRATION (ScalarPropertiesTest);
+
+using namespace std;
using namespace PBD;
namespace Properties {
PBD::PropertyDescriptor<int> fred;
};
+void
+ScalarPropertiesTest::make_property_quarks ()
+{
+ Properties::fred.property_id = g_quark_from_static_string ("fred");
+}
+
ScalarPropertiesTest::ScalarPropertiesTest ()
: _fred (Properties::fred, 0)
{
-
}
void
ScalarPropertiesTest::testBasic ()
{
CPPUNIT_ASSERT (_fred.changed() == false);
-
+
_fred = 4;
CPPUNIT_ASSERT (_fred == 4);
CPPUNIT_ASSERT (_fred.changed() == true);
+ _fred.clear_history ();
+ CPPUNIT_ASSERT (_fred.changed() == false);
+
_fred = 5;
CPPUNIT_ASSERT (_fred == 5);
CPPUNIT_ASSERT (_fred.changed() == true);
PropertyList undo;
PropertyList redo;
_fred.diff (undo, redo);
+
+ CPPUNIT_ASSERT (undo.size() == 1);
+ CPPUNIT_ASSERT (redo.size() == 1);
+
+ PropertyTemplate<int>* t = dynamic_cast<Property<int>*> (undo.begin()->second);
+ CPPUNIT_ASSERT (t);
+ CPPUNIT_ASSERT (t->val() == 4);
+
+ t = dynamic_cast<Property<int>*> (redo.begin()->second);
+ CPPUNIT_ASSERT (t);
+ CPPUNIT_ASSERT (t->val() == 5);
}