Write state data from automation list test to check why test is failing
authorTim Mayberry <mojofunk@gmail.com>
Sat, 10 Aug 2013 08:56:59 +0000 (18:56 +1000)
committerTim Mayberry <mojofunk@gmail.com>
Fri, 11 Oct 2013 12:36:19 +0000 (22:36 +1000)
libs/ardour/test/automation_list_property_test.cc

index 073fcf4b098f671ee636d6a55786daf19e7ddb7a..e5a74cad2f14b494d1a302a42f9e72db4fbe80da 100644 (file)
@@ -32,6 +32,16 @@ using namespace std;
 using namespace PBD;
 using namespace ARDOUR;
 
+void
+write_automation_list_xml (XMLNode* node, std::string filename)
+{
+       // use the same output dir for all of them
+       static std::string test_output_dir = new_test_output_dir ("automation_list_property");
+       std::string output_file = Glib::build_filename (test_output_dir, filename);
+
+       CPPUNIT_ASSERT (write_ref (node, output_file));
+}
+
 void
 AutomationListPropertyTest::basicTest ()
 {
@@ -56,14 +66,17 @@ AutomationListPropertyTest::basicTest ()
        /* Now it has changed */
        CPPUNIT_ASSERT_EQUAL (true, property.changed());
 
-       std::string test_data_file1 = Glib::build_filename (test_search_path().front(), "automation_list_property_test1.ref");
+       std::string test_data_filename = "automation_list_property_test1.ref";
+       std::string test_data_file1 = Glib::build_filename (test_search_path().front(), test_data_filename);
        CPPUNIT_ASSERT (Glib::file_test (test_data_file1, Glib::FILE_TEST_EXISTS));
 
        XMLNode* foo = new XMLNode ("test");
        property.get_changes_as_xml (foo);
+       write_automation_list_xml (foo, test_data_filename);
        check_xml (foo, test_data_file1, ignore_properties);
 
-       std::string test_data_file2 = Glib::build_filename (test_search_path().front(), "automation_list_property_test2.ref");
+       test_data_filename = "automation_list_property_test2.ref";
+       std::string test_data_file2 = Glib::build_filename (test_search_path().front(), test_data_filename);
        CPPUNIT_ASSERT (Glib::file_test (test_data_file2, Glib::FILE_TEST_EXISTS));
 
        /* Do some more */
@@ -74,6 +87,7 @@ AutomationListPropertyTest::basicTest ()
        CPPUNIT_ASSERT_EQUAL (true, property.changed());
        foo = new XMLNode ("test");
        property.get_changes_as_xml (foo);
+       write_automation_list_xml (foo, test_data_filename);
        check_xml (foo, test_data_file2, ignore_properties);
 }
 
@@ -129,17 +143,21 @@ AutomationListPropertyTest::undoTest ()
        sheila->_jim->add (7, 8);
        StatefulDiffCommand sdc (sheila);
 
-       std::string test_data_file3 = Glib::build_filename (test_search_path().front(), "automation_list_property_test3.ref");
+       std::string test_data_filename = "automation_list_property_test3.ref";
+       std::string test_data_file3 = Glib::build_filename (test_search_path().front(), test_data_filename);
        CPPUNIT_ASSERT (Glib::file_test (test_data_file3, Glib::FILE_TEST_EXISTS));
 
        /* Undo */
        sdc.undo ();
+       write_automation_list_xml (&sheila->get_state(), test_data_filename);
        check_xml (&sheila->get_state(), test_data_file3, ignore_properties);
 
-       std::string test_data_file4 = Glib::build_filename (test_search_path().front(), "automation_list_property_test4.ref");
+       test_data_filename = "automation_list_property_test4.ref";
+       std::string test_data_file4 = Glib::build_filename (test_search_path().front(), test_data_filename);
        CPPUNIT_ASSERT (Glib::file_test (test_data_file4, Glib::FILE_TEST_EXISTS));
 
        /* Redo */
        sdc.redo ();
+       write_automation_list_xml (&sheila->get_state(), test_data_filename);
        check_xml (&sheila->get_state(), test_data_file4, ignore_properties);
 }