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

Side by Side Diff: content/browser/media/android/browser_media_session_manager_browsertest.cc

Issue 2300083002: Wrap MediaMetadata in base::Optional in content and chrome (Closed)
Patch Set: addressed Mounir's comments Created 4 years, 3 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "content/browser/media/android/browser_media_session_manager.h" 5 #include "content/browser/media/android/browser_media_session_manager.h"
6 6
7 #include <iostream> 7 #include <iostream>
8 #include <sstream> 8 #include <sstream>
9 #include <utility> 9 #include <utility>
10 10
(...skipping 12 matching lines...) Expand all
23 using ::testing::_; 23 using ::testing::_;
24 using ::testing::InSequence; 24 using ::testing::InSequence;
25 using ::testing::InvokeWithoutArgs; 25 using ::testing::InvokeWithoutArgs;
26 using ::testing::Ne; 26 using ::testing::Ne;
27 27
28 namespace content { 28 namespace content {
29 29
30 namespace { 30 namespace {
31 31
32 // Helper function for build test javascripts. 32 // Helper function for build test javascripts.
33 std::string BuildSetMetadataScript(const MediaMetadata& metadata) { 33 std::string BuildSetMetadataScript(
34 const base::Optional<MediaMetadata>& metadata) {
34 std::ostringstream generated_script; 35 std::ostringstream generated_script;
35 36
36 generated_script << "var audio = document.createElement(\'audio\');" 37 generated_script
37 << "audio.session = new MediaSession();" 38 << "var audio = document.createElement(\'audio\');"
38 << "audio.session.metadata = new MediaMetadata({" 39 << "audio.session = new MediaSession();";
39 << "title: \"" << metadata.title << "\", " 40
40 << "artist: \"" << metadata.artist << "\", " 41 if (!metadata.has_value()) {
41 << "album: \"" << metadata.album << "\", " 42 generated_script << "audio.session.metadata = null;";
42 << "artwork: ["; 43 return generated_script.str();
44 }
45
46 generated_script
47 << "audio.session.metadata = new MediaMetadata({"
48 << "title: \"" << metadata->title << "\", "
49 << "artist: \"" << metadata->artist << "\", "
50 << "album: \"" << metadata->album << "\", "
51 << "artwork: [";
43 52
44 std::string artwork_separator = ""; 53 std::string artwork_separator = "";
45 for (const auto& artwork : metadata.artwork) { 54 for (const auto& artwork : metadata->artwork) {
46 generated_script << artwork_separator << "{" 55 generated_script << artwork_separator << "{"
47 << "src: \"" << artwork.src.spec() << "\", " 56 << "src: \"" << artwork.src.spec() << "\", "
48 << "type: \"" << artwork.type.string() << "\", " 57 << "type: \"" << artwork.type.string() << "\", "
49 << "sizes: \""; 58 << "sizes: \"";
50 for (const auto& size : artwork.sizes) { 59 for (const auto& size : artwork.sizes) {
51 generated_script << size.width() << "x" << size.height() << " "; 60 generated_script << size.width() << "x" << size.height() << " ";
52 } 61 }
53 generated_script << "\"}"; 62 generated_script << "\"}";
54 artwork_separator = ", "; 63 artwork_separator = ", ";
55 } 64 }
56 generated_script << "]});"; 65 generated_script << "]});";
57 66
58 return generated_script.str(); 67 return generated_script.str();
59 } 68 }
60 69
61 } // anonymous namespace 70 } // anonymous namespace
62 71
63 // Helper function to be pretty-print error messages by GMock. 72 // Helper function to be pretty-print error messages by GMock.
64 void PrintTo(const MediaMetadata& metadata, std::ostream* os) { 73 void PrintTo(const base::Optional<MediaMetadata>& metadata, std::ostream* os) {
65 *os << "{ title=" << metadata.title << ", "; 74 if (!metadata.has_value()) {
66 *os << "artist=" << metadata.artist << ", "; 75 *os << "<null MediaMetadata>";
67 *os << "album=" << metadata.album << ", "; 76 return;
77 }
78
79 *os << "{ title=" << metadata->title << ", ";
80 *os << "artist=" << metadata->artist << ", ";
81 *os << "album=" << metadata->album << ", ";
68 *os << "artwork=["; 82 *os << "artwork=[";
69 for (const auto& artwork : metadata.artwork) { 83 for (const auto& artwork : metadata->artwork) {
70 *os << "{ src=" << artwork.src.spec() << ", "; 84 *os << "{ src=" << artwork.src.spec() << ", ";
71 *os << "type=" << artwork.type.string() << ", "; 85 *os << "type=" << artwork.type.string() << ", ";
72 *os << "sizes=["; 86 *os << "sizes=[";
73 for (const auto& size : artwork.sizes) { 87 for (const auto& size : artwork.sizes) {
74 *os << size.width() << "x" << size.height() << " "; 88 *os << size.width() << "x" << size.height() << " ";
75 } 89 }
76 *os << "]}"; 90 *os << "]}";
77 } 91 }
78 *os << "]}"; 92 *os << "]}";
79 } 93 }
80 94
81 class MockBrowserMediaSessionManager : public BrowserMediaSessionManager { 95 class MockBrowserMediaSessionManager : public BrowserMediaSessionManager {
82 public: 96 public:
83 explicit MockBrowserMediaSessionManager(RenderFrameHost* render_frame_host) 97 explicit MockBrowserMediaSessionManager(RenderFrameHost* render_frame_host)
84 : BrowserMediaSessionManager(render_frame_host) {} 98 : BrowserMediaSessionManager(render_frame_host) {}
85 99
86 MOCK_METHOD2(OnActiveate, void(int session_id, int request_id)); 100 MOCK_METHOD2(OnActiveate, void(int session_id, int request_id));
87 MOCK_METHOD2(OnDeactiveate, void(int session_id, int request_id)); 101 MOCK_METHOD2(OnDeactiveate, void(int session_id, int request_id));
88 MOCK_METHOD2(OnSetMetadata, void(int session_id, 102 MOCK_METHOD2(OnSetMetadata, void(
89 const MediaMetadata& metadata)); 103 int session_id, const base::Optional<MediaMetadata>& metadata));
90 104
91 private: 105 private:
92 DISALLOW_COPY_AND_ASSIGN(MockBrowserMediaSessionManager); 106 DISALLOW_COPY_AND_ASSIGN(MockBrowserMediaSessionManager);
93 }; 107 };
94 108
95 class BrowserMediaSessionManagerBrowserTest : public ContentBrowserTest { 109 class BrowserMediaSessionManagerBrowserTest : public ContentBrowserTest {
96 public: 110 public:
97 BrowserMediaSessionManagerBrowserTest() = default; 111 BrowserMediaSessionManagerBrowserTest() = default;
98 ~BrowserMediaSessionManagerBrowserTest() override = default; 112 ~BrowserMediaSessionManagerBrowserTest() override = default;
99 113
(...skipping 22 matching lines...) Expand all
122 switches::kEnableBlinkFeatures, "MediaSession"); 136 switches::kEnableBlinkFeatures, "MediaSession");
123 } 137 }
124 138
125 WebContents* web_contents_; 139 WebContents* web_contents_;
126 MockBrowserMediaSessionManager* browser_media_session_manager_; 140 MockBrowserMediaSessionManager* browser_media_session_manager_;
127 scoped_refptr<MessageLoopRunner> message_loop_runner_; 141 scoped_refptr<MessageLoopRunner> message_loop_runner_;
128 }; 142 };
129 143
130 IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest, 144 IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
131 TestMetadataPropagated) { 145 TestMetadataPropagated) {
132 MediaMetadata expected; 146 base::Optional<MediaMetadata> expected = MediaMetadata();
133 expected.title = base::ASCIIToUTF16("title1"); 147 expected->title = base::ASCIIToUTF16("title1");
134 expected.artist = base::ASCIIToUTF16("artist1"); 148 expected->artist = base::ASCIIToUTF16("artist1");
135 expected.album = base::ASCIIToUTF16("album1"); 149 expected->album = base::ASCIIToUTF16("album1");
136 MediaMetadata::Artwork artwork; 150 MediaMetadata::Artwork artwork;
137 artwork.src = GURL("http://foo.com/bar.png"); 151 artwork.src = GURL("http://foo.com/bar.png");
138 artwork.type = base::NullableString16(base::ASCIIToUTF16("image/png"), false); 152 artwork.type = base::NullableString16(base::ASCIIToUTF16("image/png"), false);
139 artwork.sizes.push_back(gfx::Size(128, 128)); 153 artwork.sizes.push_back(gfx::Size(128, 128));
140 expected.artwork.push_back(artwork); 154 expected->artwork.push_back(artwork);
141 155
142 message_loop_runner_ = new MessageLoopRunner(); 156 message_loop_runner_ = new MessageLoopRunner();
143 EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected)) 157 EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected))
144 .Times(1); 158 .Times(1);
145 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(), 159 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
146 BuildSetMetadataScript(expected))); 160 BuildSetMetadataScript(expected)));
147 message_loop_runner_->Run(); 161 message_loop_runner_->Run();
148 } 162 }
149 163
150 IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest, 164 IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
151 TestSetMetadataTwice) { 165 TestSetMetadataTwice) {
152 // Make expectations ordered. 166 // Make expectations ordered.
153 InSequence s; 167 InSequence s;
154 168
155 MediaMetadata dont_care_metadata; 169 base::Optional<MediaMetadata> dont_care_metadata = MediaMetadata();
156 170
157 MediaMetadata expected; 171 base::Optional<MediaMetadata> expected = MediaMetadata();
158 expected.title = base::ASCIIToUTF16("title2"); 172 expected->title = base::ASCIIToUTF16("title2");
159 expected.artist = base::ASCIIToUTF16("artist2"); 173 expected->artist = base::ASCIIToUTF16("artist2");
160 expected.album = base::ASCIIToUTF16("album2"); 174 expected->album = base::ASCIIToUTF16("album2");
161 MediaMetadata::Artwork artwork; 175 MediaMetadata::Artwork artwork;
162 artwork.src = GURL("http://foo.com/bar.jpg"); 176 artwork.src = GURL("http://foo.com/bar.jpg");
163 artwork.type = base::NullableString16( 177 artwork.type = base::NullableString16(
164 base::ASCIIToUTF16("image/jpeg"), false); 178 base::ASCIIToUTF16("image/jpeg"), false);
165 artwork.sizes.push_back(gfx::Size(256, 256)); 179 artwork.sizes.push_back(gfx::Size(256, 256));
166 expected.artwork.push_back(artwork); 180 expected->artwork.push_back(artwork);
167 181
168 // Set metadata for the first time. 182 // Set metadata for the first time.
169 message_loop_runner_ = new MessageLoopRunner(); 183 message_loop_runner_ = new MessageLoopRunner();
184 EXPECT_CALL(*browser_media_session_manager_,
185 OnSetMetadata(_, dont_care_metadata))
186 .Times(1);
187 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
188 BuildSetMetadataScript(dont_care_metadata)));
189 message_loop_runner_->Run();
190
191 // Set metadata for the second time.
192 message_loop_runner_ = new MessageLoopRunner();
193 EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected))
194 .Times(1);
195 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
196 BuildSetMetadataScript(expected)));
197 message_loop_runner_->Run();
198 }
199
200
201 IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
202 TestNullMetadata) {
203 // Make expectations ordered.
204 InSequence s;
205
206 base::Optional<MediaMetadata> dont_care_metadata = MediaMetadata();
207
208 base::Optional<MediaMetadata> expected;
209
210 // Set metadata for the first time.
211 message_loop_runner_ = new MessageLoopRunner();
170 EXPECT_CALL(*browser_media_session_manager_, 212 EXPECT_CALL(*browser_media_session_manager_,
171 OnSetMetadata(_, dont_care_metadata)) 213 OnSetMetadata(_, dont_care_metadata))
172 .Times(1); 214 .Times(1);
173 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(), 215 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
174 BuildSetMetadataScript(dont_care_metadata))); 216 BuildSetMetadataScript(dont_care_metadata)));
175 message_loop_runner_->Run(); 217 message_loop_runner_->Run();
176 218
177 // Set metadata for the second time. 219 // Set metadata for the second time.
178 message_loop_runner_ = new MessageLoopRunner(); 220 message_loop_runner_ = new MessageLoopRunner();
179 EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected)) 221 EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected))
180 .Times(1); 222 .Times(1);
181 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(), 223 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
182 BuildSetMetadataScript(expected))); 224 BuildSetMetadataScript(expected)));
183 message_loop_runner_->Run(); 225 message_loop_runner_->Run();
184 } 226 }
185 227
186 IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest, 228 IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
187 TestFileArtworkRemoved) { 229 TestFileArtworkRemoved) {
188 // Make expectations ordered. 230 // Make expectations ordered.
189 InSequence s; 231 InSequence s;
190 232
191 MediaMetadata dirty_metadata; 233 base::Optional<MediaMetadata> dirty_metadata = MediaMetadata();
192 MediaMetadata::Artwork file_artwork; 234 MediaMetadata::Artwork file_artwork;
193 file_artwork.src = GURL("file:///foo/bar.jpg"); 235 file_artwork.src = GURL("file:///foo/bar.jpg");
194 file_artwork.type = base::NullableString16( 236 file_artwork.type = base::NullableString16(
195 base::ASCIIToUTF16("image/jpeg"), false); 237 base::ASCIIToUTF16("image/jpeg"), false);
196 dirty_metadata.artwork.push_back(file_artwork); 238 dirty_metadata->artwork.push_back(file_artwork);
197 239
198 MediaMetadata expected; 240 base::Optional<MediaMetadata> expected = MediaMetadata();
199 241
200 // Set metadata for the first time. 242 // Set metadata for the first time.
201 message_loop_runner_ = new MessageLoopRunner(); 243 message_loop_runner_ = new MessageLoopRunner();
202 EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected)) 244 EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected))
203 .Times(1); 245 .Times(1);
204 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(), 246 ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
205 BuildSetMetadataScript(dirty_metadata))); 247 BuildSetMetadataScript(dirty_metadata)));
206 message_loop_runner_->Run(); 248 message_loop_runner_->Run();
207 } 249 }
208 250
209 } // namespace content 251 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698