OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2008 The WebRTC project authors. All Rights Reserved. | 2 * Copyright 2008 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
11 #include <memory> | |
12 | |
11 #include "webrtc/base/gunit.h" | 13 #include "webrtc/base/gunit.h" |
12 #include "webrtc/base/logging.h" | 14 #include "webrtc/base/logging.h" |
13 #include "webrtc/base/thread.h" | 15 #include "webrtc/base/thread.h" |
14 #include "webrtc/logging/rtc_event_log/rtc_event_log.h" | 16 #include "webrtc/logging/rtc_event_log/rtc_event_log.h" |
15 #include "webrtc/media/base/fakemediaengine.h" | 17 #include "webrtc/media/base/fakemediaengine.h" |
16 #include "webrtc/media/base/fakevideocapturer.h" | 18 #include "webrtc/media/base/fakevideocapturer.h" |
17 #include "webrtc/media/base/testutils.h" | 19 #include "webrtc/media/base/testutils.h" |
18 #include "webrtc/media/engine/fakewebrtccall.h" | 20 #include "webrtc/media/engine/fakewebrtccall.h" |
19 #include "webrtc/p2p/base/faketransportcontroller.h" | 21 #include "webrtc/p2p/base/faketransportcontroller.h" |
20 #include "webrtc/pc/channelmanager.h" | 22 #include "webrtc/pc/channelmanager.h" |
(...skipping 12 matching lines...) Expand all Loading... | |
33 | 35 |
34 static const VideoCodec kVideoCodecs[] = { | 36 static const VideoCodec kVideoCodecs[] = { |
35 VideoCodec(99, "H264"), VideoCodec(100, "VP8"), VideoCodec(96, "rtx"), | 37 VideoCodec(99, "H264"), VideoCodec(100, "VP8"), VideoCodec(96, "rtx"), |
36 }; | 38 }; |
37 | 39 |
38 class ChannelManagerTest : public testing::Test { | 40 class ChannelManagerTest : public testing::Test { |
39 protected: | 41 protected: |
40 ChannelManagerTest() | 42 ChannelManagerTest() |
41 : fme_(new cricket::FakeMediaEngine()), | 43 : fme_(new cricket::FakeMediaEngine()), |
42 fdme_(new cricket::FakeDataEngine()), | 44 fdme_(new cricket::FakeDataEngine()), |
43 cm_(new cricket::ChannelManager(fme_, fdme_, rtc::Thread::Current())), | 45 cm_(new cricket::ChannelManager( |
46 std::unique_ptr<MediaEngineInterface>(fme_), | |
the sun
2017/02/10 22:00:10
did git cl format do this to us? :/
Taylor Brandstetter
2017/02/11 01:50:08
Yeah, it's four spaces of indentation; just happen
| |
47 std::unique_ptr<DataEngineInterface>(fdme_), | |
48 rtc::Thread::Current())), | |
44 fake_call_(webrtc::Call::Config(&event_log_)), | 49 fake_call_(webrtc::Call::Config(&event_log_)), |
45 fake_mc_(cm_, &fake_call_), | 50 fake_mc_(cm_.get(), &fake_call_), |
46 transport_controller_( | 51 transport_controller_( |
47 new cricket::FakeTransportController(ICEROLE_CONTROLLING)) {} | 52 new cricket::FakeTransportController(ICEROLE_CONTROLLING)) { |
48 | |
49 virtual void SetUp() { | |
50 fme_->SetAudioCodecs(MAKE_VECTOR(kAudioCodecs)); | 53 fme_->SetAudioCodecs(MAKE_VECTOR(kAudioCodecs)); |
51 fme_->SetVideoCodecs(MAKE_VECTOR(kVideoCodecs)); | 54 fme_->SetVideoCodecs(MAKE_VECTOR(kVideoCodecs)); |
52 } | 55 } |
53 | 56 |
54 virtual void TearDown() { | |
55 delete transport_controller_; | |
56 delete cm_; | |
57 cm_ = NULL; | |
58 fdme_ = NULL; | |
59 fme_ = NULL; | |
60 } | |
61 | |
62 webrtc::RtcEventLogNullImpl event_log_; | 57 webrtc::RtcEventLogNullImpl event_log_; |
63 rtc::Thread network_; | 58 rtc::Thread network_; |
64 rtc::Thread worker_; | 59 rtc::Thread worker_; |
60 // |fme_| and |fdme_| are actually owned by |cm_|. | |
65 cricket::FakeMediaEngine* fme_; | 61 cricket::FakeMediaEngine* fme_; |
66 cricket::FakeDataEngine* fdme_; | 62 cricket::FakeDataEngine* fdme_; |
67 cricket::ChannelManager* cm_; | 63 std::unique_ptr<cricket::ChannelManager> cm_; |
68 cricket::FakeCall fake_call_; | 64 cricket::FakeCall fake_call_; |
69 cricket::FakeMediaController fake_mc_; | 65 cricket::FakeMediaController fake_mc_; |
70 cricket::FakeTransportController* transport_controller_; | 66 std::unique_ptr<cricket::FakeTransportController> transport_controller_; |
71 }; | 67 }; |
72 | 68 |
73 // Test that we startup/shutdown properly. | 69 // Test that we startup/shutdown properly. |
74 TEST_F(ChannelManagerTest, StartupShutdown) { | 70 TEST_F(ChannelManagerTest, StartupShutdown) { |
75 EXPECT_FALSE(cm_->initialized()); | 71 EXPECT_FALSE(cm_->initialized()); |
76 EXPECT_EQ(rtc::Thread::Current(), cm_->worker_thread()); | 72 EXPECT_EQ(rtc::Thread::Current(), cm_->worker_thread()); |
77 EXPECT_TRUE(cm_->Init()); | 73 EXPECT_TRUE(cm_->Init()); |
78 EXPECT_TRUE(cm_->initialized()); | 74 EXPECT_TRUE(cm_->initialized()); |
79 cm_->Terminate(); | 75 cm_->Terminate(); |
80 EXPECT_FALSE(cm_->initialized()); | 76 EXPECT_FALSE(cm_->initialized()); |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
126 cm_->Terminate(); | 122 cm_->Terminate(); |
127 } | 123 } |
128 | 124 |
129 // Test that we can create and destroy a voice and video channel with a worker. | 125 // Test that we can create and destroy a voice and video channel with a worker. |
130 TEST_F(ChannelManagerTest, CreateDestroyChannelsOnThread) { | 126 TEST_F(ChannelManagerTest, CreateDestroyChannelsOnThread) { |
131 network_.Start(); | 127 network_.Start(); |
132 worker_.Start(); | 128 worker_.Start(); |
133 EXPECT_TRUE(cm_->set_worker_thread(&worker_)); | 129 EXPECT_TRUE(cm_->set_worker_thread(&worker_)); |
134 EXPECT_TRUE(cm_->set_network_thread(&network_)); | 130 EXPECT_TRUE(cm_->set_network_thread(&network_)); |
135 EXPECT_TRUE(cm_->Init()); | 131 EXPECT_TRUE(cm_->Init()); |
136 delete transport_controller_; | 132 transport_controller_.reset( |
137 transport_controller_ = | 133 new cricket::FakeTransportController(&network_, ICEROLE_CONTROLLING)); |
138 new cricket::FakeTransportController(&network_, ICEROLE_CONTROLLING); | |
139 cricket::DtlsTransportInternal* rtp_transport = | 134 cricket::DtlsTransportInternal* rtp_transport = |
140 transport_controller_->CreateDtlsTransport( | 135 transport_controller_->CreateDtlsTransport( |
141 cricket::CN_AUDIO, cricket::ICE_CANDIDATE_COMPONENT_RTP); | 136 cricket::CN_AUDIO, cricket::ICE_CANDIDATE_COMPONENT_RTP); |
142 cricket::VoiceChannel* voice_channel = cm_->CreateVoiceChannel( | 137 cricket::VoiceChannel* voice_channel = cm_->CreateVoiceChannel( |
143 &fake_mc_, rtp_transport, nullptr /*rtcp_transport*/, | 138 &fake_mc_, rtp_transport, nullptr /*rtcp_transport*/, |
144 rtc::Thread::Current(), cricket::CN_AUDIO, nullptr, | 139 rtc::Thread::Current(), cricket::CN_AUDIO, nullptr, |
145 kDefaultRtcpMuxRequired, kDefaultSrtpRequired, AudioOptions()); | 140 kDefaultRtcpMuxRequired, kDefaultSrtpRequired, AudioOptions()); |
146 EXPECT_TRUE(voice_channel != nullptr); | 141 EXPECT_TRUE(voice_channel != nullptr); |
147 cricket::VideoChannel* video_channel = cm_->CreateVideoChannel( | 142 cricket::VideoChannel* video_channel = cm_->CreateVideoChannel( |
148 &fake_mc_, rtp_transport, nullptr /*rtcp_transport*/, | 143 &fake_mc_, rtp_transport, nullptr /*rtcp_transport*/, |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
184 EXPECT_FALSE(cm_->SetVideoRtxEnabled(false)); | 179 EXPECT_FALSE(cm_->SetVideoRtxEnabled(false)); |
185 | 180 |
186 // Can set again after terminate. | 181 // Can set again after terminate. |
187 cm_->Terminate(); | 182 cm_->Terminate(); |
188 EXPECT_TRUE(cm_->SetVideoRtxEnabled(true)); | 183 EXPECT_TRUE(cm_->SetVideoRtxEnabled(true)); |
189 cm_->GetSupportedVideoCodecs(&codecs); | 184 cm_->GetSupportedVideoCodecs(&codecs); |
190 EXPECT_TRUE(ContainsMatchingCodec(codecs, rtx_codec)); | 185 EXPECT_TRUE(ContainsMatchingCodec(codecs, rtx_codec)); |
191 } | 186 } |
192 | 187 |
193 } // namespace cricket | 188 } // namespace cricket |
OLD | NEW |