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

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

Issue 2868263002: [Media Router] Add some SetForTest() functions to DialMediaSinkService and update unit tests (Closed)
Patch Set: resolve code review comments from Mark 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/test/mock_callback.h" 6 #include "base/test/mock_callback.h"
7 #include "base/timer/mock_timer.h"
7 #include "chrome/browser/media/router/discovery/dial/dial_device_data.h" 8 #include "chrome/browser/media/router/discovery/dial/dial_device_data.h"
8 #include "chrome/browser/media/router/discovery/dial/dial_registry.h" 9 #include "chrome/browser/media/router/discovery/dial/dial_registry.h"
9 #include "chrome/browser/media/router/test_helper.h" 10 #include "chrome/browser/media/router/test_helper.h"
10 #include "chrome/test/base/testing_profile.h" 11 #include "chrome/test/base/testing_profile.h"
11 #include "content/public/test/test_browser_thread_bundle.h" 12 #include "content/public/test/test_browser_thread_bundle.h"
12 #include "testing/gmock/include/gmock/gmock.h" 13 #include "testing/gmock/include/gmock/gmock.h"
13 #include "testing/gtest/include/gtest/gtest.h" 14 #include "testing/gtest/include/gtest/gtest.h"
14 15
15 using ::testing::_; 16 using ::testing::_;
16 using ::testing::Return; 17 using ::testing::Return;
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
49 50
50 namespace media_router { 51 namespace media_router {
51 52
52 class TestDialRegistry : public DialRegistry { 53 class TestDialRegistry : public DialRegistry {
53 public: 54 public:
54 TestDialRegistry() {} 55 TestDialRegistry() {}
55 ~TestDialRegistry() {} 56 ~TestDialRegistry() {}
56 57
57 MOCK_METHOD1(RegisterObserver, void(DialRegistry::Observer* observer)); 58 MOCK_METHOD1(RegisterObserver, void(DialRegistry::Observer* observer));
58 MOCK_METHOD1(UnregisterObserver, void(DialRegistry::Observer* observer)); 59 MOCK_METHOD1(UnregisterObserver, void(DialRegistry::Observer* observer));
60
61 MOCK_METHOD0(OnListenerAdded, void());
62 MOCK_METHOD0(OnListenerRemoved, void());
59 }; 63 };
60 64
61 class MockDeviceDescriptionService : public DeviceDescriptionService { 65 class MockDeviceDescriptionService : public DeviceDescriptionService {
62 public: 66 public:
63 MockDeviceDescriptionService(DeviceDescriptionParseSuccessCallback success_cb, 67 MockDeviceDescriptionService(DeviceDescriptionParseSuccessCallback success_cb,
64 DeviceDescriptionParseErrorCallback error_cb) 68 DeviceDescriptionParseErrorCallback error_cb)
65 : DeviceDescriptionService(success_cb, error_cb) {} 69 : DeviceDescriptionService(success_cb, error_cb) {}
66 ~MockDeviceDescriptionService() override {} 70 ~MockDeviceDescriptionService() override {}
67 71
68 MOCK_METHOD2(GetDeviceDescriptions, 72 MOCK_METHOD2(GetDeviceDescriptions,
69 void(const std::vector<DialDeviceData>& devices, 73 void(const std::vector<DialDeviceData>& devices,
70 net::URLRequestContextGetter* request_context)); 74 net::URLRequestContextGetter* request_context));
71 }; 75 };
72 76
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 { 77 class DialMediaSinkServiceTest : public ::testing::Test {
96 public: 78 public:
97 DialMediaSinkServiceTest() 79 DialMediaSinkServiceTest()
98 : thread_bundle_(content::TestBrowserThreadBundle::IO_MAINLOOP), 80 : thread_bundle_(content::TestBrowserThreadBundle::IO_MAINLOOP),
99 mock_description_service_(mock_success_cb_.Get(), mock_error_cb_.Get()), 81 media_sink_service_(
100 media_sink_service_(mock_sink_discovered_cb_.Get(), 82 new DialMediaSinkService(mock_sink_discovered_cb_.Get(),
101 profile_.GetRequestContext(), 83 profile_.GetRequestContext())) {}
102 &test_dial_registry_,
103 &mock_description_service_) {}
104 84
105 DialMediaSinkService* media_sink_service() { return &media_sink_service_; } 85 void SetUp() override {
86 EXPECT_CALL(test_dial_registry_,
87 RegisterObserver(media_sink_service_.get()));
88 EXPECT_CALL(test_dial_registry_, OnListenerAdded());
89
90 media_sink_service_->SetDialRegistryForTest(&test_dial_registry_);
91
92 auto mock_description_service =
93 base::MakeUnique<MockDeviceDescriptionService>(mock_success_cb_.Get(),
94 mock_error_cb_.Get());
95 mock_description_service_ = mock_description_service.get();
96 media_sink_service_->SetDescriptionServiceForTest(
97 std::move(mock_description_service));
98 mock_timer_ =
99 new base::MockTimer(true /*retain_user_task*/, false /*is_repeating*/);
100 media_sink_service_->SetTimerForTest(base::WrapUnique(mock_timer_));
101 }
102
103 void TearDown() override {
104 EXPECT_CALL(test_dial_registry_,
105 UnregisterObserver(media_sink_service_.get()));
106 EXPECT_CALL(test_dial_registry_, OnListenerRemoved());
107 }
106 108
107 void TestFetchCompleted(const std::vector<MediaSinkInternal>& old_sinks, 109 void TestFetchCompleted(const std::vector<MediaSinkInternal>& old_sinks,
108 const std::vector<MediaSinkInternal>& new_sinks) { 110 const std::vector<MediaSinkInternal>& new_sinks) {
109 media_sink_service()->mrp_sinks_ = 111 media_sink_service_->mrp_sinks_ =
110 std::set<MediaSinkInternal>(old_sinks.begin(), old_sinks.end()); 112 std::set<MediaSinkInternal>(old_sinks.begin(), old_sinks.end());
111 media_sink_service()->current_sinks_ = 113 media_sink_service_->current_sinks_ =
112 std::set<MediaSinkInternal>(new_sinks.begin(), new_sinks.end()); 114 std::set<MediaSinkInternal>(new_sinks.begin(), new_sinks.end());
113 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)); 115 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks));
114 media_sink_service()->OnFetchCompleted(); 116 media_sink_service_->OnFetchCompleted();
115 } 117 }
116 118
117 protected: 119 protected:
118 const content::TestBrowserThreadBundle thread_bundle_; 120 const content::TestBrowserThreadBundle thread_bundle_;
119 TestingProfile profile_; 121 TestingProfile profile_;
120 122
121 base::MockCallback<MediaSinkService::OnSinksDiscoveredCallback> 123 base::MockCallback<MediaSinkService::OnSinksDiscoveredCallback>
122 mock_sink_discovered_cb_; 124 mock_sink_discovered_cb_;
123 base::MockCallback< 125 base::MockCallback<
124 MockDeviceDescriptionService::DeviceDescriptionParseSuccessCallback> 126 MockDeviceDescriptionService::DeviceDescriptionParseSuccessCallback>
125 mock_success_cb_; 127 mock_success_cb_;
126 base::MockCallback< 128 base::MockCallback<
127 MockDeviceDescriptionService::DeviceDescriptionParseErrorCallback> 129 MockDeviceDescriptionService::DeviceDescriptionParseErrorCallback>
128 mock_error_cb_; 130 mock_error_cb_;
129 131
130 TestDialRegistry test_dial_registry_; 132 TestDialRegistry test_dial_registry_;
131 MockDeviceDescriptionService mock_description_service_; 133 MockDeviceDescriptionService* mock_description_service_;
134 base::MockTimer* mock_timer_;
132 135
133 TestDialMediaSinkService media_sink_service_; 136 std::unique_ptr<DialMediaSinkService> media_sink_service_;
137
138 DISALLOW_COPY_AND_ASSIGN(DialMediaSinkServiceTest);
134 }; 139 };
135 140
136 TEST_F(DialMediaSinkServiceTest, TestStart) { 141 TEST_F(DialMediaSinkServiceTest, TestStart) {
137 EXPECT_CALL(test_dial_registry_, RegisterObserver(&media_sink_service_)); 142 media_sink_service_->Start();
138 media_sink_service()->Start();
139 143
140 DialRegistry::DeviceList deviceList; 144 DialRegistry::DeviceList deviceList;
141 DialDeviceData first_device("first", GURL("http://127.0.0.1/dd.xml"), 145 DialDeviceData first_device("first", GURL("http://127.0.0.1/dd.xml"),
142 base::Time::Now()); 146 base::Time::Now());
143 DialDeviceData second_device("second", GURL("http://127.0.0.2/dd.xml"), 147 DialDeviceData second_device("second", GURL("http://127.0.0.2/dd.xml"),
144 base::Time::Now()); 148 base::Time::Now());
145 DialDeviceData third_device("third", GURL("http://127.0.0.3/dd.xml"), 149 DialDeviceData third_device("third", GURL("http://127.0.0.3/dd.xml"),
146 base::Time::Now()); 150 base::Time::Now());
147 deviceList.push_back(first_device); 151 deviceList.push_back(first_device);
148 deviceList.push_back(second_device); 152 deviceList.push_back(second_device);
149 deviceList.push_back(third_device); 153 deviceList.push_back(third_device);
150 154
151 EXPECT_CALL(mock_description_service_, GetDeviceDescriptions(deviceList, _)); 155 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _));
152 156
153 media_sink_service()->OnDialDeviceEvent(deviceList); 157 media_sink_service_->OnDialDeviceEvent(deviceList);
154 EXPECT_TRUE(media_sink_service_.finish_timer_->IsRunning()); 158 EXPECT_TRUE(media_sink_service_->finish_timer_->IsRunning());
155 } 159 }
156 160
157 TEST_F(DialMediaSinkServiceTest, TestOnDeviceDescriptionAvailable) { 161 TEST_F(DialMediaSinkServiceTest, TestOnDeviceDescriptionAvailable) {
158 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"), 162 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"),
159 base::Time::Now()); 163 base::Time::Now());
160 ParsedDialDeviceDescription device_description; 164 ParsedDialDeviceDescription device_description;
161 device_description.model_name = "model name"; 165 device_description.model_name = "model name";
162 device_description.friendly_name = "friendly name"; 166 device_description.friendly_name = "friendly name";
163 device_description.app_url = GURL("http://192.168.1.1/apps"); 167 device_description.app_url = GURL("http://192.168.1.1/apps");
164 device_description.unique_id = "unique id"; 168 device_description.unique_id = "unique id";
165 169
166 media_sink_service()->OnDeviceDescriptionAvailable(device_data, 170 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
167 device_description); 171 device_description);
168 EXPECT_TRUE(media_sink_service()->current_sinks_.empty()); 172 EXPECT_TRUE(media_sink_service_->current_sinks_.empty());
169 173
170 std::vector<DialDeviceData> deviceList{device_data}; 174 std::vector<DialDeviceData> deviceList{device_data};
171 EXPECT_CALL(mock_description_service_, GetDeviceDescriptions(deviceList, _)); 175 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _));
172 176
173 media_sink_service()->OnDialDeviceEvent(deviceList); 177 media_sink_service_->OnDialDeviceEvent(deviceList);
174 media_sink_service()->OnDeviceDescriptionAvailable(device_data, 178 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
175 device_description); 179 device_description);
176 180
177 EXPECT_EQ(size_t(1), media_sink_service()->current_sinks_.size()); 181 EXPECT_EQ(size_t(1), media_sink_service_->current_sinks_.size());
178 } 182 }
179 183
180 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted) { 184 TEST_F(DialMediaSinkServiceTest, TestTimer) {
185 DialDeviceData device_data("first", GURL("http://127.0.0.1/dd.xml"),
186 base::Time::Now());
187 ParsedDialDeviceDescription device_description;
188 device_description.model_name = "model name";
189 device_description.friendly_name = "friendly name";
190 device_description.app_url = GURL("http://192.168.1.1/apps");
191 device_description.unique_id = "unique id";
192
193 std::vector<DialDeviceData> deviceList{device_data};
194 EXPECT_CALL(*mock_description_service_, GetDeviceDescriptions(deviceList, _));
195
196 EXPECT_FALSE(mock_timer_->IsRunning());
197 media_sink_service_->OnDialDeviceEvent(deviceList);
198 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
199 device_description);
200 EXPECT_TRUE(mock_timer_->IsRunning());
201
202 EXPECT_CALL(mock_sink_discovered_cb_, Run(_));
203 mock_timer_->Fire();
204
205 EXPECT_FALSE(mock_timer_->IsRunning());
206 device_description.app_url = GURL("http://192.168.1.11/apps");
207 media_sink_service_->OnDeviceDescriptionAvailable(device_data,
208 device_description);
209 EXPECT_TRUE(mock_timer_->IsRunning());
210 }
211
212 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_SameSink) {
181 std::vector<MediaSinkInternal> old_sinks; 213 std::vector<MediaSinkInternal> old_sinks;
182 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); 214 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks();
183 TestFetchCompleted(old_sinks, new_sinks); 215 TestFetchCompleted(old_sinks, new_sinks);
184 216
185 // Same sink 217 // Same sink
186 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)).Times(0); 218 EXPECT_CALL(mock_sink_discovered_cb_, Run(new_sinks)).Times(0);
187 media_sink_service()->OnFetchCompleted(); 219 media_sink_service_->OnFetchCompleted();
188 } 220 }
189 221
190 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_OneNewSink) { 222 TEST_F(DialMediaSinkServiceTest, TestFetchCompleted_OneNewSink) {
191 std::vector<MediaSinkInternal> old_sinks = CreateDialMediaSinks(); 223 std::vector<MediaSinkInternal> old_sinks = CreateDialMediaSinks();
192 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks(); 224 std::vector<MediaSinkInternal> new_sinks = CreateDialMediaSinks();
193 MediaSink sink3("sink3", "sink_name_3", MediaSink::IconType::CAST); 225 MediaSink sink3("sink3", "sink_name_3", MediaSink::IconType::CAST);
194 DialSinkExtraData extra_data3 = CreateDialSinkExtraData( 226 DialSinkExtraData extra_data3 = CreateDialSinkExtraData(
195 "model_name3", "192.168.1.3", "https://example3.com"); 227 "model_name3", "192.168.1.3", "https://example3.com");
196 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); 228 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3));
197 TestFetchCompleted(old_sinks, new_sinks); 229 TestFetchCompleted(old_sinks, new_sinks);
(...skipping 25 matching lines...) Expand all
223 "model_name3", "192.168.1.3", "https://example3.com"); 255 "model_name3", "192.168.1.3", "https://example3.com");
224 256
225 std::vector<MediaSinkInternal> new_sinks; 257 std::vector<MediaSinkInternal> new_sinks;
226 new_sinks.push_back(MediaSinkInternal(sink1, extra_data2)); 258 new_sinks.push_back(MediaSinkInternal(sink1, extra_data2));
227 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3)); 259 new_sinks.push_back(MediaSinkInternal(sink3, extra_data3));
228 260
229 TestFetchCompleted(old_sinks, new_sinks); 261 TestFetchCompleted(old_sinks, new_sinks);
230 } 262 }
231 263
232 } // namespace media_router 264 } // namespace media_router
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698