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

Side by Side Diff: content/shell/android/browsertests_apk/content_browser_tests_android.cc

Issue 864563002: Separate JNI registration with initialization (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address comments and sync Created 5 years, 10 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // This class sets up the environment for running the content browser tests 5 // This class sets up the environment for running the content browser tests
6 // inside an android application. 6 // inside an android application.
7 7
8 #include <android/log.h> 8 #include <android/log.h>
9 #include <unistd.h> 9 #include <unistd.h>
10 10
11 #include "base/android/base_jni_registrar.h" 11 #include "base/android/base_jni_registrar.h"
12 #include "base/android/fifo_utils.h" 12 #include "base/android/fifo_utils.h"
13 #include "base/android/jni_android.h" 13 #include "base/android/jni_android.h"
14 #include "base/android/jni_string.h" 14 #include "base/android/jni_string.h"
15 #include "base/android/library_loader/library_loader_hooks.h" 15 #include "base/android/library_loader/library_loader_hooks.h"
16 #include "base/android/scoped_java_ref.h" 16 #include "base/android/scoped_java_ref.h"
17 #include "base/base_switches.h" 17 #include "base/base_switches.h"
18 #include "base/command_line.h" 18 #include "base/command_line.h"
19 #include "base/files/file_path.h" 19 #include "base/files/file_path.h"
20 #include "base/logging.h" 20 #include "base/logging.h"
21 #include "base/strings/string_tokenizer.h" 21 #include "base/strings/string_tokenizer.h"
22 #include "base/strings/string_util.h" 22 #include "base/strings/string_util.h"
23 #include "base/strings/stringprintf.h" 23 #include "base/strings/stringprintf.h"
24 #include "content/public/app/android_library_loader_hooks.h"
25 #include "content/public/app/content_main.h"
26 #include "content/public/common/content_switches.h" 24 #include "content/public/common/content_switches.h"
27 #include "content/public/test/nested_message_pump_android.h"
28 #include "content/public/test/test_launcher.h" 25 #include "content/public/test/test_launcher.h"
29 #include "content/shell/android/shell_jni_registrar.h" 26 #include "content/shell/android/shell_jni_registrar.h"
30 #include "content/shell/app/shell_main_delegate.h" 27 #include "content/shell/app/shell_main_delegate.h"
31 #include "jni/ContentBrowserTestsActivity_jni.h" 28 #include "jni/ContentBrowserTestsActivity_jni.h"
32 #include "media/base/media_switches.h" 29 #include "media/base/media_switches.h"
33 #include "testing/android/native_test_util.h" 30 #include "testing/android/native_test_util.h"
34 31
35 using testing::native_test_util::ArgsToArgv; 32 using testing::native_test_util::ArgsToArgv;
36 using testing::native_test_util::ParseArgsFromCommandLineFile; 33 using testing::native_test_util::ParseArgsFromCommandLineFile;
37 using testing::native_test_util::ScopedMainEntryLogger; 34 using testing::native_test_util::ScopedMainEntryLogger;
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 base::FilePath files_dir( 86 base::FilePath files_dir(
90 base::android::ConvertJavaStringToUTF8(env, jfiles_dir)); 87 base::android::ConvertJavaStringToUTF8(env, jfiles_dir));
91 base::FilePath fifo_path(files_dir.Append(base::FilePath("test.fifo"))); 88 base::FilePath fifo_path(files_dir.Append(base::FilePath("test.fifo")));
92 base::android::CreateFIFO(fifo_path, 0666); 89 base::android::CreateFIFO(fifo_path, 0666);
93 base::android::RedirectStream(stdout, fifo_path, "w"); 90 base::android::RedirectStream(stdout, fifo_path, "w");
94 dup2(STDOUT_FILENO, STDERR_FILENO); 91 dup2(STDOUT_FILENO, STDERR_FILENO);
95 92
96 ScopedMainEntryLogger scoped_main_entry_logger; 93 ScopedMainEntryLogger scoped_main_entry_logger;
97 main(argc, &argv[0]); 94 main(argc, &argv[0]);
98 } 95 }
96
97 bool RegisterContentBrowserTestsAndroid(JNIEnv* env) {
98 return RegisterNativesImpl(env);
99 }
100
99 } // namespace content 101 } // namespace content
100
101 // This is called by the VM when the shared library is first loaded.
102 JNI_EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) {
103
104 base::android::SetLibraryLoadedHook(&content::LibraryLoaded);
105
106 base::android::InitVM(vm);
107 JNIEnv* env = base::android::AttachCurrentThread();
108
109 if (!base::android::RegisterLibraryLoaderEntryHook(env))
110 return -1;
111
112 if (!content::android::RegisterShellJni(env))
113 return -1;
114
115 if (!content::NestedMessagePumpAndroid::RegisterJni(env))
116 return -1;
117
118 if (!content::RegisterNativesImpl(env))
119 return -1;
120
121 content::SetContentMainDelegate(new content::ShellMainDelegate());
122 return JNI_VERSION_1_4;
123 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698