Added more tests & fixed #53 (sendPitchBend range).

This commit is contained in:
Francois Best 2016-10-06 20:49:38 +02:00
parent 419606785d
commit c29dfd84d7
2 changed files with 132 additions and 30 deletions

View File

@ -289,7 +289,8 @@ template<class SerialPort, class Settings>
void MidiInterface<SerialPort, Settings>::sendPitchBend(double inPitchValue, void MidiInterface<SerialPort, Settings>::sendPitchBend(double inPitchValue,
Channel inChannel) Channel inChannel)
{ {
const int value = int(inPitchValue * double(MIDI_PITCHBEND_MAX)); const int scale = inPitchValue > 0.0 ? MIDI_PITCHBEND_MAX : MIDI_PITCHBEND_MIN;
const int value = int(inPitchValue * double(scale));
sendPitchBend(value, inChannel); sendPitchBend(value, inChannel);
} }

View File

@ -28,7 +28,7 @@ typedef midi::MidiInterface<SerialMock> MidiInterface;
// -- // --
TEST(MidiOutput, sendSingle) TEST(MidiOutput, sendGenericSingle)
{ {
SerialMock serial; SerialMock serial;
MidiInterface midi(serial); MidiInterface midi(serial);
@ -41,7 +41,7 @@ TEST(MidiOutput, sendSingle)
EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42)); EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42));
} }
TEST(MidiOutput, sendWithRunningStatus) TEST(MidiOutput, sendGenericWithRunningStatus)
{ {
SerialMock serial; SerialMock serial;
MidiInterface midi(serial); MidiInterface midi(serial);
@ -57,7 +57,7 @@ TEST(MidiOutput, sendWithRunningStatus)
EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42, 42, 47)); EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42, 42, 47));
} }
TEST(MidiOutput, sendWithoutRunningStatus) TEST(MidiOutput, sendGenericWithoutRunningStatus)
{ {
typedef VariableSettings<false, true> Settings; // No running status typedef VariableSettings<false, true> Settings; // No running status
typedef midi::MidiInterface<SerialMock, Settings> MidiInterface; typedef midi::MidiInterface<SerialMock, Settings> MidiInterface;
@ -85,7 +85,7 @@ TEST(MidiOutput, sendWithoutRunningStatus)
EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42, 0x8b, 47, 42)); EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42, 0x8b, 47, 42));
} }
TEST(MidiOutput, sendBreakingRunningStatus) TEST(MidiOutput, sendGenericBreakingRunningStatus)
{ {
SerialMock serial; SerialMock serial;
MidiInterface midi(serial); MidiInterface midi(serial);
@ -99,48 +99,149 @@ TEST(MidiOutput, sendBreakingRunningStatus)
EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42, 0x8b, 47, 42)); EXPECT_THAT(buffer, ElementsAre(0x9b, 47, 42, 0x8b, 47, 42));
} }
TEST(MidiOutput, sendMultipleNoteOff) // --
TEST(MidiOutput, sendNoteOn)
{ {
SerialMock serial; SerialMock serial;
MidiInterface midi(serial); MidiInterface midi(serial);
test_mocks::uint8 buffer[5] = { 0 }; test_mocks::uint8 buffer[5] = { 0 };
midi.begin(); midi.begin();
midi.send(midi::NoteOff, 10, 11, 12); midi.sendNoteOn(10, 11, 12);
midi.send(midi::NoteOff, 12, 13, 12); midi.sendNoteOn(12, 13, 12);
EXPECT_EQ(serial.mTxBuffer.getLength(), 5);
serial.mTxBuffer.read(buffer, 5);
EXPECT_THAT(buffer, ElementsAre(0x9b, 10, 11, 12, 13));
}
TEST(MidiOutput, sendNoteOff)
{
SerialMock serial;
MidiInterface midi(serial);
test_mocks::uint8 buffer[5] = { 0 };
midi.begin();
midi.sendNoteOff(10, 11, 12);
midi.sendNoteOff(12, 13, 12);
EXPECT_EQ(serial.mTxBuffer.getLength(), 5); EXPECT_EQ(serial.mTxBuffer.getLength(), 5);
serial.mTxBuffer.read(buffer, 5); serial.mTxBuffer.read(buffer, 5);
EXPECT_THAT(buffer, ElementsAre(0x8b, 10, 11, 12, 13)); EXPECT_THAT(buffer, ElementsAre(0x8b, 10, 11, 12, 13));
} }
/* TEST(MidiOutput, Issue41) TEST(MidiOutput, sendProgramChange)
{ {
typedef VariableSettings<true, false> Settings; // Running status, multibyte parsing
typedef midi::MidiInterface<SerialMock, Settings> MidiInterface;
// #41: issue with sending series of ControlChange
SerialMock serial; SerialMock serial;
MidiInterface midi(serial); MidiInterface midi(serial);
test_mocks::uint8 buffer[9] = { 0 }; test_mocks::uint8 buffer[3] = { 0 };
midi.begin(MIDI_CHANNEL_OMNI); midi.begin();
midi.turnThruOff(); midi.sendProgramChange(42, 12);
midi.sendProgramChange(47, 12);
EXPECT_EQ(serial.mTxBuffer.getLength(), 3);
serial.mTxBuffer.read(buffer, 3);
EXPECT_THAT(buffer, ElementsAre(0xcb, 42, 47));
}
// Simulate some pitch bend messages TEST(MidiOutput, sendControlChange)
serial.mRxBuffer.write(0xe0); {
serial.mRxBuffer.write(0); SerialMock serial;
serial.mRxBuffer.write(12); MidiInterface midi(serial);
serial.mRxBuffer.write(0); test_mocks::uint8 buffer[5] = { 0 };
serial.mRxBuffer.write(42);
serial.mRxBuffer.write(0);
serial.mRxBuffer.write(47);
midi.read();
EXPECT_EQ(serial.mTxBuffer.getLength(), 9); midi.begin();
serial.mTxBuffer.read(buffer, 9); midi.sendControlChange(42, 12, 12);
EXPECT_THAT(buffer, ElementsAre(0xbb, 80, 42, 80, 47, 80, 42, 80, 47)); midi.sendControlChange(47, 12, 12);
} */ EXPECT_EQ(serial.mTxBuffer.getLength(), 5);
serial.mTxBuffer.read(buffer, 5);
EXPECT_THAT(buffer, ElementsAre(0xbb, 42, 12, 47, 12));
}
// -- TEST(MidiOutput, sendPitchBend)
{
SerialMock serial;
MidiInterface midi(serial);
test_mocks::uint8 buffer[7] = { 0 };
// Int signature - arbitrary values
{
midi.begin();
midi.sendPitchBend(0, 12);
midi.sendPitchBend(100, 12);
midi.sendPitchBend(-100, 12);
EXPECT_EQ(serial.mTxBuffer.getLength(), 7);
serial.mTxBuffer.read(buffer, 7);
EXPECT_THAT(buffer, ElementsAre(0xeb,
0x00, 0x40,
0x64, 0x40,
0x1c, 0x3f));
}
// Int signature - min/max
{
midi.begin();
midi.sendPitchBend(0, 12);
midi.sendPitchBend(MIDI_PITCHBEND_MAX, 12);
midi.sendPitchBend(MIDI_PITCHBEND_MIN, 12);
EXPECT_EQ(serial.mTxBuffer.getLength(), 7);
serial.mTxBuffer.read(buffer, 7);
EXPECT_THAT(buffer, ElementsAre(0xeb,
0x00, 0x40,
0x7f, 0x7f,
0x00, 0x00));
}
// Float signature
{
midi.begin();
midi.sendPitchBend(0.0, 12);
midi.sendPitchBend(1.0, 12);
midi.sendPitchBend(-1.0, 12);
EXPECT_EQ(serial.mTxBuffer.getLength(), 7);
serial.mTxBuffer.read(buffer, 7);
EXPECT_THAT(buffer, ElementsAre(0xeb,
0x00, 0x40,
0x7f, 0x7f,
0x00, 0x00));
}
}
TEST(MidiOutput, sendPolyPressure)
{
}
TEST(MidiOutput, sendAfterTouch)
{
}
TEST(MidiOutput, sendSysEx)
{
}
TEST(MidiOutput, sendTimeCodeQuarterFrame)
{
}
TEST(MidiOutput, sendSongPosition)
{
}
TEST(MidiOutput, sendSongSelect)
{
}
TEST(MidiOutput, sendTuneRequest)
{
}
TEST(MidiOutput, sendRealTime)
{
}
END_UNNAMED_NAMESPACE END_UNNAMED_NAMESPACE