OLD | NEW |
---|---|
1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "chrome/browser/media/router/discovery/dial/dial_media_sink_service.h" | 5 #include "chrome/browser/media/router/discovery/dial/dial_media_sink_service.h" |
6 #include "base/run_loop.h" | |
6 #include "base/test/mock_callback.h" | 7 #include "base/test/mock_callback.h" |
8 #include "base/timer/mock_timer.h" | |
7 #include "chrome/browser/media/router/discovery/dial/dial_device_data.h" | 9 #include "chrome/browser/media/router/discovery/dial/dial_device_data.h" |
8 #include "chrome/browser/media/router/discovery/dial/dial_registry.h" | 10 #include "chrome/browser/media/router/discovery/dial/dial_registry.h" |
9 #include "chrome/browser/media/router/test_helper.h" | 11 #include "chrome/browser/media/router/test_helper.h" |
10 #include "chrome/test/base/testing_profile.h" | 12 #include "chrome/test/base/testing_profile.h" |
11 #include "content/public/test/test_browser_thread_bundle.h" | 13 #include "content/public/test/test_browser_thread_bundle.h" |
12 #include "testing/gmock/include/gmock/gmock.h" | 14 #include "testing/gmock/include/gmock/gmock.h" |
13 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
14 | 16 |
15 using ::testing::_; | 17 using ::testing::_; |
16 using ::testing::Return; | 18 using ::testing::Return; |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
49 | 51 |
50 namespace media_router { | 52 namespace media_router { |
51 | 53 |
52 class TestDialRegistry : public DialRegistry { | 54 class TestDialRegistry : public DialRegistry { |
53 public: | 55 public: |
54 TestDialRegistry() {} | 56 TestDialRegistry() {} |
55 ~TestDialRegistry() {} | 57 ~TestDialRegistry() {} |
56 | 58 |
57 MOCK_METHOD1(RegisterObserver, void(DialRegistry::Observer* observer)); | 59 MOCK_METHOD1(RegisterObserver, void(DialRegistry::Observer* observer)); |
58 MOCK_METHOD1(UnregisterObserver, void(DialRegistry::Observer* observer)); | 60 MOCK_METHOD1(UnregisterObserver, void(DialRegistry::Observer* observer)); |
61 | |
62 MOCK_METHOD0(StartPeriodicDiscovery, void()); | |
63 MOCK_METHOD0(StopPeriodicDiscovery, void()); | |
59 }; | 64 }; |
60 | 65 |
61 class MockDeviceDescriptionService : public DeviceDescriptionService { | 66 class MockDeviceDescriptionService : public DeviceDescriptionService { |
62 public: | 67 public: |
63 MockDeviceDescriptionService(DeviceDescriptionParseSuccessCallback success_cb, | 68 MockDeviceDescriptionService(DeviceDescriptionParseSuccessCallback success_cb, |
64 DeviceDescriptionParseErrorCallback error_cb) | 69 DeviceDescriptionParseErrorCallback error_cb) |
65 : DeviceDescriptionService(success_cb, error_cb) {} | 70 : DeviceDescriptionService(success_cb, error_cb) {} |
66 ~MockDeviceDescriptionService() override {} | 71 ~MockDeviceDescriptionService() override {} |
67 | 72 |
68 MOCK_METHOD2(GetDeviceDescriptions, | 73 MOCK_METHOD2(GetDeviceDescriptions, |
69 void(const std::vector<DialDeviceData>& devices, | 74 void(const std::vector<DialDeviceData>& devices, |
70 net::URLRequestContextGetter* request_context)); | 75 net::URLRequestContextGetter* request_context)); |
71 }; | 76 }; |
72 | 77 |
73 class TestDialMediaSinkService : public DialMediaSinkService { | |
74 public: | |
75 TestDialMediaSinkService( | |
76 const MediaSinkService::OnSinksDiscoveredCallback& callback, | |
77 net::URLRequestContextGetter* request_context, | |
78 TestDialRegistry* test_dial_registry, | |
79 MockDeviceDescriptionService* mock_description_service) | |
80 : DialMediaSinkService(callback, request_context), | |
81 test_dial_registry_(test_dial_registry), | |
82 mock_description_service_(mock_description_service) {} | |
83 | |
84 DialRegistry* dial_registry() override { return test_dial_registry_; } | |
85 | |
86 DeviceDescriptionService* GetDescriptionService() override { | |
87 return mock_description_service_; | |
88 } | |
89 | |
90 private: | |
91 TestDialRegistry* test_dial_registry_; | |
92 MockDeviceDescriptionService* mock_description_service_; | |
93 }; | |
94 | |
95 class DialMediaSinkServiceTest : public ::testing::Test { | 78 class DialMediaSinkServiceTest : public ::testing::Test { |
96 public: | 79 public: |
97 DialMediaSinkServiceTest() | 80 DialMediaSinkServiceTest() |
98 : thread_bundle_(content::TestBrowserThreadBundle::IO_MAINLOOP), | 81 : media_sink_service_( |
99 mock_description_service_(mock_success_cb_.Get(), mock_error_cb_.Get()), | 82 new DialMediaSinkService(mock_sink_discovered_cb_.Get(), |
100 media_sink_service_(mock_sink_discovered_cb_.Get(), | 83 profile_.GetRequestContext())) { |
101 profile_.GetRequestContext(), | 84 media_sink_service_->SetDialRegistryForTest(&test_dial_registry_); |
102 &test_dial_registry_, | 85 mock_description_service_ = new MockDeviceDescriptionService( |
Kevin M
2017/05/08 18:22:19
Best practice point: try to bind pointers to uniqu
zhaobin
2017/05/08 20:13:47
Done.
| |
103 &mock_description_service_) {} | 86 mock_success_cb_.Get(), mock_error_cb_.Get()); |
104 | 87 media_sink_service_->SetDescriptionServiceForTest( |
105 DialMediaSinkService* media_sink_service() { return &media_sink_service_; } | 88 base::WrapUnique(mock_description_service_)); |
89 mock_timer_ = | |
90 new base::MockTimer(true /*retain_user_task*/, false /*is_repeating*/); | |
Kevin M
2017/05/08 18:22:19
Suggestion: remove inline comments. A 2-bool funct
mark a. foltz
2017/05/08 18:29:02
Please keep them. Unlike a simple setter, MockTim
zhaobin
2017/05/08 20:13:48
Acknowledged.
| |
91 media_sink_service_->SetTimerForTest(base::WrapUnique(mock_timer_)); | |
92 } | |
106 | 93 |
107 void TestFetchCompleted(const std::vector<MediaSinkInternal>& old_sinks, | 94 void TestFetchCompleted(const std::vector<MediaSinkInternal>& old_sinks, |
108 const std::vector<MediaSinkInternal>& new_sinks) { | 95 const std::vector<MediaSinkInternal>& new_sinks) { |
109 media_sink_service()->mrp_sinks_ = | 96 media_sink_service_->mrp_sinks_ = |
110 std::set<MediaSinkInternal>(old_sinks.begin(), old_sinks.end()); | 97 std::set<MediaSinkInternal>(old_sinks.begin(), old_sinks.end()); |
111 media_sink_service()->current_sinks_ = | 98 media_sink_service_->current_sinks_ = |
112 std::set<MediaSinkInternal>(new_sinks.begin(), new_sinks.end()); | 99 std::set<MediaSinkInternal>(new_sinks.begin(), new_sinks.end()); |
113 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)); | 100 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)); |
114 media_sink_service()->OnFetchCompleted(); | 101 media_sink_service_->OnFetchCompleted(); |
102 | |
103 base::RunLoop().RunUntilIdle(); | |
115 } | 104 } |
116 | 105 |
117 protected: | 106 protected: |
118 const content::TestBrowserThreadBundle thread_bundle_; | 107 const content::TestBrowserThreadBundle thread_bundle_; |
119 TestingProfile profile_; | 108 TestingProfile profile_; |
120 | 109 |
121 base::MockCallback<MediaSinkService::OnSinksDiscoveredCallback> | 110 base::MockCallback<MediaSinkService::OnSinksDiscoveredCallback> |
122 mock_sink_discovered_cb_; | 111 mock_sink_discovered_cb_; |
123 base::MockCallback< | 112 base::MockCallback< |
124 MockDeviceDescriptionService::DeviceDescriptionParseSuccessCallback> | 113 MockDeviceDescriptionService::DeviceDescriptionParseSuccessCallback> |
125 mock_success_cb_; | 114 mock_success_cb_; |
126 base::MockCallback< | 115 base::MockCallback< |
127 MockDeviceDescriptionService::DeviceDescriptionParseErrorCallback> | 116 MockDeviceDescriptionService::DeviceDescriptionParseErrorCallback> |
128 mock_error_cb_; | 117 mock_error_cb_; |
129 | 118 |
130 TestDialRegistry test_dial_registry_; | 119 TestDialRegistry test_dial_registry_; |
131 MockDeviceDescriptionService mock_description_service_; | 120 MockDeviceDescriptionService* mock_description_service_; |
121 base::MockTimer* mock_timer_; | |
132 | 122 |
133 TestDialMediaSinkService media_sink_service_; | 123 scoped_refptr<DialMediaSinkService> media_sink_service_; |
124 | |
125 DISALLOW_COPY_AND_ASSIGN(DialMediaSinkServiceTest); | |
134 }; | 126 }; |
135 | 127 |
136 TEST_F(DialMediaSinkServiceTest, TestStart) { | 128 TEST_F(DialMediaSinkServiceTest, TestStart) { |
137 EXPECT_CALL(test_dial_registry_, RegisterObserver(&media_sink_service_)); | 129 EXPECT_CALL(test_dial_registry_, RegisterObserver(media_sink_service_.get())); |
138 media_sink_service()->Start(); | 130 EXPECT_CALL(test_dial_registry_, StartPeriodicDiscovery()); |
131 media_sink_service_->Start(); | |
139 | 132 |
140 DialRegistry::DeviceList deviceList; | 133 DialRegistry::DeviceList deviceList; |
141 DialDeviceData first_device("first", GURL("http://127.0.0.1/dd.xml"), | 134 DialDeviceData first_device("first", GURL("http://127.0.0.1/dd.xml"), |
142 base::Time::Now()); | 135 base::Time::Now()); |
143 DialDeviceData second_device("second", GURL("http://127.0.0.2/dd.xml"), | 136 DialDeviceData second_device("second", GURL("http://127.0.0.2/dd.xml"), |
144 base::Time::Now()); | 137 base::Time::Now()); |
145 DialDeviceData third_device("third", GURL("http://127.0.0.3/dd.xml"), | 138 DialDeviceData third_device("third", GURL("http://127.0.0.3/dd.xml"), |
146 base::Time::Now()); | 139 base::Time::Now()); |
147 deviceList.push_back(first_device); | 140 deviceList.push_back(first_device); |
148 deviceList.push_back(second_device); | 141 deviceList.push_back(second_device); |
149 deviceList.push_back(third_device); | 142 deviceList.push_back(third_device); |
150 | 143 |
151 EXPECT_CALL(mock_description_service_, GetDeviceDescriptions(deviceList, _)); | 144 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _)); |
152 | 145 |
153 media_sink_service()->OnDialDeviceEvent(deviceList); | 146 media_sink_service_->OnDialDeviceEvent(deviceList); |
154 EXPECT_TRUE(media_sink_service_.finish_timer_->IsRunning()); | 147 EXPECT_TRUE(media_sink_service_->finish_timer_->IsRunning()); |
148 | |
149 base::RunLoop().RunUntilIdle(); | |
155 } | 150 } |
156 | 151 |
157 TEST_F(DialMediaSinkServiceTest, TestOnDeviceDescriptionAvailable) { | 152 TEST_F(DialMediaSinkServiceTest, TestOnDeviceDescriptionAvailable) { |
158 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"), | 153 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"), |
159 base::Time::Now()); | 154 base::Time::Now()); |
160 ParsedDialDeviceDescription device_description; | 155 ParsedDialDeviceDescription device_description; |
161 device_description.model_name = "model name"; | 156 device_description.model_name = "model name"; |
162 device_description.friendly_name = "friendly name"; | 157 device_description.friendly_name = "friendly name"; |
163 device_description.app_url = GURL("http://192.168.1.1/apps"); | 158 device_description.app_url = GURL("http://192.168.1.1/apps"); |
164 device_description.unique_id = "unique id"; | 159 device_description.unique_id = "unique id"; |
165 | 160 |
166 media_sink_service()->OnDeviceDescriptionAvailable(device_data, | 161 media_sink_service_->OnDeviceDescriptionAvailable(device_data, |
167 device_description); | 162 device_description); |
168 EXPECT_TRUE(media_sink_service()->current_sinks_.empty()); | 163 EXPECT_TRUE(media_sink_service_->current_sinks_.empty()); |
169 | 164 |
170 std::vector<DialDeviceData> deviceList{device_data}; | 165 std::vector<DialDeviceData> deviceList{device_data}; |
171 EXPECT_CALL(mock_description_service_, GetDeviceDescriptions(deviceList, _)); | 166 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _)); |
172 | 167 |
173 media_sink_service()->OnDialDeviceEvent(deviceList); | 168 media_sink_service_->OnDialDeviceEvent(deviceList); |
174 media_sink_service()->OnDeviceDescriptionAvailable(device_data, | 169 media_sink_service_->OnDeviceDescriptionAvailable(device_data, |
175 device_description); | 170 device_description); |
176 | 171 |
177 EXPECT_EQ(size_t(1), media_sink_service()->current_sinks_.size()); | 172 EXPECT_EQ(size_t(1), media_sink_service_->current_sinks_.size()); |
178 } | 173 } |
179 | 174 |
180 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted) { | 175 TEST_F(DialMediaSinkServiceTest, TestTimer) { |
176 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"), | |
177 base::Time::Now()); | |
178 ParsedDialDeviceDescription device_description; | |
179 device_description.model_name = "model name"; | |
180 device_description.friendly_name = "friendly name"; | |
181 device_description.app_url = GURL("http://192.168.1.1/apps"); | |
182 device_description.unique_id = "unique id"; | |
183 | |
184 std::vector<DialDeviceData> deviceList{device_data}; | |
185 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _)); | |
186 | |
187 EXPECT_FALSE(mock_timer_->IsRunning()); | |
188 media_sink_service_->OnDialDeviceEvent(deviceList); | |
189 media_sink_service_->OnDeviceDescriptionAvailable(device_data, | |
190 device_description); | |
191 EXPECT_TRUE(mock_timer_->IsRunning()); | |
192 | |
193 EXPECT_CALL(mock_sink_discovered_cb_, Run(_)); | |
194 mock_timer_->Fire(); | |
195 | |
196 EXPECT_FALSE(mock_timer_->IsRunning()); | |
197 device_description.app_url = GURL("http://192.168.1.11/apps"); | |
198 media_sink_service_->OnDeviceDescriptionAvailable(device_data, | |
199 device_description); | |
200 EXPECT_TRUE(mock_timer_->IsRunning()); | |
201 | |
202 base::RunLoop().RunUntilIdle(); | |
203 } | |
204 | |
205 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_SameSink) { | |
181 std::vector<MediaSinkInternal> old_sinks; | 206 std::vector<MediaSinkInternal> old_sinks; |
182 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); | 207 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); |
183 TestFetchCompleted(old_sinks, new_sinks); | 208 TestFetchCompleted(old_sinks, new_sinks); |
184 | 209 |
185 // Same sink | 210 // Same sink |
186 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)).Times(0); | 211 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)).Times(0); |
187 media_sink_service()->OnFetchCompleted(); | 212 media_sink_service_->OnFetchCompleted(); |
213 | |
214 base::RunLoop().RunUntilIdle(); | |
188 } | 215 } |
189 | 216 |
190 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_OneNewSink) { | 217 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_OneNewSink) { |
191 std::vector<MediaSinkInternal> old_sinks = CreateDialMediaSinks(); | 218 std::vector<MediaSinkInternal> old_sinks = CreateDialMediaSinks(); |
192 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); | 219 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); |
193 MediaSink sink3("sink3", "sink_name_3", MediaSink::IconType::CAST); | 220 MediaSink sink3("sink3", "sink_name_3", MediaSink::IconType::CAST); |
194 DialSinkExtraData extra_data3 = CreateDialSinkExtraData( | 221 DialSinkExtraData extra_data3 = CreateDialSinkExtraData( |
195 "model_name3", "192.168.1.3", "https://example3.com"); | 222 "model_name3", "192.168.1.3", "https://example3.com"); |
196 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); | 223 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); |
197 TestFetchCompleted(old_sinks, new_sinks); | 224 TestFetchCompleted(old_sinks, new_sinks); |
(...skipping 25 matching lines...) Expand all Loading... | |
223 "model_name3", "192.168.1.3", "https://example3.com"); | 250 "model_name3", "192.168.1.3", "https://example3.com"); |
224 | 251 |
225 std::vector<MediaSinkInternal> new_sinks; | 252 std::vector<MediaSinkInternal> new_sinks; |
226 new_sinks.push_back(MediaSinkInternal(sink1, extra_data2)); | 253 new_sinks.push_back(MediaSinkInternal(sink1, extra_data2)); |
227 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); | 254 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); |
228 | 255 |
229 TestFetchCompleted(old_sinks, new_sinks); | 256 TestFetchCompleted(old_sinks, new_sinks); |
230 } | 257 } |
231 | 258 |
232 } // namespace media_router | 259 } // namespace media_router |
OLD | NEW |