// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "media/midi/usb_midi_descriptor_parser.h" #include #include "base/macros.h" #include "testing/gtest/include/gtest/gtest.h" namespace media { namespace midi { namespace { TEST(UsbMidiDescriptorParserTest, ParseEmpty) { UsbMidiDescriptorParser parser; std::vector jacks; EXPECT_TRUE(parser.Parse(nullptr, nullptr, 0, &jacks)); EXPECT_TRUE(jacks.empty()); } TEST(UsbMidiDescriptorParserTest, InvalidSize) { UsbMidiDescriptorParser parser; std::vector jacks; uint8_t data[] = {0x04}; EXPECT_FALSE(parser.Parse(nullptr, data, arraysize(data), &jacks)); EXPECT_TRUE(jacks.empty()); } TEST(UsbMidiDescriptorParserTest, NonExistingJackIsAssociated) { UsbMidiDescriptorParser parser; std::vector jacks; // Jack id=1 is found in a CS_ENDPOINT descriptor, but there is no definition // for the jack. uint8_t data[] = { 0x09, 0x04, 0x01, 0x00, 0x02, 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x07, 0x00, 0x05, 0x25, 0x01, 0x01, 0x01, }; EXPECT_FALSE(parser.Parse(nullptr, data, arraysize(data), &jacks)); EXPECT_TRUE(jacks.empty()); } TEST(UsbMidiDescriptorParserTest, JacksShouldBeIgnoredWhenParserIsNotParsingMidiInterface) { UsbMidiDescriptorParser parser; std::vector jacks; // a NON-MIDI INTERFACE descriptor followed by ENDPOINT and CS_ENDPOINT // descriptors (Compare with the previous test case). uint8_t data[] = { 0x09, 0x04, 0x01, 0x00, 0x02, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x07, 0x00, 0x05, 0x25, 0x01, 0x01, 0x01, }; EXPECT_TRUE(parser.Parse(nullptr, data, arraysize(data), &jacks)); EXPECT_TRUE(jacks.empty()); } TEST(UsbMidiDescriptorParserTest, Parse) { UsbMidiDescriptorParser parser; std::vector jacks; // A complete device descriptor. uint8_t data[] = { 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, 0x05, 0x25, 0x01, 0x01, 0x07, }; EXPECT_TRUE(parser.Parse(nullptr, data, arraysize(data), &jacks)); ASSERT_EQ(3u, jacks.size()); EXPECT_EQ(2u, jacks[0].jack_id); EXPECT_EQ(0u, jacks[0].cable_number); EXPECT_EQ(2u, jacks[0].endpoint_number()); EXPECT_EQ(UsbMidiJack::DIRECTION_OUT, jacks[0].direction()); EXPECT_EQ(nullptr, jacks[0].device); EXPECT_EQ(3u, jacks[1].jack_id); EXPECT_EQ(1u, jacks[1].cable_number); EXPECT_EQ(2u, jacks[1].endpoint_number()); EXPECT_EQ(UsbMidiJack::DIRECTION_OUT, jacks[1].direction()); EXPECT_EQ(nullptr, jacks[1].device); EXPECT_EQ(7u, jacks[2].jack_id); EXPECT_EQ(0u, jacks[2].cable_number); EXPECT_EQ(2u, jacks[2].endpoint_number()); EXPECT_EQ(UsbMidiJack::DIRECTION_IN, jacks[2].direction()); EXPECT_EQ(nullptr, jacks[2].device); } TEST(UsbMidiDescriptorParserTest, ParseDeviceInfoEmpty) { UsbMidiDescriptorParser parser; UsbMidiDescriptorParser::DeviceInfo info; EXPECT_FALSE(parser.ParseDeviceInfo(nullptr, 0, &info)); } TEST(UsbMidiDescriptorParserTest, ParseDeviceInfo) { UsbMidiDescriptorParser parser; UsbMidiDescriptorParser::DeviceInfo info; uint8_t data[] = { 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef, 0x00, 0x0a, }; EXPECT_TRUE(parser.ParseDeviceInfo(data, arraysize(data), &info)); EXPECT_EQ(0x2301, info.vendor_id); EXPECT_EQ(0x6745, info.product_id); EXPECT_EQ(0xab89, info.bcd_device_version); EXPECT_EQ(0xcd, info.manufacturer_index); EXPECT_EQ(0xef, info.product_index); } } // namespace } // namespace midi } // namespace media