ardour
SequenceTest.hpp
Go to the documentation of this file.
1 #include <cassert>
2 #include <sigc++/sigc++.h>
3 #include <cppunit/TestFixture.h>
4 #include <cppunit/extensions/HelperMacros.h>
5 #include "evoral/Sequence.hpp"
6 #include "evoral/TypeMap.hpp"
7 #include "evoral/EventSink.hpp"
8 #include "evoral/midi_events.h"
9 #include "evoral/Control.hpp"
10 
11 using namespace Evoral;
12 
13 class DummyTypeMap : public TypeMap {
14 public:
18  SYSEX
19  };
20 
22 
23  bool type_is_midi (uint32_t /*type*/) const { return true; }
24 
25  uint8_t parameter_midi_type(const Parameter& param) const {
26  switch (param.type()) {
27  case CONTROL: return MIDI_CMD_CONTROL;
28  case SYSEX: return MIDI_CMD_COMMON_SYSEX;
29  default: return 0;
30  };
31  }
32 
33  uint32_t midi_event_type(uint8_t status) const {
34  status &= 0xf0;
35  switch (status) {
36  case MIDI_CMD_CONTROL: return CONTROL;
37  case MIDI_CMD_COMMON_SYSEX: return SYSEX;
38  default: return 0;
39  };
40  }
41 
43  return ParameterDescriptor();
44  }
45 
46  std::string to_symbol(const Parameter& /*param*/) const { return "control"; }
47 };
48 
49 template<typename Time>
50 class MySequence : public Sequence<Time> {
51 public:
52  MySequence(DummyTypeMap&map) : Sequence<Time>(map) {}
53 
55  const Evoral::ParameterDescriptor desc;
56  boost::shared_ptr<ControlList> list(new ControlList(param, desc));
57  return boost::shared_ptr<Control>(new Control(param, desc, list));
58  }
59 };
60 
61 template<typename Time>
62 class TestSink : public EventSink<Time> {
63 public:
64  TestSink() : _last_event_time(-1) {}
65 
67  sigc::signal<uint32_t, Time, EventType, uint32_t, const uint8_t*> writing;
68 
69  virtual uint32_t write(Time time, EventType type, uint32_t size, const uint8_t* buf) {
70  //std::cerr << "last event time: " << _last_event_time << " time: " << time << std::endl;
71  uint32_t result = writing(time, type, size, buf);
72  _last_event_time = time;
73  return result;
74  }
75 
77  Time time, EventType /*type*/, uint32_t /*size*/, const uint8_t* /*buf*/) {
78  CPPUNIT_ASSERT(_last_event_time <= time);
79  return 0;
80  }
81 
82  Time last_event_time() const { return _last_event_time; }
83 
84 private:
86 };
87 
88 template<typename Time>
89 class CCTestSink : public EventSink<Time> {
90 public:
91  CCTestSink(uint32_t t) : cc_type(t) {}
92 
93  virtual uint32_t write(Time time, EventType type, uint32_t size, const uint8_t* buf) {
94  if (type == cc_type) {
95  CPPUNIT_ASSERT(size == 3);
96  events.push_back(std::make_pair(time, buf[2]));
97  }
98  return size;
99  }
100 
101  typedef std::vector< std::pair<Time, uint8_t> > Events;
102  Events events;
103  uint32_t cc_type;
104 };
105 
106 class SequenceTest : public CppUnit::TestFixture
107 {
108  CPPUNIT_TEST_SUITE (SequenceTest);
109  CPPUNIT_TEST (createTest);
110  CPPUNIT_TEST (preserveEventOrderingTest);
111  CPPUNIT_TEST (iteratorSeekTest);
112  CPPUNIT_TEST (controlInterpolationTest);
113  CPPUNIT_TEST_SUITE_END ();
114 
115 public:
116  typedef Beats Time;
117  typedef std::vector< boost::shared_ptr< Note<Time> > > Notes;
118 
119  void setUp () {
120  type_map = new DummyTypeMap();
121  assert(type_map);
122  seq = new MySequence<Time>(*type_map);
123  assert(seq);
124 
125  for (int i = 0; i < 12; i++) {
126  test_notes.push_back(
128  new Note<Time>(0, Beats(i * 100), Beats(100), 64 + i, 64)));
129  }
130  }
131 
132  void tearDown () {
133  test_notes.clear();
134  delete seq;
135  delete type_map;
136  }
137 
138  void createTest ();
139  void preserveEventOrderingTest ();
140  void iteratorSeekTest ();
141  void controlInterpolationTest ();
142 
143 private:
146 
147  Notes test_notes;
148 };
virtual uint32_t write(Time time, EventType type, uint32_t size, const uint8_t *buf)
MySequence(DummyTypeMap &map)
sigc::signal< uint32_t, Time, EventType, uint32_t, const uint8_t * > writing
return value, time, type, size, buffer
bool type_is_midi(uint32_t) const
std::vector< std::pair< Time, uint8_t > > Events
uint32_t assertLastEventTimeEarlier(Time time, EventType, uint32_t, const uint8_t *)
virtual uint32_t write(Time time, EventType type, uint32_t size, const uint8_t *buf)
CCTestSink(uint32_t t)
uint32_t midi_event_type(uint8_t status) const
#define MIDI_CMD_CONTROL
Definition: midi_events.h:110
DummyTypeMap * type_map
uint32_t cc_type
std::string to_symbol(const Parameter &) const
uint32_t EventType
Definition: types.hpp:43
#define MIDI_CMD_COMMON_SYSEX
Definition: midi_events.h:114
LIBEVORAL_API uint64_t ControlList
Definition: debug.cpp:5
boost::shared_ptr< Control > control_factory(const Parameter &param)
uint32_t type() const
Definition: Parameter.hpp:47
Time last_event_time() const
LIBEVORAL_API uint64_t Beats
uint8_t parameter_midi_type(const Parameter &param) const
Time _last_event_time
MySequence< Time > * seq
ParameterDescriptor descriptor(const Parameter &param) const
std::vector< boost::shared_ptr< Note< Time > > > Notes