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

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: fix windows unit tests failures 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_,
103 &mock_description_service_) {}
104 85
105 DialMediaSinkService* media_sink_service() { return &media_sink_service_; } 86 auto mock_description_service =
87 base::MakeUnique<MockDeviceDescriptionService>(mock_success_cb_.Get(),
88 mock_error_cb_.Get());
89 mock_description_service_ = mock_description_service.get();
90 media_sink_service_->SetDescriptionServiceForTest(
91 std::move(mock_description_service));
92 mock_timer_ =
93 new base::MockTimer(true /*retain_user_task*/, false /*is_repeating*/);
94 media_sink_service_->SetTimerForTest(base::WrapUnique(mock_timer_));
95 }
106 96
107 void TestFetchCompleted(const std::vector<MediaSinkInternal>& old_sinks, 97 void TestFetchCompleted(const std::vector<MediaSinkInternal>& old_sinks,
108 const std::vector<MediaSinkInternal>& new_sinks) { 98 const std::vector<MediaSinkInternal>& new_sinks) {
109 media_sink_service()->mrp_sinks_ = 99 media_sink_service_->mrp_sinks_ =
110 std::set<MediaSinkInternal>(old_sinks.begin(), old_sinks.end()); 100 std::set<MediaSinkInternal>(old_sinks.begin(), old_sinks.end());
111 media_sink_service()->current_sinks_ = 101 media_sink_service_->current_sinks_ =
112 std::set<MediaSinkInternal>(new_sinks.begin(), new_sinks.end()); 102 std::set<MediaSinkInternal>(new_sinks.begin(), new_sinks.end());
113 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)); 103 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks));
114 media_sink_service()->OnFetchCompleted(); 104 media_sink_service_->OnFetchCompleted();
105
106 base::RunLoop().RunUntilIdle();
115 } 107 }
116 108
117 protected: 109 protected:
118 const content::TestBrowserThreadBundle thread_bundle_; 110 const content::TestBrowserThreadBundle thread_bundle_;
119 TestingProfile profile_; 111 TestingProfile profile_;
120 112
121 base::MockCallback<MediaSinkService::OnSinksDiscoveredCallback> 113 base::MockCallback<MediaSinkService::OnSinksDiscoveredCallback>
122 mock_sink_discovered_cb_; 114 mock_sink_discovered_cb_;
123 base::MockCallback< 115 base::MockCallback<
124 MockDeviceDescriptionService::DeviceDescriptionParseSuccessCallback> 116 MockDeviceDescriptionService::DeviceDescriptionParseSuccessCallback>
125 mock_success_cb_; 117 mock_success_cb_;
126 base::MockCallback< 118 base::MockCallback<
127 MockDeviceDescriptionService::DeviceDescriptionParseErrorCallback> 119 MockDeviceDescriptionService::DeviceDescriptionParseErrorCallback>
128 mock_error_cb_; 120 mock_error_cb_;
129 121
130 TestDialRegistry test_dial_registry_; 122 TestDialRegistry test_dial_registry_;
131 MockDeviceDescriptionService mock_description_service_; 123 MockDeviceDescriptionService* mock_description_service_;
124 base::MockTimer* mock_timer_;
132 125
133 TestDialMediaSinkService media_sink_service_; 126 scoped_refptr<DialMediaSinkService> media_sink_service_;
127
128 DISALLOW_COPY_AND_ASSIGN(DialMediaSinkServiceTest);
134 }; 129 };
135 130
136 TEST_F(DialMediaSinkServiceTest, TestStart) { 131 TEST_F(DialMediaSinkServiceTest, TestStart) {
137 EXPECT_CALL(test_dial_registry_, RegisterObserver(&media_sink_service_)); 132 EXPECT_CALL(test_dial_registry_, RegisterObserver(media_sink_service_.get()));
138 media_sink_service()->Start(); 133 EXPECT_CALL(test_dial_registry_, StartPeriodicDiscovery());
134 media_sink_service_->Start();
139 135
140 DialRegistry::DeviceList deviceList; 136 DialRegistry::DeviceList deviceList;
141 DialDeviceData first_device("first", GURL("http://127.0.0.1/dd.xml"), 137 DialDeviceData first_device("first", GURL("http://127.0.0.1/dd.xml"),
142 base::Time::Now()); 138 base::Time::Now());
143 DialDeviceData second_device("second", GURL("http://127.0.0.2/dd.xml"), 139 DialDeviceData second_device("second", GURL("http://127.0.0.2/dd.xml"),
144 base::Time::Now()); 140 base::Time::Now());
145 DialDeviceData third_device("third", GURL("http://127.0.0.3/dd.xml"), 141 DialDeviceData third_device("third", GURL("http://127.0.0.3/dd.xml"),
146 base::Time::Now()); 142 base::Time::Now());
147 deviceList.push_back(first_device); 143 deviceList.push_back(first_device);
148 deviceList.push_back(second_device); 144 deviceList.push_back(second_device);
149 deviceList.push_back(third_device); 145 deviceList.push_back(third_device);
150 146
151 EXPECT_CALL(mock_description_service_, GetDeviceDescriptions(deviceList, _)); 147 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _));
152 148
153 media_sink_service()->OnDialDeviceEvent(deviceList); 149 media_sink_service_->OnDialDeviceEvent(deviceList);
154 EXPECT_TRUE(media_sink_service_.finish_timer_->IsRunning()); 150 EXPECT_TRUE(media_sink_service_->finish_timer_->IsRunning());
151
152 base::RunLoop().RunUntilIdle();
155 } 153 }
156 154
157 TEST_F(DialMediaSinkServiceTest, TestOnDeviceDescriptionAvailable) { 155 TEST_F(DialMediaSinkServiceTest, TestOnDeviceDescriptionAvailable) {
158 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"), 156 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"),
159 base::Time::Now()); 157 base::Time::Now());
160 ParsedDialDeviceDescription device_description; 158 ParsedDialDeviceDescription device_description;
161 device_description.model_name = "model name"; 159 device_description.model_name = "model name";
162 device_description.friendly_name = "friendly name"; 160 device_description.friendly_name = "friendly name";
163 device_description.app_url = GURL("http://192.168.1.1/apps"); 161 device_description.app_url = GURL("http://192.168.1.1/apps");
164 device_description.unique_id = "unique id"; 162 device_description.unique_id = "unique id";
165 163
166 media_sink_service()->OnDeviceDescriptionAvailable(device_data, 164 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
167 device_description); 165 device_description);
168 EXPECT_TRUE(media_sink_service()->current_sinks_.empty()); 166 EXPECT_TRUE(media_sink_service_->current_sinks_.empty());
169 167
170 std::vector<DialDeviceData> deviceList{device_data}; 168 std::vector<DialDeviceData> deviceList{device_data};
171 EXPECT_CALL(mock_description_service_, GetDeviceDescriptions(deviceList, _)); 169 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _));
172 170
173 media_sink_service()->OnDialDeviceEvent(deviceList); 171 media_sink_service_->OnDialDeviceEvent(deviceList);
174 media_sink_service()->OnDeviceDescriptionAvailable(device_data, 172 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
175 device_description); 173 device_description);
176 174
177 EXPECT_EQ(size_t(1), media_sink_service()->current_sinks_.size()); 175 EXPECT_EQ(size_t(1), media_sink_service_->current_sinks_.size());
178 } 176 }
179 177
180 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted) { 178 TEST_F(DialMediaSinkServiceTest, TestTimer) {
179 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"),
180 base::Time::Now());
181 ParsedDialDeviceDescription device_description;
182 device_description.model_name = "model name";
183 device_description.friendly_name = "friendly name";
184 device_description.app_url = GURL("http://192.168.1.1/apps");
185 device_description.unique_id = "unique id";
186
187 std::vector<DialDeviceData> deviceList{device_data};
188 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _));
189
190 EXPECT_FALSE(mock_timer_->IsRunning());
191 media_sink_service_->OnDialDeviceEvent(deviceList);
192 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
193 device_description);
194 EXPECT_TRUE(mock_timer_->IsRunning());
195
196 EXPECT_CALL(mock_sink_discovered_cb_, Run(_));
197 mock_timer_->Fire();
198
199 EXPECT_FALSE(mock_timer_->IsRunning());
200 device_description.app_url = GURL("http://192.168.1.11/apps");
201 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
202 device_description);
203 EXPECT_TRUE(mock_timer_->IsRunning());
204
205 base::RunLoop().RunUntilIdle();
206 }
207
208 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_SameSink) {
181 std::vector<MediaSinkInternal> old_sinks; 209 std::vector<MediaSinkInternal> old_sinks;
182 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); 210 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks();
183 TestFetchCompleted(old_sinks, new_sinks); 211 TestFetchCompleted(old_sinks, new_sinks);
184 212
185 // Same sink 213 // Same sink
186 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)).Times(0); 214 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)).Times(0);
187 media_sink_service()->OnFetchCompleted(); 215 media_sink_service_->OnFetchCompleted();
216
217 base::RunLoop().RunUntilIdle();
188 } 218 }
189 219
190 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_OneNewSink) { 220 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_OneNewSink) {
191 std::vector<MediaSinkInternal> old_sinks = CreateDialMediaSinks(); 221 std::vector<MediaSinkInternal> old_sinks = CreateDialMediaSinks();
192 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); 222 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks();
193 MediaSink sink3("sink3", "sink_name_3", MediaSink::IconType::CAST); 223 MediaSink sink3("sink3", "sink_name_3", MediaSink::IconType::CAST);
194 DialSinkExtraData extra_data3 = CreateDialSinkExtraData( 224 DialSinkExtraData extra_data3 = CreateDialSinkExtraData(
195 "model_name3", "192.168.1.3", "https://example3.com"); 225 "model_name3", "192.168.1.3", "https://example3.com");
196 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); 226 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3));
197 TestFetchCompleted(old_sinks, new_sinks); 227 TestFetchCompleted(old_sinks, new_sinks);
(...skipping 25 matching lines...) Expand all
223 "model_name3", "192.168.1.3", "https://example3.com"); 253 "model_name3", "192.168.1.3", "https://example3.com");
224 254
225 std::vector<MediaSinkInternal> new_sinks; 255 std::vector<MediaSinkInternal> new_sinks;
226 new_sinks.push_back(MediaSinkInternal(sink1, extra_data2)); 256 new_sinks.push_back(MediaSinkInternal(sink1, extra_data2));
227 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); 257 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3));
228 258
229 TestFetchCompleted(old_sinks, new_sinks); 259 TestFetchCompleted(old_sinks, new_sinks);
230 } 260 }
231 261
232 } // namespace media_router 262 } // namespace media_router
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698