Index: webrtc/api/test/androidtestinitializer.cc |
diff --git a/webrtc/modules/audio_device/android/ensure_initialized.cc b/webrtc/api/test/androidtestinitializer.cc |
similarity index 54% |
copy from webrtc/modules/audio_device/android/ensure_initialized.cc |
copy to webrtc/api/test/androidtestinitializer.cc |
index b63aec1f27d87a38607f6acc13412245b51d9300..4816702bdf9f0505556555c121c16f169d82c814 100644 |
--- a/webrtc/modules/audio_device/android/ensure_initialized.cc |
+++ b/webrtc/api/test/androidtestinitializer.cc |
@@ -1,5 +1,5 @@ |
/* |
- * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. |
+ * Copyright 2015 The WebRTC project authors. All Rights Reserved. |
* |
* Use of this source code is governed by a BSD-style license |
* that can be found in the LICENSE file in the root of the source |
@@ -8,24 +8,32 @@ |
* be found in the AUTHORS file in the root of the source tree. |
*/ |
-#include "webrtc/modules/audio_device/android/ensure_initialized.h" |
+#include "webrtc/api/test/androidtestinitializer.h" |
#include <pthread.h> |
// Note: this dependency is dangerous since it reaches into Chromium's base. |
// There's a risk of e.g. macro clashes. This file may only be used in tests. |
+// Since we use Chromes build system for creating the gtest binary, this should |
+// be fine. |
#include "base/android/context_utils.h" |
#include "base/android/jni_android.h" |
+ |
+#include "webrtc/api/java/jni/classreferenceholder.h" |
+#include "webrtc/api/java/jni/jni_helpers.h" |
#include "webrtc/base/checks.h" |
-#include "webrtc/modules/audio_device/android/audio_record_jni.h" |
-#include "webrtc/modules/audio_device/android/audio_track_jni.h" |
-#include "webrtc/modules/utility/include/jvm_android.h" |
+#include "webrtc/base/ssladapter.h" |
+#include "webrtc/voice_engine/include/voe_base.h" |
namespace webrtc { |
-namespace audiodevicemodule { |
+ |
+namespace { |
static pthread_once_t g_initialize_once = PTHREAD_ONCE_INIT; |
+// There can only be one JNI_OnLoad in each binary. So since this is a GTEST |
+// C++ runner binary, we want to initialize the same global objects we normally |
+// do if this had been a Java binary. |
void EnsureInitializedOnce() { |
RTC_CHECK(::base::android::IsVMInitialized()); |
JNIEnv* jni = ::base::android::AttachCurrentThread(); |
@@ -33,13 +41,17 @@ void EnsureInitializedOnce() { |
RTC_CHECK_EQ(0, jni->GetJavaVM(&jvm)); |
jobject context = ::base::android::GetApplicationContext(); |
- // Initialize the Java environment (currently only used by the audio manager). |
- webrtc::JVM::Initialize(jvm, context); |
+ RTC_CHECK_GE(webrtc_jni::InitGlobalJniVariables(jvm), 0); |
+ RTC_CHECK(rtc::InitializeSSL()) << "Failed to InitializeSSL()"; |
+ webrtc_jni::LoadGlobalClassReferenceHolder(); |
+ |
+ webrtc::VoiceEngine::SetAndroidObjects(jvm, context); |
} |
-void EnsureInitialized() { |
+} // anonymous namespace |
+ |
+void InitializeAndroidObjects() { |
RTC_CHECK_EQ(0, pthread_once(&g_initialize_once, &EnsureInitializedOnce)); |
} |
-} // namespace audiodevicemodule |
} // namespace webrtc |