diff options
author | Torne (Richard Coles) <torne@google.com> | 2014-02-21 12:16:55 +0000 |
---|---|---|
committer | Torne (Richard Coles) <torne@google.com> | 2014-02-21 12:16:55 +0000 |
commit | 5d1f7b1de12d16ceb2c938c56701a3e8bfa558f7 (patch) | |
tree | 5d4ae202b870bd86673f596f0d424bc4b3e55ebe /media/base/run_all_perftests.cc | |
parent | e862bac9c33104a29d98631d62668ae7b6676510 (diff) | |
download | chromium_org-5d1f7b1de12d16ceb2c938c56701a3e8bfa558f7.tar.gz |
Merge from Chromium at DEPS revision 251904
This commit was generated by merge_to_master.py.
Change-Id: I1f9543259d7d2a57d81aa41a1b84f85837439d21
Diffstat (limited to 'media/base/run_all_perftests.cc')
-rw-r--r-- | media/base/run_all_perftests.cc | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/media/base/run_all_perftests.cc b/media/base/run_all_perftests.cc new file mode 100644 index 0000000000..119bef3303 --- /dev/null +++ b/media/base/run_all_perftests.cc @@ -0,0 +1,55 @@ +// Copyright 2014 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "base/bind.h" +#include "base/command_line.h" +#include "base/test/launcher/unit_test_launcher.h" +#include "base/test/test_suite.h" +#include "build/build_config.h" +#include "media/base/media.h" +#include "media/base/media_switches.h" + +#if defined(OS_ANDROID) +#include "base/android/jni_android.h" +#include "media/base/android/media_jni_registrar.h" +#include "ui/gl/android/gl_jni_registrar.h" +#endif + +class TestSuiteNoAtExit : public base::TestSuite { + public: + TestSuiteNoAtExit(int argc, char** argv) : TestSuite(argc, argv) {} + virtual ~TestSuiteNoAtExit() {} + protected: + virtual void Initialize() OVERRIDE; +}; + +void TestSuiteNoAtExit::Initialize() { + // Run TestSuite::Initialize first so that logging is initialized. + base::TestSuite::Initialize(); + +#if defined(OS_ANDROID) + // Register JNI bindings for android. + JNIEnv* env = base::android::AttachCurrentThread(); + // Needed for surface texture support. + ui::gl::android::RegisterJni(env); + media::RegisterJni(env); +#endif + + // Run this here instead of main() to ensure an AtExitManager is already + // present. + media::InitializeMediaLibraryForTesting(); + CommandLine* cmd_line = CommandLine::ForCurrentProcess(); + cmd_line->AppendSwitch(switches::kEnableMP3StreamParser); +} + +int main(int argc, char** argv) { + TestSuiteNoAtExit test_suite(argc, argv); + + // Always run the perf tests serially, to avoid distorting + // perf measurements with randomness resulting from running + // in parallel. + return base::LaunchUnitTestsSerially( + argc, argv, base::Bind(&TestSuiteNoAtExit::Run, + base::Unretained(&test_suite))); +} |