phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 1 | /* |
kjellander | b24317b | 2016-02-10 07:54:43 -0800 | [diff] [blame] | 2 | * Copyright 2015 The WebRTC project authors. All Rights Reserved. |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 3 | * |
kjellander | b24317b | 2016-02-10 07:54:43 -0800 | [diff] [blame] | 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 9 | */ |
| 10 | |
Henrik Kjellander | 15583c1 | 2016-02-10 10:53:12 +0100 | [diff] [blame] | 11 | #include "webrtc/api/test/androidtestinitializer.h" |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 12 | |
| 13 | #include <pthread.h> |
| 14 | |
kwiberg | 77eab70 | 2016-09-28 17:42:01 -0700 | [diff] [blame] | 15 | #include "webrtc/base/ignore_wundef.h" |
| 16 | |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 17 | // Note: this dependency is dangerous since it reaches into Chromium's base. |
| 18 | // There's a risk of e.g. macro clashes. This file may only be used in tests. |
| 19 | // Since we use Chromes build system for creating the gtest binary, this should |
| 20 | // be fine. |
kwiberg | 77eab70 | 2016-09-28 17:42:01 -0700 | [diff] [blame] | 21 | RTC_PUSH_IGNORING_WUNDEF() |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 22 | #include "base/android/context_utils.h" |
| 23 | #include "base/android/jni_android.h" |
kwiberg | 77eab70 | 2016-09-28 17:42:01 -0700 | [diff] [blame] | 24 | RTC_POP_IGNORING_WUNDEF() |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 25 | |
sakal | d34a711 | 2016-07-01 05:10:51 -0700 | [diff] [blame] | 26 | #include "webrtc/api/android/jni/classreferenceholder.h" |
| 27 | #include "webrtc/api/android/jni/jni_helpers.h" |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 28 | #include "webrtc/base/checks.h" |
| 29 | #include "webrtc/base/ssladapter.h" |
| 30 | #include "webrtc/voice_engine/include/voe_base.h" |
| 31 | |
| 32 | namespace webrtc { |
| 33 | |
| 34 | namespace { |
| 35 | |
| 36 | static pthread_once_t g_initialize_once = PTHREAD_ONCE_INIT; |
| 37 | |
| 38 | // There can only be one JNI_OnLoad in each binary. So since this is a GTEST |
| 39 | // C++ runner binary, we want to initialize the same global objects we normally |
| 40 | // do if this had been a Java binary. |
| 41 | void EnsureInitializedOnce() { |
| 42 | RTC_CHECK(::base::android::IsVMInitialized()); |
| 43 | JNIEnv* jni = ::base::android::AttachCurrentThread(); |
| 44 | JavaVM* jvm = NULL; |
| 45 | RTC_CHECK_EQ(0, jni->GetJavaVM(&jvm)); |
magjed | 235020d | 2016-08-18 01:45:45 -0700 | [diff] [blame] | 46 | jobject context = ::base::android::GetApplicationContext().obj(); |
phoglund | 37ebcf0 | 2016-01-08 05:04:57 -0800 | [diff] [blame] | 47 | |
| 48 | RTC_CHECK_GE(webrtc_jni::InitGlobalJniVariables(jvm), 0); |
| 49 | RTC_CHECK(rtc::InitializeSSL()) << "Failed to InitializeSSL()"; |
| 50 | webrtc_jni::LoadGlobalClassReferenceHolder(); |
| 51 | |
| 52 | webrtc::VoiceEngine::SetAndroidObjects(jvm, context); |
| 53 | } |
| 54 | |
| 55 | } // anonymous namespace |
| 56 | |
| 57 | void InitializeAndroidObjects() { |
| 58 | RTC_CHECK_EQ(0, pthread_once(&g_initialize_once, &EnsureInitializedOnce)); |
| 59 | } |
| 60 | |
| 61 | } // namespace webrtc |