summaryrefslogtreecommitdiff
path: root/libs/evoral/test/SequenceTest.cpp
blob: ba261cdd871b4c8e997a7ef0a8831b2ead4c33ba (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
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>::assertLastEventTimeEarlier));

	seq->read(sink, timestamp_t(0), timedur_t(1200), timestamp_t(0));
	
	CPPUNIT_ASSERT_EQUAL(size_t(12), test_notes.size());
	
}