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

Unified 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: fix Android build 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 side-by-side diff with in-line comments
Download patch
Index: content/browser/media/android/browser_media_session_manager_browsertest.cc
diff --git a/content/browser/media/android/browser_media_session_manager_browsertest.cc b/content/browser/media/android/browser_media_session_manager_browsertest.cc
index f98d73f7df0a334c91935ace43f88119ee87fd3e..ddd11e1a1602aac54ba781a025d91c8023443d8b 100644
--- a/content/browser/media/android/browser_media_session_manager_browsertest.cc
+++ b/content/browser/media/android/browser_media_session_manager_browsertest.cc
@@ -14,6 +14,7 @@
#include "content/browser/media/android/media_web_contents_observer_android.h"
#include "content/public/browser/web_contents.h"
#include "content/public/common/content_switches.h"
+#include "content/public/common/media_metadata.h"
#include "content/public/test/browser_test_utils.h"
#include "content/public/test/content_browser_test.h"
#include "content/public/test/test_utils.h"
@@ -30,19 +31,28 @@ namespace content {
namespace {
// Helper function for build test javascripts.
-std::string BuildSetMetadataScript(const MediaMetadata& metadata) {
+std::string BuildSetMetadataScript(
+ const base::Optional<MediaMetadata>& metadata) {
std::ostringstream generated_script;
- generated_script << "var audio = document.createElement(\'audio\');"
- << "audio.session = new MediaSession();"
- << "audio.session.metadata = new MediaMetadata({"
- << "title: \"" << metadata.title << "\", "
- << "artist: \"" << metadata.artist << "\", "
- << "album: \"" << metadata.album << "\", "
- << "artwork: [";
+ generated_script
+ << "var audio = document.createElement(\'audio\');"
+ << "audio.session = new MediaSession();";
+
+ if (!metadata.has_value()) {
+ generated_script << "audio.session.metadata = null;";
+ return generated_script.str();
+ }
+
+ generated_script
+ << "audio.session.metadata = new MediaMetadata({"
+ << "title: \"" << metadata->title << "\", "
+ << "artist: \"" << metadata->artist << "\", "
+ << "album: \"" << metadata->album << "\", "
+ << "artwork: [";
std::string artwork_separator = "";
- for (const auto& artwork : metadata.artwork) {
+ for (const auto& artwork : metadata->artwork) {
generated_script << artwork_separator << "{"
<< "src: \"" << artwork.src.spec() << "\", "
<< "type: \"" << artwork.type.string() << "\", "
@@ -61,12 +71,17 @@ std::string BuildSetMetadataScript(const MediaMetadata& metadata) {
} // anonymous namespace
// Helper function to be pretty-print error messages by GMock.
-void PrintTo(const MediaMetadata& metadata, std::ostream* os) {
- *os << "{ title=" << metadata.title << ", ";
- *os << "artist=" << metadata.artist << ", ";
- *os << "album=" << metadata.album << ", ";
+void PrintTo(const base::Optional<MediaMetadata>& metadata, std::ostream* os) {
+ if (!metadata.has_value()) {
+ *os << "<null MediaMetadata>";
+ return;
+ }
+
+ *os << "{ title=" << metadata->title << ", ";
+ *os << "artist=" << metadata->artist << ", ";
+ *os << "album=" << metadata->album << ", ";
*os << "artwork=[";
- for (const auto& artwork : metadata.artwork) {
+ for (const auto& artwork : metadata->artwork) {
*os << "{ src=" << artwork.src.spec() << ", ";
*os << "type=" << artwork.type.string() << ", ";
*os << "sizes=[";
@@ -85,8 +100,8 @@ class MockBrowserMediaSessionManager : public BrowserMediaSessionManager {
MOCK_METHOD2(OnActiveate, void(int session_id, int request_id));
MOCK_METHOD2(OnDeactiveate, void(int session_id, int request_id));
- MOCK_METHOD2(OnSetMetadata, void(int session_id,
- const MediaMetadata& metadata));
+ MOCK_METHOD2(OnSetMetadata, void(
+ int session_id, const base::Optional<MediaMetadata>& metadata));
private:
DISALLOW_COPY_AND_ASSIGN(MockBrowserMediaSessionManager);
@@ -129,15 +144,15 @@ class BrowserMediaSessionManagerBrowserTest : public ContentBrowserTest {
IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
TestMetadataPropagated) {
- MediaMetadata expected;
- expected.title = base::ASCIIToUTF16("title1");
- expected.artist = base::ASCIIToUTF16("artist1");
- expected.album = base::ASCIIToUTF16("album1");
+ base::Optional<MediaMetadata> expected = MediaMetadata();
+ expected->title = base::ASCIIToUTF16("title1");
+ expected->artist = base::ASCIIToUTF16("artist1");
+ expected->album = base::ASCIIToUTF16("album1");
MediaMetadata::Artwork artwork;
artwork.src = GURL("http://foo.com/bar.png");
artwork.type = base::NullableString16(base::ASCIIToUTF16("image/png"), false);
artwork.sizes.push_back(gfx::Size(128, 128));
- expected.artwork.push_back(artwork);
+ expected->artwork.push_back(artwork);
message_loop_runner_ = new MessageLoopRunner();
EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected))
@@ -152,18 +167,46 @@ IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
// Make expectations ordered.
InSequence s;
- MediaMetadata dont_care_metadata;
+ base::Optional<MediaMetadata> dont_care_metadata = MediaMetadata();
- MediaMetadata expected;
- expected.title = base::ASCIIToUTF16("title2");
- expected.artist = base::ASCIIToUTF16("artist2");
- expected.album = base::ASCIIToUTF16("album2");
+ base::Optional<MediaMetadata> expected = MediaMetadata();
+ expected->title = base::ASCIIToUTF16("title2");
+ expected->artist = base::ASCIIToUTF16("artist2");
+ expected->album = base::ASCIIToUTF16("album2");
MediaMetadata::Artwork artwork;
artwork.src = GURL("http://foo.com/bar.jpg");
artwork.type = base::NullableString16(
base::ASCIIToUTF16("image/jpeg"), false);
artwork.sizes.push_back(gfx::Size(256, 256));
- expected.artwork.push_back(artwork);
+ expected->artwork.push_back(artwork);
+
+ // Set metadata for the first time.
+ message_loop_runner_ = new MessageLoopRunner();
+ EXPECT_CALL(*browser_media_session_manager_,
+ OnSetMetadata(_, dont_care_metadata))
+ .Times(1);
+ ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
+ BuildSetMetadataScript(dont_care_metadata)));
+ message_loop_runner_->Run();
+
+ // Set metadata for the second time.
+ message_loop_runner_ = new MessageLoopRunner();
+ EXPECT_CALL(*browser_media_session_manager_, OnSetMetadata(_, expected))
+ .Times(1);
+ ASSERT_TRUE(ExecuteScript(web_contents_->GetMainFrame(),
+ BuildSetMetadataScript(expected)));
+ message_loop_runner_->Run();
+}
+
+
+IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
+ TestNullMetadata) {
+ // Make expectations ordered.
+ InSequence s;
+
+ base::Optional<MediaMetadata> dont_care_metadata = MediaMetadata();
+
+ base::Optional<MediaMetadata> expected;
// Set metadata for the first time.
message_loop_runner_ = new MessageLoopRunner();
@@ -188,14 +231,14 @@ IN_PROC_BROWSER_TEST_F(BrowserMediaSessionManagerBrowserTest,
// Make expectations ordered.
InSequence s;
- MediaMetadata dirty_metadata;
+ base::Optional<MediaMetadata> dirty_metadata = MediaMetadata();
MediaMetadata::Artwork file_artwork;
file_artwork.src = GURL("file:///foo/bar.jpg");
file_artwork.type = base::NullableString16(
base::ASCIIToUTF16("image/jpeg"), false);
- dirty_metadata.artwork.push_back(file_artwork);
+ dirty_metadata->artwork.push_back(file_artwork);
- MediaMetadata expected;
+ base::Optional<MediaMetadata> expected = MediaMetadata();
// Set metadata for the first time.
message_loop_runner_ = new MessageLoopRunner();
« no previous file with comments | « content/browser/media/android/browser_media_session_manager.cc ('k') | content/browser/media/session/media_session.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698