Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(156)

Side by Side Diff: chrome/browser/media/router/discovery/dial/dial_media_sink_service_unittest.cc

Issue 2837363002: [Media Router] Use DialMediaSinkService in MediaRouterMojoImpl (Closed)
Patch Set: resolve code review comments from Kevin Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698