blob: 055e1ad1c68d94f8a61163103ed21aec07fdde69 [file] [log] [blame]
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001// libjingle
2// Copyright 2008 Google Inc.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are met:
6//
7// 1. Redistributions of source code must retain the above copyright notice,
8// this list of conditions and the following disclaimer.
9// 2. Redistributions in binary form must reproduce the above copyright notice,
10// this list of conditions and the following disclaimer in the documentation
11// and/or other materials provided with the distribution.
12// 3. The name of the author may not be used to endorse or promote products
13// derived from this software without specific prior written permission.
14//
15// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
16// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
17// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
18// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
19// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
20// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
21// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
22// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
23// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
24// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25
26#include "talk/base/gunit.h"
27#include "talk/base/logging.h"
28#include "talk/base/thread.h"
29#include "talk/media/base/fakecapturemanager.h"
30#include "talk/media/base/fakemediaengine.h"
31#include "talk/media/base/fakemediaprocessor.h"
32#include "talk/media/base/nullvideorenderer.h"
33#include "talk/media/devices/fakedevicemanager.h"
34#include "talk/media/base/testutils.h"
35#include "talk/p2p/base/fakesession.h"
36#include "talk/session/media/channelmanager.h"
37
38namespace cricket {
39
40static const AudioCodec kAudioCodecs[] = {
41 AudioCodec(97, "voice", 1, 2, 3, 0),
42 AudioCodec(110, "CELT", 32000, 48000, 2, 0),
43 AudioCodec(111, "OPUS", 48000, 32000, 2, 0),
44};
45
46static const VideoCodec kVideoCodecs[] = {
47 VideoCodec(99, "H264", 100, 200, 300, 0),
48 VideoCodec(100, "VP8", 100, 200, 300, 0),
49 VideoCodec(96, "rtx", 100, 200, 300, 0),
50};
51
52class ChannelManagerTest : public testing::Test {
53 protected:
54 ChannelManagerTest() : fme_(NULL), fdm_(NULL), fcm_(NULL), cm_(NULL) {
55 }
56
57 virtual void SetUp() {
58 fme_ = new cricket::FakeMediaEngine();
59 fme_->SetAudioCodecs(MAKE_VECTOR(kAudioCodecs));
60 fme_->SetVideoCodecs(MAKE_VECTOR(kVideoCodecs));
61 fdme_ = new cricket::FakeDataEngine();
62 fdm_ = new cricket::FakeDeviceManager();
63 fcm_ = new cricket::FakeCaptureManager();
64 cm_ = new cricket::ChannelManager(
65 fme_, fdme_, fdm_, fcm_, talk_base::Thread::Current());
66 session_ = new cricket::FakeSession(true);
67
68 std::vector<std::string> in_device_list, out_device_list, vid_device_list;
69 in_device_list.push_back("audio-in1");
70 in_device_list.push_back("audio-in2");
71 out_device_list.push_back("audio-out1");
72 out_device_list.push_back("audio-out2");
73 vid_device_list.push_back("video-in1");
74 vid_device_list.push_back("video-in2");
75 fdm_->SetAudioInputDevices(in_device_list);
76 fdm_->SetAudioOutputDevices(out_device_list);
77 fdm_->SetVideoCaptureDevices(vid_device_list);
78 }
79
80 virtual void TearDown() {
81 delete session_;
82 delete cm_;
83 cm_ = NULL;
84 fdm_ = NULL;
85 fcm_ = NULL;
86 fdme_ = NULL;
87 fme_ = NULL;
88 }
89
90 talk_base::Thread worker_;
91 cricket::FakeMediaEngine* fme_;
92 cricket::FakeDataEngine* fdme_;
93 cricket::FakeDeviceManager* fdm_;
94 cricket::FakeCaptureManager* fcm_;
95 cricket::ChannelManager* cm_;
96 cricket::FakeSession* session_;
97};
98
99// Test that we startup/shutdown properly.
100TEST_F(ChannelManagerTest, StartupShutdown) {
101 EXPECT_FALSE(cm_->initialized());
102 EXPECT_EQ(talk_base::Thread::Current(), cm_->worker_thread());
103 EXPECT_TRUE(cm_->Init());
104 EXPECT_TRUE(cm_->initialized());
105 cm_->Terminate();
106 EXPECT_FALSE(cm_->initialized());
107}
108
109// Test that we startup/shutdown properly with a worker thread.
110TEST_F(ChannelManagerTest, StartupShutdownOnThread) {
111 worker_.Start();
112 EXPECT_FALSE(cm_->initialized());
113 EXPECT_EQ(talk_base::Thread::Current(), cm_->worker_thread());
114 EXPECT_TRUE(cm_->set_worker_thread(&worker_));
115 EXPECT_EQ(&worker_, cm_->worker_thread());
116 EXPECT_TRUE(cm_->Init());
117 EXPECT_TRUE(cm_->initialized());
118 // Setting the worker thread while initialized should fail.
119 EXPECT_FALSE(cm_->set_worker_thread(talk_base::Thread::Current()));
120 cm_->Terminate();
121 EXPECT_FALSE(cm_->initialized());
122}
123
124// Test that we fail to startup if we're given an unstarted thread.
fischman@webrtc.org39eccef2014-05-23 17:50:38 +0000125// TODO(fischman): delete once Thread::RunningForChannelManager() is gone
126// (webrtc:3388).
127TEST_F(ChannelManagerTest, DISABLED_StartupShutdownOnUnstartedThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000128 EXPECT_TRUE(cm_->set_worker_thread(&worker_));
129 EXPECT_FALSE(cm_->Init());
130 EXPECT_FALSE(cm_->initialized());
131}
132
133// Test that we can create and destroy a voice and video channel.
134TEST_F(ChannelManagerTest, CreateDestroyChannels) {
135 EXPECT_TRUE(cm_->Init());
136 cricket::VoiceChannel* voice_channel = cm_->CreateVoiceChannel(
137 session_, cricket::CN_AUDIO, false);
138 EXPECT_TRUE(voice_channel != NULL);
139 cricket::VideoChannel* video_channel =
140 cm_->CreateVideoChannel(session_, cricket::CN_VIDEO,
141 false, voice_channel);
142 EXPECT_TRUE(video_channel != NULL);
143 cricket::DataChannel* data_channel =
144 cm_->CreateDataChannel(session_, cricket::CN_DATA,
145 false, cricket::DCT_RTP);
146 EXPECT_TRUE(data_channel != NULL);
147 cm_->DestroyVideoChannel(video_channel);
148 cm_->DestroyVoiceChannel(voice_channel);
149 cm_->DestroyDataChannel(data_channel);
150 cm_->Terminate();
151}
152
153// Test that we can create and destroy a voice and video channel with a worker.
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000154TEST_F(ChannelManagerTest, CreateDestroyChannelsOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000155 worker_.Start();
156 EXPECT_TRUE(cm_->set_worker_thread(&worker_));
157 EXPECT_TRUE(cm_->Init());
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000158 delete session_;
wu@webrtc.org1d1ffc92013-10-16 18:12:02 +0000159 session_ = new cricket::FakeSession(&worker_, true);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000160 cricket::VoiceChannel* voice_channel = cm_->CreateVoiceChannel(
161 session_, cricket::CN_AUDIO, false);
162 EXPECT_TRUE(voice_channel != NULL);
163 cricket::VideoChannel* video_channel =
164 cm_->CreateVideoChannel(session_, cricket::CN_VIDEO,
165 false, voice_channel);
166 EXPECT_TRUE(video_channel != NULL);
167 cricket::DataChannel* data_channel =
168 cm_->CreateDataChannel(session_, cricket::CN_DATA,
169 false, cricket::DCT_RTP);
170 EXPECT_TRUE(data_channel != NULL);
171 cm_->DestroyVideoChannel(video_channel);
172 cm_->DestroyVoiceChannel(voice_channel);
173 cm_->DestroyDataChannel(data_channel);
174 cm_->Terminate();
175}
176
177// Test that we fail to create a voice/video channel if the session is unable
178// to create a cricket::TransportChannel
179TEST_F(ChannelManagerTest, NoTransportChannelTest) {
180 EXPECT_TRUE(cm_->Init());
181 session_->set_fail_channel_creation(true);
182 // The test is useless unless the session does not fail creating
183 // cricket::TransportChannel.
184 ASSERT_TRUE(session_->CreateChannel(
185 "audio", "rtp", cricket::ICE_CANDIDATE_COMPONENT_RTP) == NULL);
186
187 cricket::VoiceChannel* voice_channel = cm_->CreateVoiceChannel(
188 session_, cricket::CN_AUDIO, false);
189 EXPECT_TRUE(voice_channel == NULL);
190 cricket::VideoChannel* video_channel =
191 cm_->CreateVideoChannel(session_, cricket::CN_VIDEO,
192 false, voice_channel);
193 EXPECT_TRUE(video_channel == NULL);
194 cricket::DataChannel* data_channel =
195 cm_->CreateDataChannel(session_, cricket::CN_DATA,
196 false, cricket::DCT_RTP);
197 EXPECT_TRUE(data_channel == NULL);
198 cm_->Terminate();
199}
200
201// Test that SetDefaultVideoCodec passes through the right values.
202TEST_F(ChannelManagerTest, SetDefaultVideoEncoderConfig) {
203 cricket::VideoCodec codec(96, "G264", 1280, 720, 60, 0);
204 cricket::VideoEncoderConfig config(codec, 1, 2);
205 EXPECT_TRUE(cm_->Init());
206 EXPECT_TRUE(cm_->SetDefaultVideoEncoderConfig(config));
207 EXPECT_EQ(config, fme_->default_video_encoder_config());
208}
209
sergeyu@chromium.orga59696b2013-09-13 23:48:58 +0000210struct GetCapturerFrameSize : public sigslot::has_slots<> {
211 void OnVideoFrame(VideoCapturer* capturer, const VideoFrame* frame) {
212 width = frame->GetWidth();
213 height = frame->GetHeight();
214 }
215 GetCapturerFrameSize(VideoCapturer* capturer) : width(0), height(0) {
216 capturer->SignalVideoFrame.connect(this,
217 &GetCapturerFrameSize::OnVideoFrame);
218 static_cast<FakeVideoCapturer*>(capturer)->CaptureFrame();
219 }
220 size_t width;
221 size_t height;
222};
223
224TEST_F(ChannelManagerTest, DefaultCapturerAspectRatio) {
225 VideoCodec codec(100, "VP8", 640, 360, 30, 0);
226 VideoFormat format(640, 360, 33, FOURCC_ANY);
227 VideoEncoderConfig config(codec, 1, 2);
228 EXPECT_TRUE(cm_->Init());
229 // A capturer created before the default encoder config is set will have no
230 // set aspect ratio, so it'll be 4:3 (based on the fake video capture impl).
231 VideoCapturer* capturer = cm_->CreateVideoCapturer();
232 ASSERT_TRUE(capturer != NULL);
233 EXPECT_EQ(CS_RUNNING, capturer->Start(format));
234 GetCapturerFrameSize size(capturer);
235 EXPECT_EQ(640u, size.width);
236 EXPECT_EQ(480u, size.height);
237 delete capturer;
238 // Try again, but with the encoder config set to 16:9.
239 EXPECT_TRUE(cm_->SetDefaultVideoEncoderConfig(config));
240 capturer = cm_->CreateVideoCapturer();
241 ASSERT_TRUE(capturer != NULL);
242 EXPECT_EQ(CS_RUNNING, capturer->Start(format));
243 GetCapturerFrameSize cropped_size(capturer);
244 EXPECT_EQ(640u, cropped_size.width);
245 EXPECT_EQ(360u, cropped_size.height);
246 delete capturer;
247}
248
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000249// Test that SetDefaultVideoCodec passes through the right values.
250TEST_F(ChannelManagerTest, SetDefaultVideoCodecBeforeInit) {
251 cricket::VideoCodec codec(96, "G264", 1280, 720, 60, 0);
252 cricket::VideoEncoderConfig config(codec, 1, 2);
253 EXPECT_TRUE(cm_->SetDefaultVideoEncoderConfig(config));
254 EXPECT_TRUE(cm_->Init());
255 EXPECT_EQ(config, fme_->default_video_encoder_config());
256}
257
258TEST_F(ChannelManagerTest, SetAudioOptionsBeforeInit) {
259 // Test that values that we set before Init are applied.
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000260 AudioOptions options;
261 options.auto_gain_control.Set(true);
262 options.echo_cancellation.Set(false);
263 EXPECT_TRUE(cm_->SetAudioOptions("audio-in1", "audio-out1", options));
264 std::string audio_in, audio_out;
265 AudioOptions set_options;
266 // Check options before Init.
267 EXPECT_TRUE(cm_->GetAudioOptions(&audio_in, &audio_out, &set_options));
268 EXPECT_EQ("audio-in1", audio_in);
269 EXPECT_EQ("audio-out1", audio_out);
270 EXPECT_EQ(options, set_options);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000271 EXPECT_TRUE(cm_->Init());
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000272 // Check options after Init.
273 EXPECT_TRUE(cm_->GetAudioOptions(&audio_in, &audio_out, &set_options));
274 EXPECT_EQ("audio-in1", audio_in);
275 EXPECT_EQ("audio-out1", audio_out);
276 EXPECT_EQ(options, set_options);
277 // At this point, the media engine should also be initialized.
278 EXPECT_EQ(options, fme_->audio_options());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000279 EXPECT_EQ(cricket::MediaEngineInterface::kDefaultAudioDelayOffset,
280 fme_->audio_delay_offset());
281}
282
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000283TEST_F(ChannelManagerTest, GetAudioOptionsWithNullParameters) {
284 std::string audio_in, audio_out;
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000285 AudioOptions options;
286 options.echo_cancellation.Set(true);
287 EXPECT_TRUE(cm_->SetAudioOptions("audio-in2", "audio-out2", options));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000288 EXPECT_TRUE(cm_->GetAudioOptions(&audio_in, NULL, NULL));
289 EXPECT_EQ("audio-in2", audio_in);
290 EXPECT_TRUE(cm_->GetAudioOptions(NULL, &audio_out, NULL));
291 EXPECT_EQ("audio-out2", audio_out);
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000292 AudioOptions out_options;
293 EXPECT_TRUE(cm_->GetAudioOptions(NULL, NULL, &out_options));
294 bool echo_cancellation = false;
295 EXPECT_TRUE(out_options.echo_cancellation.Get(&echo_cancellation));
296 EXPECT_TRUE(echo_cancellation);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000297}
298
299TEST_F(ChannelManagerTest, SetAudioOptions) {
300 // Test initial state.
301 EXPECT_TRUE(cm_->Init());
302 EXPECT_EQ(std::string(cricket::DeviceManagerInterface::kDefaultDeviceName),
303 fme_->audio_in_device());
304 EXPECT_EQ(std::string(cricket::DeviceManagerInterface::kDefaultDeviceName),
305 fme_->audio_out_device());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000306 EXPECT_EQ(cricket::MediaEngineInterface::kDefaultAudioDelayOffset,
307 fme_->audio_delay_offset());
308 // Test setting specific values.
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000309 AudioOptions options;
310 options.auto_gain_control.Set(true);
311 EXPECT_TRUE(cm_->SetAudioOptions("audio-in1", "audio-out1", options));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000312 EXPECT_EQ("audio-in1", fme_->audio_in_device());
313 EXPECT_EQ("audio-out1", fme_->audio_out_device());
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000314 bool auto_gain_control = false;
315 EXPECT_TRUE(
316 fme_->audio_options().auto_gain_control.Get(&auto_gain_control));
317 EXPECT_TRUE(auto_gain_control);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000318 EXPECT_EQ(cricket::MediaEngineInterface::kDefaultAudioDelayOffset,
319 fme_->audio_delay_offset());
320 // Test setting bad values.
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000321 EXPECT_FALSE(cm_->SetAudioOptions("audio-in9", "audio-out2", options));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000322}
323
324TEST_F(ChannelManagerTest, SetCaptureDeviceBeforeInit) {
325 // Test that values that we set before Init are applied.
326 EXPECT_TRUE(cm_->SetCaptureDevice("video-in2"));
327 EXPECT_TRUE(cm_->Init());
328 EXPECT_EQ("video-in2", cm_->video_device_name());
329}
330
331TEST_F(ChannelManagerTest, GetCaptureDeviceBeforeInit) {
332 std::string video_in;
333 // Test that GetCaptureDevice works before Init.
334 EXPECT_TRUE(cm_->SetCaptureDevice("video-in1"));
335 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
336 EXPECT_EQ("video-in1", video_in);
337 // Test that options set before Init can be gotten after Init.
338 EXPECT_TRUE(cm_->SetCaptureDevice("video-in2"));
339 EXPECT_TRUE(cm_->Init());
340 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
341 EXPECT_EQ("video-in2", video_in);
342}
343
344TEST_F(ChannelManagerTest, SetCaptureDevice) {
345 // Test setting defaults.
346 EXPECT_TRUE(cm_->Init());
347 EXPECT_TRUE(cm_->SetCaptureDevice("")); // will use DeviceManager default
348 EXPECT_EQ("video-in1", cm_->video_device_name());
349 // Test setting specific values.
350 EXPECT_TRUE(cm_->SetCaptureDevice("video-in2"));
351 EXPECT_EQ("video-in2", cm_->video_device_name());
352 // TODO(juberti): Add test for invalid value here.
353}
354
355// Test unplugging and plugging back the preferred devices. When the preferred
356// device is unplugged, we fall back to the default device. When the preferred
357// device is plugged back, we use it.
358TEST_F(ChannelManagerTest, SetAudioOptionsUnplugPlug) {
359 // Set preferences "audio-in1" and "audio-out1" before init.
mallinath@webrtc.orga27be8e2013-09-27 23:04:10 +0000360 AudioOptions options;
361 EXPECT_TRUE(cm_->SetAudioOptions("audio-in1", "audio-out1", options));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000362 // Unplug device "audio-in1" and "audio-out1".
363 std::vector<std::string> in_device_list, out_device_list;
364 in_device_list.push_back("audio-in2");
365 out_device_list.push_back("audio-out2");
366 fdm_->SetAudioInputDevices(in_device_list);
367 fdm_->SetAudioOutputDevices(out_device_list);
368 // Init should fall back to default devices.
369 EXPECT_TRUE(cm_->Init());
370 // The media engine should use the default.
371 EXPECT_EQ("", fme_->audio_in_device());
372 EXPECT_EQ("", fme_->audio_out_device());
373 // The channel manager keeps the preferences "audio-in1" and "audio-out1".
374 std::string audio_in, audio_out;
375 EXPECT_TRUE(cm_->GetAudioOptions(&audio_in, &audio_out, NULL));
376 EXPECT_EQ("audio-in1", audio_in);
377 EXPECT_EQ("audio-out1", audio_out);
378 cm_->Terminate();
379
380 // Plug devices "audio-in2" and "audio-out2" back.
381 in_device_list.push_back("audio-in1");
382 out_device_list.push_back("audio-out1");
383 fdm_->SetAudioInputDevices(in_device_list);
384 fdm_->SetAudioOutputDevices(out_device_list);
385 // Init again. The preferences, "audio-in2" and "audio-out2", are used.
386 EXPECT_TRUE(cm_->Init());
387 EXPECT_EQ("audio-in1", fme_->audio_in_device());
388 EXPECT_EQ("audio-out1", fme_->audio_out_device());
389 EXPECT_TRUE(cm_->GetAudioOptions(&audio_in, &audio_out, NULL));
390 EXPECT_EQ("audio-in1", audio_in);
391 EXPECT_EQ("audio-out1", audio_out);
392}
393
394// We have one camera. Unplug it, fall back to no camera.
395TEST_F(ChannelManagerTest, SetCaptureDeviceUnplugPlugOneCamera) {
396 // Set preferences "video-in1" before init.
397 std::vector<std::string> vid_device_list;
398 vid_device_list.push_back("video-in1");
399 fdm_->SetVideoCaptureDevices(vid_device_list);
400 EXPECT_TRUE(cm_->SetCaptureDevice("video-in1"));
401
402 // Unplug "video-in1".
403 vid_device_list.clear();
404 fdm_->SetVideoCaptureDevices(vid_device_list);
405
406 // Init should fall back to avatar.
407 EXPECT_TRUE(cm_->Init());
408 // The media engine should use no camera.
409 EXPECT_EQ("", cm_->video_device_name());
410 // The channel manager keeps the user preference "video-in".
411 std::string video_in;
412 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
413 EXPECT_EQ("video-in1", video_in);
414 cm_->Terminate();
415
416 // Plug device "video-in1" back.
417 vid_device_list.push_back("video-in1");
418 fdm_->SetVideoCaptureDevices(vid_device_list);
419 // Init again. The user preferred device, "video-in1", is used.
420 EXPECT_TRUE(cm_->Init());
421 EXPECT_EQ("video-in1", cm_->video_device_name());
422 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
423 EXPECT_EQ("video-in1", video_in);
424}
425
426// We have multiple cameras. Unplug the preferred, fall back to another camera.
427TEST_F(ChannelManagerTest, SetCaptureDeviceUnplugPlugTwoDevices) {
428 // Set video device to "video-in1" before init.
429 EXPECT_TRUE(cm_->SetCaptureDevice("video-in1"));
430 // Unplug device "video-in1".
431 std::vector<std::string> vid_device_list;
432 vid_device_list.push_back("video-in2");
433 fdm_->SetVideoCaptureDevices(vid_device_list);
434 // Init should fall back to default device "video-in2".
435 EXPECT_TRUE(cm_->Init());
436 // The media engine should use the default device "video-in2".
437 EXPECT_EQ("video-in2", cm_->video_device_name());
438 // The channel manager keeps the user preference "video-in".
439 std::string video_in;
440 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
441 EXPECT_EQ("video-in1", video_in);
442 cm_->Terminate();
443
444 // Plug device "video-in1" back.
445 vid_device_list.push_back("video-in1");
446 fdm_->SetVideoCaptureDevices(vid_device_list);
447 // Init again. The user preferred device, "video-in1", is used.
448 EXPECT_TRUE(cm_->Init());
449 EXPECT_EQ("video-in1", cm_->video_device_name());
450 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
451 EXPECT_EQ("video-in1", video_in);
452}
453
454TEST_F(ChannelManagerTest, GetCaptureDevice) {
455 std::string video_in;
456 // Test setting/getting defaults.
457 EXPECT_TRUE(cm_->Init());
458 EXPECT_TRUE(cm_->SetCaptureDevice(""));
459 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
460 EXPECT_EQ("video-in1", video_in);
461 // Test setting/getting specific values.
462 EXPECT_TRUE(cm_->SetCaptureDevice("video-in2"));
463 EXPECT_TRUE(cm_->GetCaptureDevice(&video_in));
464 EXPECT_EQ("video-in2", video_in);
465}
466
467TEST_F(ChannelManagerTest, GetSetOutputVolumeBeforeInit) {
468 int level;
469 // Before init, SetOutputVolume() remembers the volume but does not change the
470 // volume of the engine. GetOutputVolume() should fail.
471 EXPECT_EQ(-1, fme_->output_volume());
472 EXPECT_FALSE(cm_->GetOutputVolume(&level));
473 EXPECT_FALSE(cm_->SetOutputVolume(-1)); // Invalid volume.
474 EXPECT_TRUE(cm_->SetOutputVolume(99));
475 EXPECT_EQ(-1, fme_->output_volume());
476
477 // Init() will apply the remembered volume.
478 EXPECT_TRUE(cm_->Init());
479 EXPECT_TRUE(cm_->GetOutputVolume(&level));
480 EXPECT_EQ(99, level);
481 EXPECT_EQ(level, fme_->output_volume());
482
483 EXPECT_TRUE(cm_->SetOutputVolume(60));
484 EXPECT_TRUE(cm_->GetOutputVolume(&level));
485 EXPECT_EQ(60, level);
486 EXPECT_EQ(level, fme_->output_volume());
487}
488
489TEST_F(ChannelManagerTest, GetSetOutputVolume) {
490 int level;
491 EXPECT_TRUE(cm_->Init());
492 EXPECT_TRUE(cm_->GetOutputVolume(&level));
493 EXPECT_EQ(level, fme_->output_volume());
494
495 EXPECT_FALSE(cm_->SetOutputVolume(-1)); // Invalid volume.
496 EXPECT_TRUE(cm_->SetOutputVolume(60));
497 EXPECT_EQ(60, fme_->output_volume());
498 EXPECT_TRUE(cm_->GetOutputVolume(&level));
499 EXPECT_EQ(60, level);
500}
501
502// Test that a value set before Init is applied properly.
503TEST_F(ChannelManagerTest, SetLocalRendererBeforeInit) {
504 cricket::NullVideoRenderer renderer;
505 EXPECT_TRUE(cm_->SetLocalRenderer(&renderer));
506 EXPECT_TRUE(cm_->Init());
507 EXPECT_EQ(&renderer, fme_->local_renderer());
508}
509
510// Test that a value set after init is passed through properly.
511TEST_F(ChannelManagerTest, SetLocalRenderer) {
512 cricket::NullVideoRenderer renderer;
513 EXPECT_TRUE(cm_->Init());
514 EXPECT_TRUE(cm_->SetLocalRenderer(&renderer));
515 EXPECT_EQ(&renderer, fme_->local_renderer());
516}
517
518// Test that logging options set before Init are applied properly,
519// and retained even after Init.
520TEST_F(ChannelManagerTest, SetLoggingBeforeInit) {
521 cm_->SetVoiceLogging(talk_base::LS_INFO, "test-voice");
522 cm_->SetVideoLogging(talk_base::LS_VERBOSE, "test-video");
523 EXPECT_EQ(talk_base::LS_INFO, fme_->voice_loglevel());
524 EXPECT_STREQ("test-voice", fme_->voice_logfilter().c_str());
525 EXPECT_EQ(talk_base::LS_VERBOSE, fme_->video_loglevel());
526 EXPECT_STREQ("test-video", fme_->video_logfilter().c_str());
527 EXPECT_TRUE(cm_->Init());
528 EXPECT_EQ(talk_base::LS_INFO, fme_->voice_loglevel());
529 EXPECT_STREQ("test-voice", fme_->voice_logfilter().c_str());
530 EXPECT_EQ(talk_base::LS_VERBOSE, fme_->video_loglevel());
531 EXPECT_STREQ("test-video", fme_->video_logfilter().c_str());
532}
533
534// Test that logging options set after Init are applied properly.
535TEST_F(ChannelManagerTest, SetLogging) {
536 EXPECT_TRUE(cm_->Init());
537 cm_->SetVoiceLogging(talk_base::LS_INFO, "test-voice");
538 cm_->SetVideoLogging(talk_base::LS_VERBOSE, "test-video");
539 EXPECT_EQ(talk_base::LS_INFO, fme_->voice_loglevel());
540 EXPECT_STREQ("test-voice", fme_->voice_logfilter().c_str());
541 EXPECT_EQ(talk_base::LS_VERBOSE, fme_->video_loglevel());
542 EXPECT_STREQ("test-video", fme_->video_logfilter().c_str());
543}
544
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000545// Test that the Video/Voice Processors register and unregister
546TEST_F(ChannelManagerTest, RegisterProcessors) {
547 cricket::FakeMediaProcessor fmp;
548 EXPECT_TRUE(cm_->Init());
549 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_TX));
550 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_RX));
551
552 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_TX));
553 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_RX));
554
555 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_TX));
556 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_RX));
557
558 EXPECT_TRUE(cm_->RegisterVoiceProcessor(1,
559 &fmp,
560 cricket::MPD_RX));
561 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_TX));
562 EXPECT_TRUE(fme_->voice_processor_registered(cricket::MPD_RX));
563
564
565 EXPECT_TRUE(cm_->UnregisterVoiceProcessor(1,
566 &fmp,
567 cricket::MPD_RX));
568 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_TX));
569 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_RX));
570
571 EXPECT_TRUE(cm_->RegisterVoiceProcessor(1,
572 &fmp,
573 cricket::MPD_TX));
574 EXPECT_TRUE(fme_->voice_processor_registered(cricket::MPD_TX));
575 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_RX));
576
577 EXPECT_TRUE(cm_->UnregisterVoiceProcessor(1,
578 &fmp,
579 cricket::MPD_TX));
580 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_TX));
581 EXPECT_FALSE(fme_->voice_processor_registered(cricket::MPD_RX));
582}
583
584TEST_F(ChannelManagerTest, SetVideoRtxEnabled) {
585 std::vector<VideoCodec> codecs;
586 const VideoCodec rtx_codec(96, "rtx", 0, 0, 0, 0);
587
588 // By default RTX is disabled.
589 cm_->GetSupportedVideoCodecs(&codecs);
590 EXPECT_FALSE(ContainsMatchingCodec(codecs, rtx_codec));
591
592 // Enable and check.
593 EXPECT_TRUE(cm_->SetVideoRtxEnabled(true));
594 cm_->GetSupportedVideoCodecs(&codecs);
595 EXPECT_TRUE(ContainsMatchingCodec(codecs, rtx_codec));
596
597 // Disable and check.
598 EXPECT_TRUE(cm_->SetVideoRtxEnabled(false));
599 cm_->GetSupportedVideoCodecs(&codecs);
600 EXPECT_FALSE(ContainsMatchingCodec(codecs, rtx_codec));
601
602 // Cannot toggle rtx after initialization.
603 EXPECT_TRUE(cm_->Init());
604 EXPECT_FALSE(cm_->SetVideoRtxEnabled(true));
605 EXPECT_FALSE(cm_->SetVideoRtxEnabled(false));
606
607 // Can set again after terminate.
608 cm_->Terminate();
609 EXPECT_TRUE(cm_->SetVideoRtxEnabled(true));
610 cm_->GetSupportedVideoCodecs(&codecs);
611 EXPECT_TRUE(ContainsMatchingCodec(codecs, rtx_codec));
612}
613
614} // namespace cricket