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

Unified Diff: media/mojo/services/media_renderer_apptest.cc

Issue 709923003: Use ApplicationTestBase for MojoRendererTest. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix media.gyp Created 6 years, 1 month 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 | « media/mojo/services/BUILD.gn ('k') | media/mojo/services/renderer_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/mojo/services/media_renderer_apptest.cc
diff --git a/media/mojo/services/renderer_unittest.cc b/media/mojo/services/media_renderer_apptest.cc
similarity index 72%
rename from media/mojo/services/renderer_unittest.cc
rename to media/mojo/services/media_renderer_apptest.cc
index a191d726adf6791eaed5f811188d25cfd3133846..7c88ad87d5848cdf5f0f12205cc202c38b132881 100644
--- a/media/mojo/services/renderer_unittest.cc
+++ b/media/mojo/services/media_renderer_apptest.cc
@@ -2,9 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "base/at_exit.h"
#include "base/bind.h"
-#include "base/command_line.h"
#include "base/message_loop/message_loop.h"
#include "base/run_loop.h"
#include "media/base/audio_decoder_config.h"
@@ -13,10 +11,9 @@
#include "media/base/sample_format.h"
#include "media/base/video_decoder_config.h"
#include "media/mojo/services/mojo_renderer_impl.h"
-#include "mojo/public/c/system/main.h"
#include "mojo/public/cpp/application/application_delegate.h"
#include "mojo/public/cpp/application/application_impl.h"
-#include "testing/gtest/include/gtest/gtest.h"
+#include "mojo/public/cpp/application/application_test_base.h"
namespace {
@@ -40,9 +37,6 @@ class MojoRendererTestHelper : public mojo::ApplicationDelegate {
DISALLOW_COPY_AND_ASSIGN(MojoRendererTestHelper);
};
-// TODO(tim): Reconcile this with mojo apptest framework when ready.
-MojoRendererTestHelper* g_test_delegate = NULL;
-
// TODO(tim): Make media::FakeDemuxerStream support audio and use that for the
// DemuxerStream implementation instead.
class FakeDemuxerStream : public media::DemuxerStreamProvider,
@@ -53,8 +47,9 @@ class FakeDemuxerStream : public media::DemuxerStreamProvider,
// media::Demuxer implementation.
media::DemuxerStream* GetStream(media::DemuxerStream::Type type) override {
- DCHECK_EQ(media::DemuxerStream::AUDIO, type);
- return this;
+ if (type == media::DemuxerStream::AUDIO)
+ return this;
+ return nullptr;
}
media::DemuxerStreamProvider::Liveness GetLiveness() const override {
return media::DemuxerStreamProvider::LIVENESS_UNKNOWN;
@@ -104,15 +99,25 @@ class FakeDemuxerStream : public media::DemuxerStreamProvider,
namespace media {
-class MojoRendererTest : public testing::Test {
+class MojoRendererTest : public mojo::test::ApplicationTestBase {
public:
- MojoRendererTest() : service_provider_(NULL) {}
+ MojoRendererTest()
+ : ApplicationTestBase(mojo::Array<mojo::String>()),
+ service_provider_(NULL) {}
+ ~MojoRendererTest() override {}
+
+ protected:
+ // ApplicationTestBase implementation.
+ mojo::ApplicationDelegate* GetApplicationDelegate() override {
+ return &mojo_renderer_test_helper_;
+ }
void SetUp() override {
+ ApplicationTestBase::SetUp();
demuxer_stream_provider_.reset(new FakeDemuxerStream());
service_provider_ =
- g_test_delegate->application_impl()
- ->ConnectToApplication("mojo:media_mojo_renderer_app")
+ application_impl()
+ ->ConnectToApplication("mojo:mojo_media_renderer_app")
->GetServiceProvider();
}
@@ -125,6 +130,7 @@ class MojoRendererTest : public testing::Test {
}
private:
+ MojoRendererTestHelper mojo_renderer_test_helper_;
scoped_ptr<DemuxerStreamProvider> demuxer_stream_provider_;
mojo::ServiceProvider* service_provider_;
@@ -140,14 +146,12 @@ void ErrorCallback(PipelineStatus* output, PipelineStatus status) {
// connection. The test also initializes a media::AudioRendererImpl which
// will error-out expectedly due to lack of support for decoder selection.
TEST_F(MojoRendererTest, BasicInitialize) {
- MojoRendererImpl rimpl(task_runner(), service_provider());
+ MojoRendererImpl mojo_renderer_impl(task_runner(), service_provider());
PipelineStatus expected_error(PIPELINE_OK);
- rimpl.Initialize(stream_provider(),
- base::MessageLoop::current()->QuitClosure(),
- media::StatisticsCB(),
- base::Closure(),
- base::Bind(&ErrorCallback, &expected_error),
- media::BufferingStateCB());
+ mojo_renderer_impl.Initialize(
+ stream_provider(), base::MessageLoop::current()->QuitClosure(),
+ media::StatisticsCB(), base::Closure(),
+ base::Bind(&ErrorCallback, &expected_error), media::BufferingStateCB());
base::MessageLoop::current()->Run();
// We expect an error during initialization because MojoRendererService
@@ -156,29 +160,3 @@ TEST_F(MojoRendererTest, BasicInitialize) {
}
} // namespace media
-
-MojoResult MojoMain(MojoHandle shell_handle) {
- base::CommandLine::Init(0, NULL);
-#if !defined(COMPONENT_BUILD)
- base::AtExitManager at_exit;
-#endif
-
- // TODO(tim): Reconcile this with apptest framework when it is ready.
- scoped_ptr<mojo::ApplicationDelegate> delegate(new MojoRendererTestHelper());
- g_test_delegate = static_cast<MojoRendererTestHelper*>(delegate.get());
- {
- base::MessageLoop loop;
- mojo::ApplicationImpl impl(
- delegate.get(),
- mojo::MakeScopedHandle(mojo::MessagePipeHandle(shell_handle)));
-
- int argc = 0;
- char** argv = NULL;
- testing::InitGoogleTest(&argc, argv);
- mojo_ignore_result(RUN_ALL_TESTS());
- }
-
- g_test_delegate = NULL;
- delegate.reset();
- return MOJO_RESULT_OK;
-}
« no previous file with comments | « media/mojo/services/BUILD.gn ('k') | media/mojo/services/renderer_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698