OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "media/midi/midi_manager_usb.h" | 5 #include "media/midi/midi_manager_usb.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "base/run_loop.h" | 10 #include "base/run_loop.h" |
(...skipping 24 matching lines...) Expand all Loading... |
35 } | 35 } |
36 | 36 |
37 private: | 37 private: |
38 std::string log_; | 38 std::string log_; |
39 | 39 |
40 DISALLOW_COPY_AND_ASSIGN(Logger); | 40 DISALLOW_COPY_AND_ASSIGN(Logger); |
41 }; | 41 }; |
42 | 42 |
43 class FakeUsbMidiDevice : public UsbMidiDevice { | 43 class FakeUsbMidiDevice : public UsbMidiDevice { |
44 public: | 44 public: |
45 explicit FakeUsbMidiDevice(Logger* logger) : logger_(logger) {} | 45 explicit FakeUsbMidiDevice(Logger* logger) |
| 46 : device_version_(0), logger_(logger) {} |
46 ~FakeUsbMidiDevice() override {} | 47 ~FakeUsbMidiDevice() override {} |
47 | 48 |
48 std::vector<uint8> GetDescriptor() override { | 49 std::vector<uint8> GetDescriptors() override { |
49 logger_->AddLog("UsbMidiDevice::GetDescriptor\n"); | 50 logger_->AddLog("UsbMidiDevice::GetDescriptors\n"); |
50 return descriptor_; | 51 return descriptors_; |
51 } | 52 } |
52 | 53 |
| 54 std::string GetManufacturer() override { return manufacturer_; } |
| 55 std::string GetProductName() override { return product_name_; } |
| 56 uint16 GetDeviceVersion() override { return device_version_; } |
| 57 |
53 void Send(int endpoint_number, const std::vector<uint8>& data) override { | 58 void Send(int endpoint_number, const std::vector<uint8>& data) override { |
54 logger_->AddLog("UsbMidiDevice::Send "); | 59 logger_->AddLog("UsbMidiDevice::Send "); |
55 logger_->AddLog(base::StringPrintf("endpoint = %d data =", | 60 logger_->AddLog(base::StringPrintf("endpoint = %d data =", |
56 endpoint_number)); | 61 endpoint_number)); |
57 for (size_t i = 0; i < data.size(); ++i) | 62 for (size_t i = 0; i < data.size(); ++i) |
58 logger_->AddLog(base::StringPrintf(" 0x%02x", data[i])); | 63 logger_->AddLog(base::StringPrintf(" 0x%02x", data[i])); |
59 logger_->AddLog("\n"); | 64 logger_->AddLog("\n"); |
60 } | 65 } |
61 | 66 |
62 void SetDescriptor(const std::vector<uint8> descriptor) { | 67 void SetDescriptors(const std::vector<uint8> descriptors) { |
63 descriptor_ = descriptor; | 68 descriptors_ = descriptors; |
| 69 } |
| 70 void SetManufacturer(const std::string& manufacturer) { |
| 71 manufacturer_ = manufacturer; |
| 72 } |
| 73 void SetProductName(const std::string& product_name) { |
| 74 product_name_ = product_name; |
| 75 } |
| 76 void SetDeviceVersion(uint16 device_version) { |
| 77 device_version_ = device_version; |
64 } | 78 } |
65 | 79 |
66 private: | 80 private: |
67 std::vector<uint8> descriptor_; | 81 std::vector<uint8> descriptors_; |
| 82 std::string manufacturer_; |
| 83 std::string product_name_; |
| 84 uint16 device_version_; |
68 Logger* logger_; | 85 Logger* logger_; |
69 | 86 |
70 DISALLOW_COPY_AND_ASSIGN(FakeUsbMidiDevice); | 87 DISALLOW_COPY_AND_ASSIGN(FakeUsbMidiDevice); |
71 }; | 88 }; |
72 | 89 |
73 class FakeMidiManagerClient : public MidiManagerClient { | 90 class FakeMidiManagerClient : public MidiManagerClient { |
74 public: | 91 public: |
75 explicit FakeMidiManagerClient(Logger* logger) | 92 explicit FakeMidiManagerClient(Logger* logger) |
76 : complete_start_session_(false), | 93 : complete_start_session_(false), |
77 result_(MIDI_NOT_SUPPORTED), | 94 result_(MIDI_NOT_SUPPORTED), |
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
208 | 225 |
209 private: | 226 private: |
210 scoped_ptr<base::MessageLoop> message_loop_; | 227 scoped_ptr<base::MessageLoop> message_loop_; |
211 | 228 |
212 DISALLOW_COPY_AND_ASSIGN(MidiManagerUsbTest); | 229 DISALLOW_COPY_AND_ASSIGN(MidiManagerUsbTest); |
213 }; | 230 }; |
214 | 231 |
215 | 232 |
216 TEST_F(MidiManagerUsbTest, Initialize) { | 233 TEST_F(MidiManagerUsbTest, Initialize) { |
217 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); | 234 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); |
218 uint8 descriptor[] = { | 235 uint8 descriptors[] = { |
219 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, | 236 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, |
220 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, | 237 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, |
221 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, | 238 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, |
222 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, | 239 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, |
223 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, | 240 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, |
224 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, | 241 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, |
225 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, | 242 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, |
226 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, | 243 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, |
227 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, | 244 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, |
228 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, | 245 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, |
229 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, | 246 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, |
230 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, | 247 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, |
231 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, | 248 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, |
232 0x05, 0x25, 0x01, 0x01, 0x07, | 249 0x05, 0x25, 0x01, 0x01, 0x07, |
233 }; | 250 }; |
234 device->SetDescriptor(ToVector(descriptor)); | 251 device->SetDescriptors(ToVector(descriptors)); |
| 252 device->SetManufacturer("vendor1"); |
| 253 device->SetProductName("device1"); |
| 254 device->SetDeviceVersion(0x0102); |
235 | 255 |
236 Initialize(); | 256 Initialize(); |
237 ScopedVector<UsbMidiDevice> devices; | 257 ScopedVector<UsbMidiDevice> devices; |
238 devices.push_back(device.release()); | 258 devices.push_back(device.release()); |
239 EXPECT_FALSE(IsInitializationCallbackInvoked()); | 259 EXPECT_FALSE(IsInitializationCallbackInvoked()); |
240 RunCallbackUntilCallbackInvoked(true, &devices); | 260 RunCallbackUntilCallbackInvoked(true, &devices); |
241 EXPECT_EQ(MIDI_OK, GetInitializationResult()); | 261 EXPECT_EQ(MIDI_OK, GetInitializationResult()); |
242 | 262 |
243 ASSERT_EQ(1u, input_ports().size()); | 263 ASSERT_EQ(1u, input_ports().size()); |
| 264 EXPECT_EQ("port-0-2", input_ports()[0].id); |
| 265 EXPECT_EQ("vendor1", input_ports()[0].manufacturer); |
| 266 EXPECT_EQ("device1", input_ports()[0].name); |
| 267 EXPECT_EQ("1.02", input_ports()[0].version); |
| 268 |
244 ASSERT_EQ(2u, output_ports().size()); | 269 ASSERT_EQ(2u, output_ports().size()); |
| 270 EXPECT_EQ("port-0-0", output_ports()[0].id); |
| 271 EXPECT_EQ("vendor1", output_ports()[0].manufacturer); |
| 272 EXPECT_EQ("device1", output_ports()[0].name); |
| 273 EXPECT_EQ("1.02", output_ports()[0].version); |
| 274 EXPECT_EQ("port-0-1", output_ports()[1].id); |
| 275 EXPECT_EQ("vendor1", output_ports()[1].manufacturer); |
| 276 EXPECT_EQ("device1", output_ports()[1].name); |
| 277 EXPECT_EQ("1.02", output_ports()[1].version); |
| 278 |
245 ASSERT_TRUE(manager_->input_stream()); | 279 ASSERT_TRUE(manager_->input_stream()); |
246 std::vector<UsbMidiJack> jacks = manager_->input_stream()->jacks(); | 280 std::vector<UsbMidiJack> jacks = manager_->input_stream()->jacks(); |
247 ASSERT_EQ(2u, manager_->output_streams().size()); | 281 ASSERT_EQ(2u, manager_->output_streams().size()); |
248 EXPECT_EQ(2u, manager_->output_streams()[0]->jack().jack_id); | 282 EXPECT_EQ(2u, manager_->output_streams()[0]->jack().jack_id); |
249 EXPECT_EQ(3u, manager_->output_streams()[1]->jack().jack_id); | 283 EXPECT_EQ(3u, manager_->output_streams()[1]->jack().jack_id); |
250 ASSERT_EQ(1u, jacks.size()); | 284 ASSERT_EQ(1u, jacks.size()); |
251 EXPECT_EQ(2, jacks[0].endpoint_number()); | 285 EXPECT_EQ(2, jacks[0].endpoint_number()); |
252 | 286 |
253 EXPECT_EQ("UsbMidiDevice::GetDescriptor\n", logger_.TakeLog()); | 287 EXPECT_EQ("UsbMidiDevice::GetDescriptors\n", logger_.TakeLog()); |
254 } | 288 } |
255 | 289 |
256 TEST_F(MidiManagerUsbTest, InitializeMultipleDevices) { | 290 TEST_F(MidiManagerUsbTest, InitializeMultipleDevices) { |
257 scoped_ptr<FakeUsbMidiDevice> device1(new FakeUsbMidiDevice(&logger_)); | 291 scoped_ptr<FakeUsbMidiDevice> device1(new FakeUsbMidiDevice(&logger_)); |
258 scoped_ptr<FakeUsbMidiDevice> device2(new FakeUsbMidiDevice(&logger_)); | 292 scoped_ptr<FakeUsbMidiDevice> device2(new FakeUsbMidiDevice(&logger_)); |
259 uint8 descriptor[] = { | 293 uint8 descriptors[] = { |
260 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, 0x2d, 0x75, | 294 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, 0x2d, 0x75, |
261 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, 0x75, 0x00, 0x02, 0x01, | 295 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, 0x75, 0x00, 0x02, 0x01, |
262 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, | 296 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, |
263 0x09, 0x24, 0x01, 0x00, 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, | 297 0x09, 0x24, 0x01, 0x00, 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, |
264 0x00, 0x02, 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, | 298 0x00, 0x02, 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, |
265 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, 0x01, 0x03, | 299 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, 0x01, 0x03, |
266 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, 0x24, 0x03, 0x01, 0x07, | 300 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, 0x24, 0x03, 0x01, 0x07, |
267 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, | 301 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, |
268 0x00, 0x09, 0x24, 0x03, 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, | 302 0x00, 0x09, 0x24, 0x03, 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, |
269 0x02, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, | 303 0x02, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, |
270 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, 0x05, 0x25, | 304 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, 0x05, 0x25, |
271 0x01, 0x01, 0x07, | 305 0x01, 0x01, 0x07, |
272 }; | 306 }; |
273 device1->SetDescriptor(ToVector(descriptor)); | 307 device1->SetDescriptors(ToVector(descriptors)); |
274 device2->SetDescriptor(ToVector(descriptor)); | 308 device1->SetManufacturer("vendor1"); |
| 309 device1->SetProductName("device1"); |
| 310 device1->SetDeviceVersion(0x0102); |
| 311 device2->SetDescriptors(ToVector(descriptors)); |
| 312 device2->SetManufacturer("vendor2"); |
| 313 device2->SetProductName("device2"); |
| 314 device2->SetDeviceVersion(0x9876); |
275 | 315 |
276 Initialize(); | 316 Initialize(); |
277 ScopedVector<UsbMidiDevice> devices; | 317 ScopedVector<UsbMidiDevice> devices; |
278 devices.push_back(device1.release()); | 318 devices.push_back(device1.release()); |
279 devices.push_back(device2.release()); | 319 devices.push_back(device2.release()); |
280 EXPECT_FALSE(IsInitializationCallbackInvoked()); | 320 EXPECT_FALSE(IsInitializationCallbackInvoked()); |
281 RunCallbackUntilCallbackInvoked(true, &devices); | 321 RunCallbackUntilCallbackInvoked(true, &devices); |
282 EXPECT_EQ(MIDI_OK, GetInitializationResult()); | 322 EXPECT_EQ(MIDI_OK, GetInitializationResult()); |
283 | 323 |
284 ASSERT_EQ(2u, input_ports().size()); | 324 ASSERT_EQ(2u, input_ports().size()); |
| 325 EXPECT_EQ("port-0-2", input_ports()[0].id); |
| 326 EXPECT_EQ("vendor1", input_ports()[0].manufacturer); |
| 327 EXPECT_EQ("device1", input_ports()[0].name); |
| 328 EXPECT_EQ("1.02", input_ports()[0].version); |
| 329 EXPECT_EQ("port-1-2", input_ports()[1].id); |
| 330 EXPECT_EQ("vendor2", input_ports()[1].manufacturer); |
| 331 EXPECT_EQ("device2", input_ports()[1].name); |
| 332 EXPECT_EQ("98.76", input_ports()[1].version); |
| 333 |
285 ASSERT_EQ(4u, output_ports().size()); | 334 ASSERT_EQ(4u, output_ports().size()); |
| 335 EXPECT_EQ("port-0-0", output_ports()[0].id); |
| 336 EXPECT_EQ("vendor1", output_ports()[0].manufacturer); |
| 337 EXPECT_EQ("device1", output_ports()[0].name); |
| 338 EXPECT_EQ("1.02", output_ports()[0].version); |
| 339 EXPECT_EQ("port-0-1", output_ports()[1].id); |
| 340 EXPECT_EQ("vendor1", output_ports()[1].manufacturer); |
| 341 EXPECT_EQ("device1", output_ports()[1].name); |
| 342 EXPECT_EQ("1.02", output_ports()[1].version); |
| 343 EXPECT_EQ("port-1-0", output_ports()[2].id); |
| 344 EXPECT_EQ("vendor2", output_ports()[2].manufacturer); |
| 345 EXPECT_EQ("device2", output_ports()[2].name); |
| 346 EXPECT_EQ("98.76", output_ports()[2].version); |
| 347 EXPECT_EQ("port-1-1", output_ports()[3].id); |
| 348 EXPECT_EQ("vendor2", output_ports()[3].manufacturer); |
| 349 EXPECT_EQ("device2", output_ports()[3].name); |
| 350 EXPECT_EQ("98.76", output_ports()[3].version); |
| 351 |
286 ASSERT_TRUE(manager_->input_stream()); | 352 ASSERT_TRUE(manager_->input_stream()); |
287 std::vector<UsbMidiJack> jacks = manager_->input_stream()->jacks(); | 353 std::vector<UsbMidiJack> jacks = manager_->input_stream()->jacks(); |
288 ASSERT_EQ(4u, manager_->output_streams().size()); | 354 ASSERT_EQ(4u, manager_->output_streams().size()); |
289 EXPECT_EQ(2u, manager_->output_streams()[0]->jack().jack_id); | 355 EXPECT_EQ(2u, manager_->output_streams()[0]->jack().jack_id); |
290 EXPECT_EQ(3u, manager_->output_streams()[1]->jack().jack_id); | 356 EXPECT_EQ(3u, manager_->output_streams()[1]->jack().jack_id); |
291 ASSERT_EQ(2u, jacks.size()); | 357 ASSERT_EQ(2u, jacks.size()); |
292 EXPECT_EQ(2, jacks[0].endpoint_number()); | 358 EXPECT_EQ(2, jacks[0].endpoint_number()); |
293 | 359 |
294 EXPECT_EQ( | 360 EXPECT_EQ( |
295 "UsbMidiDevice::GetDescriptor\n" | 361 "UsbMidiDevice::GetDescriptors\n" |
296 "UsbMidiDevice::GetDescriptor\n", | 362 "UsbMidiDevice::GetDescriptors\n", |
297 logger_.TakeLog()); | 363 logger_.TakeLog()); |
298 } | 364 } |
299 | 365 |
300 TEST_F(MidiManagerUsbTest, InitializeFail) { | 366 TEST_F(MidiManagerUsbTest, InitializeFail) { |
301 Initialize(); | 367 Initialize(); |
302 | 368 |
303 EXPECT_FALSE(IsInitializationCallbackInvoked()); | 369 EXPECT_FALSE(IsInitializationCallbackInvoked()); |
304 RunCallbackUntilCallbackInvoked(false, NULL); | 370 RunCallbackUntilCallbackInvoked(false, NULL); |
305 EXPECT_EQ(MIDI_INITIALIZATION_ERROR, GetInitializationResult()); | 371 EXPECT_EQ(MIDI_INITIALIZATION_ERROR, GetInitializationResult()); |
306 } | 372 } |
307 | 373 |
308 TEST_F(MidiManagerUsbTest, InitializeFailBecauseOfInvalidDescriptor) { | 374 TEST_F(MidiManagerUsbTest, InitializeFailBecauseOfInvalidDescriptors) { |
309 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); | 375 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); |
310 uint8 descriptor[] = {0x04}; | 376 uint8 descriptors[] = {0x04}; |
311 device->SetDescriptor(ToVector(descriptor)); | 377 device->SetDescriptors(ToVector(descriptors)); |
312 | 378 |
313 Initialize(); | 379 Initialize(); |
314 ScopedVector<UsbMidiDevice> devices; | 380 ScopedVector<UsbMidiDevice> devices; |
315 devices.push_back(device.release()); | 381 devices.push_back(device.release()); |
316 EXPECT_FALSE(IsInitializationCallbackInvoked()); | 382 EXPECT_FALSE(IsInitializationCallbackInvoked()); |
317 RunCallbackUntilCallbackInvoked(true, &devices); | 383 RunCallbackUntilCallbackInvoked(true, &devices); |
318 EXPECT_EQ(MIDI_INITIALIZATION_ERROR, GetInitializationResult()); | 384 EXPECT_EQ(MIDI_INITIALIZATION_ERROR, GetInitializationResult()); |
319 EXPECT_EQ("UsbMidiDevice::GetDescriptor\n", logger_.TakeLog()); | 385 EXPECT_EQ("UsbMidiDevice::GetDescriptors\n", logger_.TakeLog()); |
320 } | 386 } |
321 | 387 |
322 TEST_F(MidiManagerUsbTest, Send) { | 388 TEST_F(MidiManagerUsbTest, Send) { |
323 Initialize(); | 389 Initialize(); |
324 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); | 390 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); |
325 uint8 descriptor[] = { | 391 uint8 descriptors[] = { |
326 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, | 392 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, |
327 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, | 393 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, |
328 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, | 394 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, |
329 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, | 395 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, |
330 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, | 396 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, |
331 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, | 397 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, |
332 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, | 398 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, |
333 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, | 399 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, |
334 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, | 400 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, |
335 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, | 401 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, |
336 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, | 402 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, |
337 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, | 403 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, |
338 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, | 404 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, |
339 0x05, 0x25, 0x01, 0x01, 0x07, | 405 0x05, 0x25, 0x01, 0x01, 0x07, |
340 }; | 406 }; |
341 | 407 |
342 device->SetDescriptor(ToVector(descriptor)); | 408 device->SetDescriptors(ToVector(descriptors)); |
343 uint8 data[] = { | 409 uint8 data[] = { |
344 0x90, 0x45, 0x7f, | 410 0x90, 0x45, 0x7f, |
345 0xf0, 0x00, 0x01, 0xf7, | 411 0xf0, 0x00, 0x01, 0xf7, |
346 }; | 412 }; |
347 | 413 |
348 ScopedVector<UsbMidiDevice> devices; | 414 ScopedVector<UsbMidiDevice> devices; |
349 devices.push_back(device.release()); | 415 devices.push_back(device.release()); |
350 EXPECT_FALSE(IsInitializationCallbackInvoked()); | 416 EXPECT_FALSE(IsInitializationCallbackInvoked()); |
351 RunCallbackUntilCallbackInvoked(true, &devices); | 417 RunCallbackUntilCallbackInvoked(true, &devices); |
352 EXPECT_EQ(MIDI_OK, GetInitializationResult()); | 418 EXPECT_EQ(MIDI_OK, GetInitializationResult()); |
353 ASSERT_EQ(2u, manager_->output_streams().size()); | 419 ASSERT_EQ(2u, manager_->output_streams().size()); |
354 | 420 |
355 manager_->DispatchSendMidiData(client_.get(), 1, ToVector(data), 0); | 421 manager_->DispatchSendMidiData(client_.get(), 1, ToVector(data), 0); |
356 // Since UsbMidiDevice::Send is posted as a task, RunLoop should run to | 422 // Since UsbMidiDevice::Send is posted as a task, RunLoop should run to |
357 // invoke the task. | 423 // invoke the task. |
358 base::RunLoop run_loop; | 424 base::RunLoop run_loop; |
359 run_loop.RunUntilIdle(); | 425 run_loop.RunUntilIdle(); |
360 EXPECT_EQ("UsbMidiDevice::GetDescriptor\n" | 426 EXPECT_EQ("UsbMidiDevice::GetDescriptors\n" |
361 "UsbMidiDevice::Send endpoint = 2 data = " | 427 "UsbMidiDevice::Send endpoint = 2 data = " |
362 "0x19 0x90 0x45 0x7f " | 428 "0x19 0x90 0x45 0x7f " |
363 "0x14 0xf0 0x00 0x01 " | 429 "0x14 0xf0 0x00 0x01 " |
364 "0x15 0xf7 0x00 0x00\n" | 430 "0x15 0xf7 0x00 0x00\n" |
365 "MidiManagerClient::AccumulateMidiBytesSent size = 7\n", | 431 "MidiManagerClient::AccumulateMidiBytesSent size = 7\n", |
366 logger_.TakeLog()); | 432 logger_.TakeLog()); |
367 } | 433 } |
368 | 434 |
369 TEST_F(MidiManagerUsbTest, SendFromCompromizedRenderer) { | 435 TEST_F(MidiManagerUsbTest, SendFromCompromizedRenderer) { |
370 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); | 436 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); |
371 uint8 descriptor[] = { | 437 uint8 descriptors[] = { |
372 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, | 438 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, |
373 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, | 439 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, |
374 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, | 440 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, |
375 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, | 441 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, |
376 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, | 442 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, |
377 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, | 443 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, |
378 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, | 444 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, |
379 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, | 445 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, |
380 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, | 446 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, |
381 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, | 447 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, |
382 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, | 448 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, |
383 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, | 449 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, |
384 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, | 450 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, |
385 0x05, 0x25, 0x01, 0x01, 0x07, | 451 0x05, 0x25, 0x01, 0x01, 0x07, |
386 }; | 452 }; |
387 | 453 |
388 device->SetDescriptor(ToVector(descriptor)); | 454 device->SetDescriptors(ToVector(descriptors)); |
389 uint8 data[] = { | 455 uint8 data[] = { |
390 0x90, 0x45, 0x7f, | 456 0x90, 0x45, 0x7f, |
391 0xf0, 0x00, 0x01, 0xf7, | 457 0xf0, 0x00, 0x01, 0xf7, |
392 }; | 458 }; |
393 | 459 |
394 Initialize(); | 460 Initialize(); |
395 ScopedVector<UsbMidiDevice> devices; | 461 ScopedVector<UsbMidiDevice> devices; |
396 devices.push_back(device.release()); | 462 devices.push_back(device.release()); |
397 EXPECT_FALSE(IsInitializationCallbackInvoked()); | 463 EXPECT_FALSE(IsInitializationCallbackInvoked()); |
398 RunCallbackUntilCallbackInvoked(true, &devices); | 464 RunCallbackUntilCallbackInvoked(true, &devices); |
399 EXPECT_EQ(MIDI_OK, GetInitializationResult()); | 465 EXPECT_EQ(MIDI_OK, GetInitializationResult()); |
400 ASSERT_EQ(2u, manager_->output_streams().size()); | 466 ASSERT_EQ(2u, manager_->output_streams().size()); |
401 EXPECT_EQ("UsbMidiDevice::GetDescriptor\n", logger_.TakeLog()); | 467 EXPECT_EQ("UsbMidiDevice::GetDescriptors\n", logger_.TakeLog()); |
402 | 468 |
403 // The specified port index is invalid. The manager must ignore the request. | 469 // The specified port index is invalid. The manager must ignore the request. |
404 manager_->DispatchSendMidiData(client_.get(), 99, ToVector(data), 0); | 470 manager_->DispatchSendMidiData(client_.get(), 99, ToVector(data), 0); |
405 EXPECT_EQ("", logger_.TakeLog()); | 471 EXPECT_EQ("", logger_.TakeLog()); |
406 | 472 |
407 // The specified port index is invalid. The manager must ignore the request. | 473 // The specified port index is invalid. The manager must ignore the request. |
408 manager_->DispatchSendMidiData(client_.get(), 2, ToVector(data), 0); | 474 manager_->DispatchSendMidiData(client_.get(), 2, ToVector(data), 0); |
409 EXPECT_EQ("", logger_.TakeLog()); | 475 EXPECT_EQ("", logger_.TakeLog()); |
410 } | 476 } |
411 | 477 |
412 TEST_F(MidiManagerUsbTest, Receive) { | 478 TEST_F(MidiManagerUsbTest, Receive) { |
413 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); | 479 scoped_ptr<FakeUsbMidiDevice> device(new FakeUsbMidiDevice(&logger_)); |
414 uint8 descriptor[] = { | 480 uint8 descriptors[] = { |
415 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, | 481 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, |
416 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, | 482 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, |
417 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, | 483 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, |
418 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, | 484 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, |
419 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, | 485 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, |
420 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, | 486 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, |
421 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, | 487 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, |
422 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, | 488 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, |
423 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, | 489 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, |
424 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, | 490 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, |
425 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, | 491 0x02, 0x05, 0x01, 0x03, 0x01, 0x00, 0x09, 0x05, 0x02, 0x02, |
426 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, | 492 0x20, 0x00, 0x00, 0x00, 0x00, 0x06, 0x25, 0x01, 0x02, 0x02, |
427 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, | 493 0x03, 0x09, 0x05, 0x82, 0x02, 0x20, 0x00, 0x00, 0x00, 0x00, |
428 0x05, 0x25, 0x01, 0x01, 0x07, | 494 0x05, 0x25, 0x01, 0x01, 0x07, |
429 }; | 495 }; |
430 | 496 |
431 device->SetDescriptor(ToVector(descriptor)); | 497 device->SetDescriptors(ToVector(descriptors)); |
432 uint8 data[] = { | 498 uint8 data[] = { |
433 0x09, 0x90, 0x45, 0x7f, | 499 0x09, 0x90, 0x45, 0x7f, |
434 0x04, 0xf0, 0x00, 0x01, | 500 0x04, 0xf0, 0x00, 0x01, |
435 0x49, 0x90, 0x88, 0x99, // This data should be ignored (CN = 4). | 501 0x49, 0x90, 0x88, 0x99, // This data should be ignored (CN = 4). |
436 0x05, 0xf7, 0x00, 0x00, | 502 0x05, 0xf7, 0x00, 0x00, |
437 }; | 503 }; |
438 | 504 |
439 Initialize(); | 505 Initialize(); |
440 ScopedVector<UsbMidiDevice> devices; | 506 ScopedVector<UsbMidiDevice> devices; |
441 UsbMidiDevice* device_raw = device.get(); | 507 UsbMidiDevice* device_raw = device.get(); |
442 devices.push_back(device.release()); | 508 devices.push_back(device.release()); |
443 EXPECT_FALSE(IsInitializationCallbackInvoked()); | 509 EXPECT_FALSE(IsInitializationCallbackInvoked()); |
444 RunCallbackUntilCallbackInvoked(true, &devices); | 510 RunCallbackUntilCallbackInvoked(true, &devices); |
445 EXPECT_EQ(MIDI_OK, GetInitializationResult()); | 511 EXPECT_EQ(MIDI_OK, GetInitializationResult()); |
446 | 512 |
447 manager_->ReceiveUsbMidiData(device_raw, 2, data, arraysize(data), | 513 manager_->ReceiveUsbMidiData(device_raw, 2, data, arraysize(data), |
448 base::TimeTicks()); | 514 base::TimeTicks()); |
449 Finalize(); | 515 Finalize(); |
450 | 516 |
451 EXPECT_EQ("UsbMidiDevice::GetDescriptor\n" | 517 EXPECT_EQ("UsbMidiDevice::GetDescriptors\n" |
452 "MidiManagerClient::ReceiveMidiData port_index = 0 " | 518 "MidiManagerClient::ReceiveMidiData port_index = 0 " |
453 "data = 0x90 0x45 0x7f\n" | 519 "data = 0x90 0x45 0x7f\n" |
454 "MidiManagerClient::ReceiveMidiData port_index = 0 " | 520 "MidiManagerClient::ReceiveMidiData port_index = 0 " |
455 "data = 0xf0 0x00 0x01\n" | 521 "data = 0xf0 0x00 0x01\n" |
456 "MidiManagerClient::ReceiveMidiData port_index = 0 data = 0xf7\n", | 522 "MidiManagerClient::ReceiveMidiData port_index = 0 data = 0xf7\n", |
457 logger_.TakeLog()); | 523 logger_.TakeLog()); |
458 } | 524 } |
459 | 525 |
460 TEST_F(MidiManagerUsbTest, AttachDevice) { | 526 TEST_F(MidiManagerUsbTest, AttachDevice) { |
461 uint8 descriptor[] = { | 527 uint8 descriptors[] = { |
462 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, | 528 0x12, 0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x08, 0x86, 0x1a, |
463 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, | 529 0x2d, 0x75, 0x54, 0x02, 0x00, 0x02, 0x00, 0x01, 0x09, 0x02, |
464 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, | 530 0x75, 0x00, 0x02, 0x01, 0x00, 0x80, 0x30, 0x09, 0x04, 0x00, |
465 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, | 531 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, |
466 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, | 532 0x01, 0x09, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x00, 0x02, |
467 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, | 533 0x01, 0x03, 0x00, 0x00, 0x07, 0x24, 0x01, 0x00, 0x01, 0x51, |
468 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, | 534 0x00, 0x06, 0x24, 0x02, 0x01, 0x02, 0x00, 0x06, 0x24, 0x02, |
469 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, | 535 0x01, 0x03, 0x00, 0x06, 0x24, 0x02, 0x02, 0x06, 0x00, 0x09, |
470 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, | 536 0x24, 0x03, 0x01, 0x07, 0x01, 0x06, 0x01, 0x00, 0x09, 0x24, |
471 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, | 537 0x03, 0x02, 0x04, 0x01, 0x02, 0x01, 0x00, 0x09, 0x24, 0x03, |
(...skipping 11 matching lines...) Expand all Loading... |
483 | 549 |
484 ASSERT_EQ(0u, input_ports().size()); | 550 ASSERT_EQ(0u, input_ports().size()); |
485 ASSERT_EQ(0u, output_ports().size()); | 551 ASSERT_EQ(0u, output_ports().size()); |
486 ASSERT_TRUE(manager_->input_stream()); | 552 ASSERT_TRUE(manager_->input_stream()); |
487 std::vector<UsbMidiJack> jacks = manager_->input_stream()->jacks(); | 553 std::vector<UsbMidiJack> jacks = manager_->input_stream()->jacks(); |
488 ASSERT_EQ(0u, manager_->output_streams().size()); | 554 ASSERT_EQ(0u, manager_->output_streams().size()); |
489 ASSERT_EQ(0u, jacks.size()); | 555 ASSERT_EQ(0u, jacks.size()); |
490 EXPECT_EQ("", logger_.TakeLog()); | 556 EXPECT_EQ("", logger_.TakeLog()); |
491 | 557 |
492 scoped_ptr<FakeUsbMidiDevice> new_device(new FakeUsbMidiDevice(&logger_)); | 558 scoped_ptr<FakeUsbMidiDevice> new_device(new FakeUsbMidiDevice(&logger_)); |
493 new_device->SetDescriptor(ToVector(descriptor)); | 559 new_device->SetDescriptors(ToVector(descriptors)); |
494 manager_->OnDeviceAttached(new_device.Pass()); | 560 manager_->OnDeviceAttached(new_device.Pass()); |
495 | 561 |
496 ASSERT_EQ(1u, input_ports().size()); | 562 ASSERT_EQ(1u, input_ports().size()); |
497 ASSERT_EQ(2u, output_ports().size()); | 563 ASSERT_EQ(2u, output_ports().size()); |
498 ASSERT_TRUE(manager_->input_stream()); | 564 ASSERT_TRUE(manager_->input_stream()); |
499 jacks = manager_->input_stream()->jacks(); | 565 jacks = manager_->input_stream()->jacks(); |
500 ASSERT_EQ(2u, manager_->output_streams().size()); | 566 ASSERT_EQ(2u, manager_->output_streams().size()); |
501 EXPECT_EQ(2u, manager_->output_streams()[0]->jack().jack_id); | 567 EXPECT_EQ(2u, manager_->output_streams()[0]->jack().jack_id); |
502 EXPECT_EQ(3u, manager_->output_streams()[1]->jack().jack_id); | 568 EXPECT_EQ(3u, manager_->output_streams()[1]->jack().jack_id); |
503 ASSERT_EQ(1u, jacks.size()); | 569 ASSERT_EQ(1u, jacks.size()); |
504 EXPECT_EQ(2, jacks[0].endpoint_number()); | 570 EXPECT_EQ(2, jacks[0].endpoint_number()); |
505 EXPECT_EQ("UsbMidiDevice::GetDescriptor\n", logger_.TakeLog()); | 571 EXPECT_EQ("UsbMidiDevice::GetDescriptors\n", logger_.TakeLog()); |
506 } | 572 } |
507 | 573 |
508 } // namespace | 574 } // namespace |
509 | 575 |
510 } // namespace media | 576 } // namespace media |
OLD | NEW |