4 #include <io.h> // for R_OK
9 CPPUNIT_TEST_SUITE_REGISTRATION( SMFTest );
12 SMFTest::createNewFileTest ()
15 smf.create("NewFile.mid");
17 CPPUNIT_ASSERT(access("NewFile.mid", R_OK) == 0);
18 unlink(smf.path().c_str());
22 SMFTest::takeFiveTest ()
25 smf.open("./test/testdata/TakeFive.mid");
26 CPPUNIT_ASSERT(!smf.is_empty());
31 uint64_t time = 0; /* in SMF ticks */
32 Evoral::Event<double> ev;
34 const double frames_per_beat = 100.0;
40 while ((ret = smf.read_event(&delta_t, &size, &buf)) >= 0) {
41 ev.set(buf, size, 0.0);
44 if (ret > 0) { // didn't skip (meta) event
45 //cerr << "read smf event type " << hex << int(buf[0]) << endl;
46 // make ev.time absolute time in frames
47 ev.set_time(time * frames_per_beat / (double)smf.ppqn());
48 ev.set_event_type(type_map->midi_event_type(buf[0]));
49 seq->append(ev, next_event_id ());
53 seq->end_write (Sequence<Time>::Relax, false);
54 CPPUNIT_ASSERT(!seq->empty());