Chromium Code Reviews| 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 |