2 #include <sigc++/sigc++.h>
3 #include <cppunit/TestFixture.h>
4 #include <cppunit/extensions/HelperMacros.h>
5 #include "evoral/Beats.hpp"
6 #include "evoral/Sequence.hpp"
7 #include "evoral/TypeMap.hpp"
8 #include "evoral/EventSink.hpp"
9 #include "evoral/midi_events.h"
10 #include "evoral/Control.hpp"
12 using namespace Evoral;
14 class DummyTypeMap : public TypeMap {
24 bool type_is_midi (uint32_t /*type*/) const { return true; }
26 uint8_t parameter_midi_type(const Parameter& param) const {
27 switch (param.type()) {
28 case CONTROL: return MIDI_CMD_CONTROL;
29 case SYSEX: return MIDI_CMD_COMMON_SYSEX;
34 uint32_t midi_event_type(uint8_t status) const {
37 case MIDI_CMD_CONTROL: return CONTROL;
38 case MIDI_CMD_COMMON_SYSEX: return SYSEX;
43 ParameterDescriptor descriptor(const Parameter& param) const {
44 return ParameterDescriptor();
47 std::string to_symbol(const Parameter& /*param*/) const { return "control"; }
50 template<typename Time>
51 class MySequence : public Sequence<Time> {
53 MySequence(DummyTypeMap&map) : Sequence<Time>(map) {}
55 virtual bool find_next_event(double start, double end, ControlEvent& ev, bool only_active) const { return false; }
57 boost::shared_ptr<Control> control_factory(const Parameter& param) {
58 const Evoral::ParameterDescriptor desc;
59 boost::shared_ptr<ControlList> list(new ControlList(param, desc));
60 return boost::shared_ptr<Control>(new Control(param, desc, list));
64 template<typename Time>
65 class TestSink : public EventSink<Time> {
67 TestSink() : _last_event_time(-1) {}
69 /// return value, time, type, size, buffer
70 sigc::signal<uint32_t, Time, EventType, uint32_t, const uint8_t*> writing;
72 virtual uint32_t write(Time time, EventType type, uint32_t size, const uint8_t* buf) {
73 //std::cerr << "last event time: " << _last_event_time << " time: " << time << std::endl;
74 uint32_t result = writing(time, type, size, buf);
75 _last_event_time = time;
79 uint32_t assertLastEventTimeEarlier(
80 Time time, EventType /*type*/, uint32_t /*size*/, const uint8_t* /*buf*/) {
81 CPPUNIT_ASSERT(_last_event_time <= time);
85 Time last_event_time() const { return _last_event_time; }
88 Time _last_event_time;
91 template<typename Time>
92 class CCTestSink : public EventSink<Time> {
94 CCTestSink(uint32_t t) : cc_type(t) {}
96 virtual uint32_t write(Time time, EventType type, uint32_t size, const uint8_t* buf) {
97 if (type == cc_type) {
98 CPPUNIT_ASSERT(size == 3);
99 events.push_back(std::make_pair(time, buf[2]));
104 typedef std::vector< std::pair<Time, uint8_t> > Events;
109 class SequenceTest : public CppUnit::TestFixture
111 CPPUNIT_TEST_SUITE (SequenceTest);
112 CPPUNIT_TEST (createTest);
113 CPPUNIT_TEST (preserveEventOrderingTest);
114 CPPUNIT_TEST (iteratorSeekTest);
115 CPPUNIT_TEST (controlInterpolationTest);
116 CPPUNIT_TEST_SUITE_END ();
120 typedef std::vector< boost::shared_ptr< Note<Time> > > Notes;
123 type_map = new DummyTypeMap();
125 seq = new MySequence<Time>(*type_map);
128 for (int i = 0; i < 12; i++) {
129 test_notes.push_back(
130 boost::shared_ptr<Note<Time> >(
131 new Note<Time>(0, Beats(i * 100), Beats(100), 64 + i, 64)));
142 void preserveEventOrderingTest ();
143 void iteratorSeekTest ();
144 void controlInterpolationTest ();
147 DummyTypeMap* type_map;
148 MySequence<Time>* seq;