summaryrefslogtreecommitdiff
path: root/libs/evoral/test
diff options
context:
space:
mode:
authorHans Baier <hansfbaier@googlemail.com>2009-02-09 22:32:38 +0000
committerHans Baier <hansfbaier@googlemail.com>2009-02-09 22:32:38 +0000
commit1c043e33041326671a11cd39151bf7278670639f (patch)
tree902242acf4aff65a5416611216512cfe98e494b7 /libs/evoral/test
parenta44a244cbae6982dee0680a5055a90562a3b3dfd (diff)
* filename conventions
* added (blank) SMFTest.cpp/hpp: To be implemented git-svn-id: svn://localhost/ardour2/branches/3.0@4509 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/evoral/test')
-rw-r--r--libs/evoral/test/SMFTest.cpp1
-rw-r--r--libs/evoral/test/SMFTest.hpp8
-rw-r--r--libs/evoral/test/SequenceTest.cpp61
-rw-r--r--libs/evoral/test/SequenceTest.hpp138
4 files changed, 208 insertions, 0 deletions
diff --git a/libs/evoral/test/SMFTest.cpp b/libs/evoral/test/SMFTest.cpp
new file mode 100644
index 0000000000..369bc80e45
--- /dev/null
+++ b/libs/evoral/test/SMFTest.cpp
@@ -0,0 +1 @@
+#include "SMFTest.hpp"
diff --git a/libs/evoral/test/SMFTest.hpp b/libs/evoral/test/SMFTest.hpp
new file mode 100644
index 0000000000..5b3d96a27b
--- /dev/null
+++ b/libs/evoral/test/SMFTest.hpp
@@ -0,0 +1,8 @@
+#include <cppunit/TestFixture.h>
+#include <cppunit/extensions/HelperMacros.h>
+
+#include <evoral/SMF.hpp>
+
+#include <sigc++/sigc++.h>
+
+#include <cassert>
diff --git a/libs/evoral/test/SequenceTest.cpp b/libs/evoral/test/SequenceTest.cpp
new file mode 100644
index 0000000000..9c5a2000a7
--- /dev/null
+++ b/libs/evoral/test/SequenceTest.cpp
@@ -0,0 +1,61 @@
+#include "SequenceTest.hpp"
+#include <cassert>
+
+CPPUNIT_TEST_SUITE_REGISTRATION( SequenceTest );
+
+using namespace std;
+
+void
+SequenceTest::createTest (void)
+{
+ CPPUNIT_ASSERT_EQUAL(size_t(0), seq->sysexes().size());
+ CPPUNIT_ASSERT_EQUAL(size_t(0), seq->notes().size());
+ CPPUNIT_ASSERT(seq->notes().begin() == seq->notes().end());
+}
+
+
+void
+SequenceTest::preserveEventOrderingTest (void)
+{
+ vector<boost::shared_ptr<Event<Time> > > inserted_events;
+
+ seq->start_write();
+
+ for (Notes::const_iterator i = test_notes.begin(); i != test_notes.end(); ++i) {
+ uint8_t buffer[2];
+ Event<Time>* event = new Event<Time>(
+ DummyTypeMap::CONTROL, (*i)->on_event().time(), 3, buffer, true
+ );
+
+ event->buffer()[0] = MIDI_CMD_CONTROL;
+ event->buffer()[1] = event->time() / 100;
+ event->buffer()[2] = event->time() / 100;
+
+ boost::shared_ptr<Event<Time> > event_ptr(event);
+
+ seq->append((*i)->on_event());
+ inserted_events.push_back(
+ boost::shared_ptr<Event<Time> >(
+ new Event<Time>((*i)->on_event(), true)
+ ));
+
+ seq->append(*event_ptr);
+ inserted_events.push_back(event_ptr);
+
+ seq->append((*i)->off_event());
+ inserted_events.push_back(
+ boost::shared_ptr<Event<Time> >(
+ new Event<Time>((*i)->off_event(), true)
+ ));
+ }
+
+ seq->end_write();
+
+ TestSink<Time> sink;
+ sink.writing.connect(sigc::mem_fun(&sink, &TestSink<Time>::assertLastEventTimeLessOrEqualEventTime));
+
+ seq->read(sink, timestamp_t(0), timedur_t(1200), timestamp_t(0));
+
+ CPPUNIT_ASSERT_EQUAL(size_t(12), test_notes.size());
+
+}
diff --git a/libs/evoral/test/SequenceTest.hpp b/libs/evoral/test/SequenceTest.hpp
new file mode 100644
index 0000000000..746c20cd0f
--- /dev/null
+++ b/libs/evoral/test/SequenceTest.hpp
@@ -0,0 +1,138 @@
+#include <cppunit/TestFixture.h>
+#include <cppunit/extensions/HelperMacros.h>
+
+#include <evoral/Sequence.hpp>
+#include <evoral/TypeMap.hpp>
+#include <evoral/EventSink.hpp>
+#include <evoral/midi_events.h>
+#include <evoral/Control.hpp>
+
+#include <sigc++/sigc++.h>
+
+#include <cassert>
+
+
+using namespace Evoral;
+
+class DummyTypeMap : public TypeMap {
+public:
+
+ enum DummyEventType {
+ NOTE,
+ CONTROL,
+ SYSEX
+ };
+
+ ~DummyTypeMap() {}
+
+ bool type_is_midi(uint32_t type) const {return true;}
+
+ uint8_t parameter_midi_type(const Parameter& param) const {
+ switch (param.type()) {
+ case CONTROL: return MIDI_CMD_CONTROL;
+ case SYSEX: return MIDI_CMD_COMMON_SYSEX;
+ default: return 0;
+ };
+ }
+
+ uint32_t midi_event_type(uint8_t status) const {
+ status &= 0xf0;
+ switch (status) {
+ case MIDI_CMD_CONTROL: return CONTROL;
+ case MIDI_CMD_COMMON_SYSEX: return SYSEX;
+ default: return 0;
+ };
+ }
+
+ bool is_integer(const Evoral::Parameter& param) const {return true;}
+
+ Parameter new_parameter(uint32_t type, uint8_t channel, uint32_t id) const {
+ Parameter p(type, channel, id);
+ p.set_range(type, 0.0f, 1.0f, 0.0f);
+ return p;
+ }
+
+ std::string to_symbol(const Parameter& param) const {return "control";}
+};
+
+template<typename Time>
+class MySequence : public Sequence<Time> {
+public:
+ MySequence(DummyTypeMap&map, int size) : Sequence<Time>(map, size) {}
+
+ boost::shared_ptr<Control> control_factory(const Parameter& param) {
+
+ return boost::shared_ptr<Control>(
+ new Control(param, boost::shared_ptr<ControlList> (
+ new ControlList(param)
+ )));
+ }
+};
+
+template<typename Time>
+class TestSink : public EventSink<Time> {
+public:
+ TestSink() : _last_event_time(-1) {}
+
+ /// return value, time, type, size, buffer
+ sigc::signal<uint32_t, Time, EventType, uint32_t, const uint8_t*> writing;
+
+ virtual uint32_t write(Time time, EventType type, uint32_t size, const uint8_t* buf) {
+ std::cerr << "last event time: " << _last_event_time << " time: " << time << std::endl;
+ uint32_t result = writing(time, type, size, buf);
+ _last_event_time = time;
+ return result;
+ }
+
+ uint32_t assertLastEventTimeLessOrEqualEventTime(
+ Time time, EventType type, uint32_t size, const uint8_t* buf) {
+ CPPUNIT_ASSERT(_last_event_time <= time);
+ return 0;
+ }
+
+ Time last_event_time() const { return _last_event_time; }
+
+private:
+ Time _last_event_time;
+};
+
+class SequenceTest : public CppUnit::TestFixture
+{
+ CPPUNIT_TEST_SUITE (SequenceTest);
+ CPPUNIT_TEST (createTest);
+ CPPUNIT_TEST (preserveEventOrderingTest);
+ CPPUNIT_TEST_SUITE_END ();
+
+ public:
+
+ typedef double Time;
+ typedef std::vector<boost::shared_ptr<Note<Time> > > Notes;
+
+ void setUp (void) {
+ std::cerr << "SetUp" << std::endl;
+ type_map = new DummyTypeMap();
+ assert(type_map);
+ seq = new MySequence<Time>(*type_map, 0);
+ assert(seq);
+
+ for(int i = 0; i < 12; i++) {
+ test_notes.push_back(boost::shared_ptr<Note<Time> >
+ (new Note<Time>(0, i * 100, 100, 64 + i, 64)));
+ }
+ }
+
+ void tearDown (void) {
+ test_notes.clear();
+ delete seq;
+ delete type_map;
+ }
+
+ void createTest (void);
+ void preserveEventOrderingTest (void);
+
+ private:
+ DummyTypeMap* type_map;
+ MySequence<Time>* seq;
+
+ Notes test_notes;
+};