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

Unified Diff: chromecast/browser/cast_media_blocker_unittest.cc

Issue 2623953002: [Chromecast] Fix media session blocking tests. (Closed)
Patch Set: [Chromecast] Fix media session blocking tests. Created 3 years, 11 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
« no previous file with comments | « no previous file | content/browser/media/session/media_session_impl.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chromecast/browser/cast_media_blocker_unittest.cc
diff --git a/chromecast/browser/cast_media_blocker_unittest.cc b/chromecast/browser/cast_media_blocker_unittest.cc
index dddb0082c90c5dfdcb58e5bde95266b71eb858e1..c0eb415c9d1b0ef104e4389db5fa3eb9df7f9d50 100644
--- a/chromecast/browser/cast_media_blocker_unittest.cc
+++ b/chromecast/browser/cast_media_blocker_unittest.cc
@@ -8,12 +8,11 @@
#include "base/memory/ptr_util.h"
#include "content/public/browser/media_session.h"
-#include "content/public/browser/web_contents.h"
#include "content/public/test/test_content_client_initializer.h"
#include "content/public/test/test_renderer_host.h"
-#include "content/public/test/web_contents_tester.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
+#include "ui/gl/test/gl_surface_test_support.h"
namespace chromecast {
namespace shell {
@@ -21,19 +20,12 @@ namespace shell {
using ::testing::_;
using ::testing::Invoke;
+namespace {
+
class MockMediaSession : public content::MediaSession {
public:
- explicit MockMediaSession(content::MediaSession* session) {
- // Delegate the calls to the real MediaSession.
- ON_CALL(*this, Resume(_))
- .WillByDefault(Invoke(session, &MediaSession::Resume));
- ON_CALL(*this, Suspend(_))
- .WillByDefault(Invoke(session, &MediaSession::Suspend));
- ON_CALL(*this, Stop(_)).WillByDefault(Invoke(session, &MediaSession::Stop));
- ON_CALL(*this, DidReceiveAction(_))
- .WillByDefault(Invoke(session, &MediaSession::DidReceiveAction));
- }
- ~MockMediaSession() {}
+ MockMediaSession() {}
+ ~MockMediaSession() override {}
MOCK_METHOD1(Resume, void(content::MediaSession::SuspendType));
MOCK_METHOD1(Suspend, void(content::MediaSession::SuspendType));
@@ -41,25 +33,26 @@ class MockMediaSession : public content::MediaSession {
MOCK_METHOD0(StartDucking, void());
MOCK_METHOD0(StopDucking, void());
MOCK_METHOD1(DidReceiveAction, void(blink::mojom::MediaSessionAction));
+ MOCK_METHOD1(AddObserver, void(content::MediaSessionObserver*));
+ MOCK_METHOD1(RemoveObserver, void(content::MediaSessionObserver*));
private:
DISALLOW_COPY_AND_ASSIGN(MockMediaSession);
};
+} // namespace
+
class CastMediaBlockerTest : public content::RenderViewHostTestHarness {
public:
CastMediaBlockerTest() {}
~CastMediaBlockerTest() override {}
void SetUp() override {
+ gl::GLSurfaceTestSupport::InitializeOneOff();
initializer_ = base::MakeUnique<content::TestContentClientInitializer>();
content::RenderViewHostTestHarness::SetUp();
- media_session_ = base::MakeUnique<MockMediaSession>(
- content::MediaSession::Get(web_contents()));
+ media_session_ = base::MakeUnique<MockMediaSession>();
media_blocker_ = base::MakeUnique<CastMediaBlocker>(media_session_.get());
-
- content::WebContentsTester::For(web_contents())
- ->NavigateAndCommit(GURL("https://www.youtube.com"));
}
void TearDown() override { content::RenderViewHostTestHarness::TearDown(); }
@@ -77,10 +70,8 @@ class CastMediaBlockerTest : public content::RenderViewHostTestHarness {
DISALLOW_COPY_AND_ASSIGN(CastMediaBlockerTest);
};
-// TODO(derekjchow): Make the tests pass on cast testbots.
-// crbug.com/665118
-TEST_F(CastMediaBlockerTest, DISABLED_Block_Unblock_Suspended) {
+TEST_F(CastMediaBlockerTest, Block_Unblock_Suspended) {
// Testing block/unblock operations do nothing if media never plays.
EXPECT_CALL(*media_session_, Suspend(_)).Times(0);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -96,7 +87,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Block_Unblock_Suspended) {
media_blocker_->BlockMediaLoading(false);
}
-TEST_F(CastMediaBlockerTest, DISABLED_No_Block) {
+TEST_F(CastMediaBlockerTest, No_Block) {
// Tests CastMediaBlocker does nothing if block/unblock is not called.
EXPECT_CALL(*media_session_, Suspend(_)).Times(0);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -121,7 +112,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_No_Block) {
MediaSessionChanged(true, true);
}
-TEST_F(CastMediaBlockerTest, DISABLED_Block_Before_Controllable) {
+TEST_F(CastMediaBlockerTest, Block_Before_Controllable) {
// Tests CastMediaBlocker only suspends when controllable.
EXPECT_CALL(*media_session_, Suspend(_)).Times(0);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -134,7 +125,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Block_Before_Controllable) {
MediaSessionChanged(true, false);
}
-TEST_F(CastMediaBlockerTest, DISABLED_Block_After_Controllable) {
+TEST_F(CastMediaBlockerTest, Block_After_Controllable) {
// Tests CastMediaBlocker suspends immediately on block if controllable.
EXPECT_CALL(*media_session_, Suspend(_)).Times(0);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -154,7 +145,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Block_After_Controllable) {
media_blocker_->BlockMediaLoading(false);
}
-TEST_F(CastMediaBlockerTest, DISABLED_Block_Multiple) {
+TEST_F(CastMediaBlockerTest, Block_Multiple) {
// Tests CastMediaBlocker repeatively suspends when blocked.
EXPECT_CALL(*media_session_, Suspend(_)).Times(0);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -182,7 +173,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Block_Multiple) {
testing::Mock::VerifyAndClearExpectations(media_session_.get());
}
-TEST_F(CastMediaBlockerTest, DISABLED_Block_Unblock_Uncontrollable) {
+TEST_F(CastMediaBlockerTest, Block_Unblock_Uncontrollable) {
// Tests CastMediaBlocker does not suspend or resume when uncontrollable.
EXPECT_CALL(*media_session_, Suspend(_)).Times(0);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -196,7 +187,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Block_Unblock_Uncontrollable) {
testing::Mock::VerifyAndClearExpectations(media_session_.get());
}
-TEST_F(CastMediaBlockerTest, DISABLED_Block_Unblock_Uncontrollable2) {
+TEST_F(CastMediaBlockerTest, Block_Unblock_Uncontrollable2) {
EXPECT_CALL(*media_session_, Suspend(_)).Times(1);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
MediaSessionChanged(true, true);
@@ -219,7 +210,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Block_Unblock_Uncontrollable2) {
media_blocker_->BlockMediaLoading(false);
}
-TEST_F(CastMediaBlockerTest, DISABLED_Resume_When_Controllable) {
+TEST_F(CastMediaBlockerTest, Resume_When_Controllable) {
// Tests CastMediaBlocker will only resume after unblock when controllable.
EXPECT_CALL(*media_session_, Suspend(_)).Times(1);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -235,7 +226,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Resume_When_Controllable) {
MediaSessionChanged(true, true);
}
-TEST_F(CastMediaBlockerTest, DISABLED_No_Resume) {
+TEST_F(CastMediaBlockerTest, No_Resume) {
// Tests CastMediaBlocker will not resume if media starts playing by itself
// after unblock.
EXPECT_CALL(*media_session_, Suspend(_)).Times(1);
@@ -252,7 +243,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_No_Resume) {
MediaSessionChanged(false, false);
}
-TEST_F(CastMediaBlockerTest, DISABLED_Block_Before_Resume) {
+TEST_F(CastMediaBlockerTest, Block_Before_Resume) {
// Tests CastMediaBlocker does not resume if blocked again after an unblock.
EXPECT_CALL(*media_session_, Suspend(_)).Times(1);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
@@ -269,7 +260,7 @@ TEST_F(CastMediaBlockerTest, DISABLED_Block_Before_Resume) {
MediaSessionChanged(true, true);
}
-TEST_F(CastMediaBlockerTest, DISABLED_Unblocked_Already_Playing) {
+TEST_F(CastMediaBlockerTest, Unblocked_Already_Playing) {
// Tests CastMediaBlocker does not resume if unblocked and media is playing.
EXPECT_CALL(*media_session_, Suspend(_)).Times(1);
EXPECT_CALL(*media_session_, Resume(_)).Times(0);
« no previous file with comments | « no previous file | content/browser/media/session/media_session_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698