/* 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 #include #include #include #include #include "evoral/types.hpp" #include "evoral/SMF.hpp" #include "SequenceTest.hpp" using namespace Evoral; 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(writeTest); CPPUNIT_TEST_SUITE_END(); public: typedef Evoral::Beats Time; void setUp() { type_map = new DummyTypeMap(); assert(type_map); seq = new MySequence