merge with master
[ardour.git] / libs / evoral / test / SMFTest.hpp
index 5b3d96a27bb9bcf39f123f2c2d85e4f8bc45578d..9b5d2d54e3c07d1bbac1a33996d8f5d7ed50f20e 100644 (file)
@@ -1,8 +1,80 @@
+/* This file is part of Evoral.
+ * Copyright(C) 2000-2008 Paul Davis
+ * Author: Hans Baier
+ *
+ * Evoral 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 2 of the License, or(at your option) any later
+ * version.
+ *
+ * Evoral 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 details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include <cassert>
+#include <stdint.h>
+#include <sigc++/sigc++.h>
 #include <cppunit/TestFixture.h>
 #include <cppunit/extensions/HelperMacros.h>
+#include "evoral/SMF.hpp"
+#include "SequenceTest.hpp"
 
-#include <evoral/SMF.hpp>
+using namespace Evoral;
 
-#include <sigc++/sigc++.h>
+class TestSMF : public SMF {
+public:
+       std::string path() const { return _path; }
+
+       int open(const std::string& path) THROW_FILE_ERROR {
+               _path = path;
+               return SMF::open(path);
+       }
+
+       void close() THROW_FILE_ERROR {
+               return SMF::close();
+       }
+
+       int read_event(uint32_t* delta_t, uint32_t* size, uint8_t** buf) const {
+               event_id_t id;
+               return SMF::read_event(delta_t, size, buf, &id);
+       }
+
+private:
+       std::string  _path;
+};
+
+class SMFTest : public CppUnit::TestFixture
+{
+       CPPUNIT_TEST_SUITE(SMFTest);
+       CPPUNIT_TEST(createNewFileTest);
+       CPPUNIT_TEST(takeFiveTest);
+       CPPUNIT_TEST_SUITE_END();
+
+public:
+       typedef double Time;
+
+       void setUp() {
+               type_map = new DummyTypeMap();
+               assert(type_map);
+               seq = new MySequence<Time>(*type_map);
+               assert(seq);
+       }
+
+       void tearDown() {
+               delete seq;
+               delete type_map;
+       }
+
+       void createNewFileTest();
+       void takeFiveTest();
+
+private:
+       DummyTypeMap*     type_map;
+       MySequence<Time>* seq;
+};
 
-#include <cassert>