blob: 1dc46871ac995740489cdff17e08a9fe12f9d146 [file] [log] [blame]
Elliott Hughes2faa5f12012-01-30 14:42:07 -08001/*
2 * Copyright (C) 2011 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Elliott Hughes11e45072011-08-16 17:40:46 -070016
Brian Carlstroma1ce1fe2014-02-24 23:23:58 -080017#include "utils.h"
18
Andreas Gampe3f093892017-09-14 15:11:01 -070019#include <libgen.h>
David Sehrd106d9f2016-08-16 19:22:57 -070020#include <stdlib.h>
21
Andreas Gampe542451c2016-07-26 09:02:02 -070022#include "base/enums.h"
David Sehr891a50e2017-10-27 17:01:07 -070023#include "base/file_utils.h"
Andreas Gampe3f093892017-09-14 15:11:01 -070024#include "base/stl_util.h"
Vladimir Marko3481ba22015-04-13 12:22:36 +010025#include "class_linker-inl.h"
Brian Carlstroma1ce1fe2014-02-24 23:23:58 -080026#include "common_runtime_test.h"
David Sehr97c381e2017-02-01 15:09:58 -080027#include "exec_utils.h"
Andreas Gampe8cf9cb32017-07-19 09:28:38 -070028#include "handle_scope-inl.h"
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080029#include "mirror/array-inl.h"
Andreas Gampe8cf9cb32017-07-19 09:28:38 -070030#include "mirror/array.h"
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080031#include "mirror/object-inl.h"
32#include "mirror/object_array-inl.h"
33#include "mirror/string.h"
Mathieu Chartier0795f232016-09-27 18:43:30 -070034#include "scoped_thread_state_change-inl.h"
Elliott Hughes11e45072011-08-16 17:40:46 -070035
Evgenii Stepanov1e133742015-05-20 12:30:59 -070036#include "base/memory_tool.h"
Mathieu Chartier661974a2014-01-09 11:23:53 -080037
Elliott Hughes11e45072011-08-16 17:40:46 -070038namespace art {
39
Elliott Hughes9058f2b2012-03-22 18:06:48 -070040std::string PrettyArguments(const char* signature);
41std::string PrettyReturnType(const char* signature);
42
Brian Carlstroma1ce1fe2014-02-24 23:23:58 -080043class UtilsTest : public CommonRuntimeTest {};
Elliott Hughes11e45072011-08-16 17:40:46 -070044
Elliott Hughes5174fe62011-08-23 15:12:35 -070045TEST_F(UtilsTest, PrettyDescriptor_ArrayReferences) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070046 EXPECT_EQ("java.lang.Class[]", PrettyDescriptor("[Ljava/lang/Class;"));
47 EXPECT_EQ("java.lang.Class[][]", PrettyDescriptor("[[Ljava/lang/Class;"));
Elliott Hughes11e45072011-08-16 17:40:46 -070048}
49
Elliott Hughes5174fe62011-08-23 15:12:35 -070050TEST_F(UtilsTest, PrettyDescriptor_ScalarReferences) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070051 EXPECT_EQ("java.lang.String", PrettyDescriptor("Ljava.lang.String;"));
52 EXPECT_EQ("java.lang.String", PrettyDescriptor("Ljava/lang/String;"));
Elliott Hughes11e45072011-08-16 17:40:46 -070053}
54
Mathieu Chartier76433272014-09-26 14:32:37 -070055TEST_F(UtilsTest, PrettyDescriptor_Primitive) {
56 EXPECT_EQ("boolean", PrettyDescriptor(Primitive::kPrimBoolean));
57 EXPECT_EQ("byte", PrettyDescriptor(Primitive::kPrimByte));
58 EXPECT_EQ("char", PrettyDescriptor(Primitive::kPrimChar));
59 EXPECT_EQ("short", PrettyDescriptor(Primitive::kPrimShort));
60 EXPECT_EQ("int", PrettyDescriptor(Primitive::kPrimInt));
61 EXPECT_EQ("float", PrettyDescriptor(Primitive::kPrimFloat));
62 EXPECT_EQ("long", PrettyDescriptor(Primitive::kPrimLong));
63 EXPECT_EQ("double", PrettyDescriptor(Primitive::kPrimDouble));
64 EXPECT_EQ("void", PrettyDescriptor(Primitive::kPrimVoid));
65}
66
Elliott Hughes5174fe62011-08-23 15:12:35 -070067TEST_F(UtilsTest, PrettyDescriptor_PrimitiveArrays) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070068 EXPECT_EQ("boolean[]", PrettyDescriptor("[Z"));
69 EXPECT_EQ("boolean[][]", PrettyDescriptor("[[Z"));
70 EXPECT_EQ("byte[]", PrettyDescriptor("[B"));
71 EXPECT_EQ("byte[][]", PrettyDescriptor("[[B"));
72 EXPECT_EQ("char[]", PrettyDescriptor("[C"));
73 EXPECT_EQ("char[][]", PrettyDescriptor("[[C"));
74 EXPECT_EQ("double[]", PrettyDescriptor("[D"));
75 EXPECT_EQ("double[][]", PrettyDescriptor("[[D"));
76 EXPECT_EQ("float[]", PrettyDescriptor("[F"));
77 EXPECT_EQ("float[][]", PrettyDescriptor("[[F"));
78 EXPECT_EQ("int[]", PrettyDescriptor("[I"));
79 EXPECT_EQ("int[][]", PrettyDescriptor("[[I"));
80 EXPECT_EQ("long[]", PrettyDescriptor("[J"));
81 EXPECT_EQ("long[][]", PrettyDescriptor("[[J"));
82 EXPECT_EQ("short[]", PrettyDescriptor("[S"));
83 EXPECT_EQ("short[][]", PrettyDescriptor("[[S"));
Elliott Hughes11e45072011-08-16 17:40:46 -070084}
85
Elliott Hughes5174fe62011-08-23 15:12:35 -070086TEST_F(UtilsTest, PrettyDescriptor_PrimitiveScalars) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070087 EXPECT_EQ("boolean", PrettyDescriptor("Z"));
88 EXPECT_EQ("byte", PrettyDescriptor("B"));
89 EXPECT_EQ("char", PrettyDescriptor("C"));
90 EXPECT_EQ("double", PrettyDescriptor("D"));
91 EXPECT_EQ("float", PrettyDescriptor("F"));
92 EXPECT_EQ("int", PrettyDescriptor("I"));
93 EXPECT_EQ("long", PrettyDescriptor("J"));
94 EXPECT_EQ("short", PrettyDescriptor("S"));
95}
96
Elliott Hughes54e7df12011-09-16 11:47:04 -070097TEST_F(UtilsTest, PrettyTypeOf) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -070098 ScopedObjectAccess soa(Thread::Current());
David Sehr709b0702016-10-13 09:12:37 -070099 EXPECT_EQ("null", mirror::Object::PrettyTypeOf(nullptr));
Elliott Hughes11e45072011-08-16 17:40:46 -0700100
Mathieu Chartiereb8167a2014-05-07 15:43:14 -0700101 StackHandleScope<2> hs(soa.Self());
102 Handle<mirror::String> s(hs.NewHandle(mirror::String::AllocFromModifiedUtf8(soa.Self(), "")));
David Sehr709b0702016-10-13 09:12:37 -0700103 EXPECT_EQ("java.lang.String", mirror::Object::PrettyTypeOf(s.Get()));
Elliott Hughes11e45072011-08-16 17:40:46 -0700104
Mathieu Chartiereb8167a2014-05-07 15:43:14 -0700105 Handle<mirror::ShortArray> a(hs.NewHandle(mirror::ShortArray::Alloc(soa.Self(), 2)));
David Sehr709b0702016-10-13 09:12:37 -0700106 EXPECT_EQ("short[]", mirror::Object::PrettyTypeOf(a.Get()));
Elliott Hughes11e45072011-08-16 17:40:46 -0700107
Ian Rogers98379392014-02-24 16:53:16 -0800108 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "[Ljava/lang/String;");
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700109 ASSERT_TRUE(c != nullptr);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800110 mirror::Object* o = mirror::ObjectArray<mirror::String>::Alloc(soa.Self(), c, 0);
David Sehr709b0702016-10-13 09:12:37 -0700111 EXPECT_EQ("java.lang.String[]", mirror::Object::PrettyTypeOf(o));
112 EXPECT_EQ("java.lang.Class<java.lang.String[]>", mirror::Object::PrettyTypeOf(o->GetClass()));
Elliott Hughes54e7df12011-09-16 11:47:04 -0700113}
114
115TEST_F(UtilsTest, PrettyClass) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700116 ScopedObjectAccess soa(Thread::Current());
David Sehr709b0702016-10-13 09:12:37 -0700117 EXPECT_EQ("null", mirror::Class::PrettyClass(nullptr));
Ian Rogers98379392014-02-24 16:53:16 -0800118 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "[Ljava/lang/String;");
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700119 ASSERT_TRUE(c != nullptr);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800120 mirror::Object* o = mirror::ObjectArray<mirror::String>::Alloc(soa.Self(), c, 0);
David Sehr709b0702016-10-13 09:12:37 -0700121 EXPECT_EQ("java.lang.Class<java.lang.String[]>", mirror::Class::PrettyClass(o->GetClass()));
Elliott Hughes54e7df12011-09-16 11:47:04 -0700122}
123
Ian Rogersd81871c2011-10-03 13:57:23 -0700124TEST_F(UtilsTest, PrettyClassAndClassLoader) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700125 ScopedObjectAccess soa(Thread::Current());
David Sehr709b0702016-10-13 09:12:37 -0700126 EXPECT_EQ("null", mirror::Class::PrettyClassAndClassLoader(nullptr));
Ian Rogers98379392014-02-24 16:53:16 -0800127 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "[Ljava/lang/String;");
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700128 ASSERT_TRUE(c != nullptr);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800129 mirror::Object* o = mirror::ObjectArray<mirror::String>::Alloc(soa.Self(), c, 0);
David Sehr709b0702016-10-13 09:12:37 -0700130 EXPECT_EQ("java.lang.Class<java.lang.String[],null>",
131 mirror::Class::PrettyClassAndClassLoader(o->GetClass()));
Ian Rogersd81871c2011-10-03 13:57:23 -0700132}
133
Elliott Hughes54e7df12011-09-16 11:47:04 -0700134TEST_F(UtilsTest, PrettyField) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700135 ScopedObjectAccess soa(Thread::Current());
David Sehr709b0702016-10-13 09:12:37 -0700136 EXPECT_EQ("null", ArtField::PrettyField(nullptr));
Elliott Hughes54e7df12011-09-16 11:47:04 -0700137
Ian Rogers98379392014-02-24 16:53:16 -0800138 mirror::Class* java_lang_String = class_linker_->FindSystemClass(soa.Self(),
139 "Ljava/lang/String;");
Elliott Hughes54e7df12011-09-16 11:47:04 -0700140
Mathieu Chartierc7853442015-03-27 14:35:38 -0700141 ArtField* f;
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700142 f = java_lang_String->FindDeclaredInstanceField("count", "I");
David Sehr709b0702016-10-13 09:12:37 -0700143 EXPECT_EQ("int java.lang.String.count", f->PrettyField());
144 EXPECT_EQ("java.lang.String.count", f->PrettyField(false));
Elliott Hughes11e45072011-08-16 17:40:46 -0700145}
146
Ian Rogers3bb17a62012-01-27 23:56:44 -0800147TEST_F(UtilsTest, PrettySize) {
148 EXPECT_EQ("1GB", PrettySize(1 * GB));
149 EXPECT_EQ("2GB", PrettySize(2 * GB));
150 if (sizeof(size_t) > sizeof(uint32_t)) {
151 EXPECT_EQ("100GB", PrettySize(100 * GB));
152 }
Elliott Hughesc967f782012-04-16 10:23:15 -0700153 EXPECT_EQ("1024KB", PrettySize(1 * MB));
Ian Rogers3bb17a62012-01-27 23:56:44 -0800154 EXPECT_EQ("10MB", PrettySize(10 * MB));
155 EXPECT_EQ("100MB", PrettySize(100 * MB));
Elliott Hughesc967f782012-04-16 10:23:15 -0700156 EXPECT_EQ("1024B", PrettySize(1 * KB));
Elliott Hughes409d2732012-04-03 13:34:44 -0700157 EXPECT_EQ("10KB", PrettySize(10 * KB));
158 EXPECT_EQ("100KB", PrettySize(100 * KB));
Elliott Hughesc967f782012-04-16 10:23:15 -0700159 EXPECT_EQ("0B", PrettySize(0));
Ian Rogers3bb17a62012-01-27 23:56:44 -0800160 EXPECT_EQ("1B", PrettySize(1));
161 EXPECT_EQ("10B", PrettySize(10));
162 EXPECT_EQ("100B", PrettySize(100));
Elliott Hughesc967f782012-04-16 10:23:15 -0700163 EXPECT_EQ("512B", PrettySize(512));
Ian Rogers3bb17a62012-01-27 23:56:44 -0800164}
165
Elliott Hughes79082e32011-08-25 12:07:32 -0700166TEST_F(UtilsTest, MangleForJni) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700167 ScopedObjectAccess soa(Thread::Current());
Elliott Hughes79082e32011-08-25 12:07:32 -0700168 EXPECT_EQ("hello_00024world", MangleForJni("hello$world"));
169 EXPECT_EQ("hello_000a9world", MangleForJni("hello\xc2\xa9world"));
170 EXPECT_EQ("hello_1world", MangleForJni("hello_world"));
171 EXPECT_EQ("Ljava_lang_String_2", MangleForJni("Ljava/lang/String;"));
172 EXPECT_EQ("_3C", MangleForJni("[C"));
173}
174
175TEST_F(UtilsTest, JniShortName_JniLongName) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700176 ScopedObjectAccess soa(Thread::Current());
Ian Rogers98379392014-02-24 16:53:16 -0800177 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "Ljava/lang/String;");
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700178 ASSERT_TRUE(c != nullptr);
Mathieu Chartiere401d142015-04-22 13:56:20 -0700179 ArtMethod* m;
Elliott Hughes79082e32011-08-25 12:07:32 -0700180
Vladimir Markoba118822017-06-12 15:41:56 +0100181 m = c->FindClassMethod("charAt", "(I)C", kRuntimePointerSize);
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700182 ASSERT_TRUE(m != nullptr);
Vladimir Markoba118822017-06-12 15:41:56 +0100183 ASSERT_FALSE(m->IsDirect());
David Sehr709b0702016-10-13 09:12:37 -0700184 EXPECT_EQ("Java_java_lang_String_charAt", m->JniShortName());
185 EXPECT_EQ("Java_java_lang_String_charAt__I", m->JniLongName());
Elliott Hughes79082e32011-08-25 12:07:32 -0700186
Vladimir Markoba118822017-06-12 15:41:56 +0100187 m = c->FindClassMethod("indexOf", "(Ljava/lang/String;I)I", kRuntimePointerSize);
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700188 ASSERT_TRUE(m != nullptr);
Vladimir Markoba118822017-06-12 15:41:56 +0100189 ASSERT_FALSE(m->IsDirect());
David Sehr709b0702016-10-13 09:12:37 -0700190 EXPECT_EQ("Java_java_lang_String_indexOf", m->JniShortName());
191 EXPECT_EQ("Java_java_lang_String_indexOf__Ljava_lang_String_2I", m->JniLongName());
Elliott Hughes79082e32011-08-25 12:07:32 -0700192
Vladimir Markoba118822017-06-12 15:41:56 +0100193 m = c->FindClassMethod("copyValueOf", "([CII)Ljava/lang/String;", kRuntimePointerSize);
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700194 ASSERT_TRUE(m != nullptr);
Vladimir Markoba118822017-06-12 15:41:56 +0100195 ASSERT_TRUE(m->IsStatic());
David Sehr709b0702016-10-13 09:12:37 -0700196 EXPECT_EQ("Java_java_lang_String_copyValueOf", m->JniShortName());
197 EXPECT_EQ("Java_java_lang_String_copyValueOf___3CII", m->JniLongName());
Elliott Hughes79082e32011-08-25 12:07:32 -0700198}
199
Elliott Hughes34023802011-08-30 12:06:17 -0700200TEST_F(UtilsTest, Split) {
201 std::vector<std::string> actual;
202 std::vector<std::string> expected;
203
204 expected.clear();
205
206 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700207 Split("", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700208 EXPECT_EQ(expected, actual);
209
210 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700211 Split(":", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700212 EXPECT_EQ(expected, actual);
213
214 expected.clear();
215 expected.push_back("foo");
216
217 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700218 Split(":foo", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700219 EXPECT_EQ(expected, actual);
220
221 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700222 Split("foo:", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700223 EXPECT_EQ(expected, actual);
224
225 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700226 Split(":foo:", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700227 EXPECT_EQ(expected, actual);
228
229 expected.push_back("bar");
230
231 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700232 Split("foo:bar", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700233 EXPECT_EQ(expected, actual);
234
235 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700236 Split(":foo:bar", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700237 EXPECT_EQ(expected, actual);
238
239 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700240 Split("foo:bar:", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700241 EXPECT_EQ(expected, actual);
242
243 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700244 Split(":foo:bar:", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700245 EXPECT_EQ(expected, actual);
246
247 expected.push_back("baz");
248
249 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700250 Split("foo:bar:baz", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700251 EXPECT_EQ(expected, actual);
252
253 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700254 Split(":foo:bar:baz", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700255 EXPECT_EQ(expected, actual);
256
257 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700258 Split("foo:bar:baz:", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700259 EXPECT_EQ(expected, actual);
260
261 actual.clear();
Ian Rogers6f3dbba2014-10-14 17:41:57 -0700262 Split(":foo:bar:baz:", ':', &actual);
Elliott Hughes34023802011-08-30 12:06:17 -0700263 EXPECT_EQ(expected, actual);
264}
265
Richard Uhler458ab532016-08-15 16:12:57 -0700266TEST_F(UtilsTest, GetDalvikCacheFilename) {
267 std::string name;
268 std::string error;
Narayan Kamath11d9f062014-04-23 20:24:57 +0100269
Richard Uhler458ab532016-08-15 16:12:57 -0700270 EXPECT_TRUE(GetDalvikCacheFilename("/system/app/Foo.apk", "/foo", &name, &error)) << error;
271 EXPECT_EQ("/foo/system@app@Foo.apk@classes.dex", name);
272
273 EXPECT_TRUE(GetDalvikCacheFilename("/data/app/foo-1.apk", "/foo", &name, &error)) << error;
274 EXPECT_EQ("/foo/data@app@foo-1.apk@classes.dex", name);
275
276 EXPECT_TRUE(GetDalvikCacheFilename("/system/framework/core.jar", "/foo", &name, &error)) << error;
277 EXPECT_EQ("/foo/system@framework@core.jar@classes.dex", name);
278
279 EXPECT_TRUE(GetDalvikCacheFilename("/system/framework/boot.art", "/foo", &name, &error)) << error;
280 EXPECT_EQ("/foo/system@framework@boot.art", name);
281
282 EXPECT_TRUE(GetDalvikCacheFilename("/system/framework/boot.oat", "/foo", &name, &error)) << error;
283 EXPECT_EQ("/foo/system@framework@boot.oat", name);
Brian Carlstrom19a08362013-10-16 14:37:22 -0700284}
285
Andreas Gampe40da2862015-02-27 12:49:04 -0800286TEST_F(UtilsTest, GetDalvikCache) {
Richard Uhler55b58b62016-08-12 09:05:13 -0700287 EXPECT_STREQ("", GetDalvikCache("should-not-exist123").c_str());
Andreas Gampe40da2862015-02-27 12:49:04 -0800288
Richard Uhler55b58b62016-08-12 09:05:13 -0700289 EXPECT_STREQ((android_data_ + "/dalvik-cache/.").c_str(), GetDalvikCache(".").c_str());
Andreas Gampe40da2862015-02-27 12:49:04 -0800290}
291
292
Brian Carlstrom0e12bdc2014-05-14 17:44:28 -0700293TEST_F(UtilsTest, GetSystemImageFilename) {
294 EXPECT_STREQ("/system/framework/arm/boot.art",
Vladimir Marko33bff252017-11-01 14:35:42 +0000295 GetSystemImageFilename("/system/framework/boot.art", InstructionSet::kArm).c_str());
Brian Carlstrom0e12bdc2014-05-14 17:44:28 -0700296}
297
Brian Carlstrom6449c622014-02-10 23:48:36 -0800298TEST_F(UtilsTest, ExecSuccess) {
299 std::vector<std::string> command;
300 if (kIsTargetBuild) {
Nicolas Geoffray4f7fdd22015-04-24 11:57:37 +0100301 std::string android_root(GetAndroidRoot());
302 command.push_back(android_root + "/bin/id");
Brian Carlstrom6449c622014-02-10 23:48:36 -0800303 } else {
304 command.push_back("/usr/bin/id");
305 }
306 std::string error_msg;
Evgenii Stepanov1e133742015-05-20 12:30:59 -0700307 if (!(RUNNING_ON_MEMORY_TOOL && kMemoryToolDetectsLeaks)) {
Mathieu Chartier661974a2014-01-09 11:23:53 -0800308 // Running on valgrind fails due to some memory that leaks in thread alternate signal stacks.
309 EXPECT_TRUE(Exec(command, &error_msg));
310 }
Brian Carlstrom6449c622014-02-10 23:48:36 -0800311 EXPECT_EQ(0U, error_msg.size()) << error_msg;
312}
313
Brian Carlstroma1ce1fe2014-02-24 23:23:58 -0800314TEST_F(UtilsTest, ExecError) {
Andreas Gampe369810a2015-01-14 19:53:31 -0800315 // This will lead to error messages in the log.
316 ScopedLogSeverity sls(LogSeverity::FATAL);
317
Brian Carlstrom6449c622014-02-10 23:48:36 -0800318 std::vector<std::string> command;
319 command.push_back("bogus");
320 std::string error_msg;
Evgenii Stepanov1e133742015-05-20 12:30:59 -0700321 if (!(RUNNING_ON_MEMORY_TOOL && kMemoryToolDetectsLeaks)) {
Mathieu Chartier661974a2014-01-09 11:23:53 -0800322 // Running on valgrind fails due to some memory that leaks in thread alternate signal stacks.
323 EXPECT_FALSE(Exec(command, &error_msg));
David Sehrd106d9f2016-08-16 19:22:57 -0700324 EXPECT_FALSE(error_msg.empty());
Mathieu Chartier661974a2014-01-09 11:23:53 -0800325 }
Brian Carlstrom6449c622014-02-10 23:48:36 -0800326}
327
David Sehrd106d9f2016-08-16 19:22:57 -0700328TEST_F(UtilsTest, EnvSnapshotAdditionsAreNotVisible) {
329 static constexpr const char* kModifiedVariable = "EXEC_SHOULD_NOT_EXPORT_THIS";
330 static constexpr int kOverwrite = 1;
331 // Set an variable in the current environment.
332 EXPECT_EQ(setenv(kModifiedVariable, "NEVER", kOverwrite), 0);
333 // Test that it is not exported.
334 std::vector<std::string> command;
335 if (kIsTargetBuild) {
336 std::string android_root(GetAndroidRoot());
337 command.push_back(android_root + "/bin/printenv");
338 } else {
339 command.push_back("/usr/bin/printenv");
340 }
341 command.push_back(kModifiedVariable);
342 std::string error_msg;
343 if (!(RUNNING_ON_MEMORY_TOOL && kMemoryToolDetectsLeaks)) {
344 // Running on valgrind fails due to some memory that leaks in thread alternate signal stacks.
345 EXPECT_FALSE(Exec(command, &error_msg));
346 EXPECT_NE(0U, error_msg.size()) << error_msg;
347 }
348}
349
350TEST_F(UtilsTest, EnvSnapshotDeletionsAreNotVisible) {
351 static constexpr const char* kDeletedVariable = "PATH";
352 static constexpr int kOverwrite = 1;
353 // Save the variable's value.
354 const char* save_value = getenv(kDeletedVariable);
355 EXPECT_NE(save_value, nullptr);
356 // Delete the variable.
357 EXPECT_EQ(unsetenv(kDeletedVariable), 0);
358 // Test that it is not exported.
359 std::vector<std::string> command;
360 if (kIsTargetBuild) {
361 std::string android_root(GetAndroidRoot());
362 command.push_back(android_root + "/bin/printenv");
363 } else {
364 command.push_back("/usr/bin/printenv");
365 }
366 command.push_back(kDeletedVariable);
367 std::string error_msg;
368 if (!(RUNNING_ON_MEMORY_TOOL && kMemoryToolDetectsLeaks)) {
369 // Running on valgrind fails due to some memory that leaks in thread alternate signal stacks.
370 EXPECT_TRUE(Exec(command, &error_msg));
371 EXPECT_EQ(0U, error_msg.size()) << error_msg;
372 }
373 // Restore the variable's value.
374 EXPECT_EQ(setenv(kDeletedVariable, save_value, kOverwrite), 0);
375}
376
Narayan Kamath8508e372015-05-06 14:55:43 +0100377TEST_F(UtilsTest, IsValidDescriptor) {
378 std::vector<uint8_t> descriptor(
379 { 'L', 'a', '/', 'b', '$', 0xed, 0xa0, 0x80, 0xed, 0xb0, 0x80, ';', 0x00 });
380 EXPECT_TRUE(IsValidDescriptor(reinterpret_cast<char*>(&descriptor[0])));
381
382 std::vector<uint8_t> unpaired_surrogate(
383 { 'L', 'a', '/', 'b', '$', 0xed, 0xa0, 0x80, ';', 0x00 });
384 EXPECT_FALSE(IsValidDescriptor(reinterpret_cast<char*>(&unpaired_surrogate[0])));
385
386 std::vector<uint8_t> unpaired_surrogate_at_end(
387 { 'L', 'a', '/', 'b', '$', 0xed, 0xa0, 0x80, 0x00 });
388 EXPECT_FALSE(IsValidDescriptor(reinterpret_cast<char*>(&unpaired_surrogate_at_end[0])));
389
390 std::vector<uint8_t> invalid_surrogate(
391 { 'L', 'a', '/', 'b', '$', 0xed, 0xb0, 0x80, ';', 0x00 });
392 EXPECT_FALSE(IsValidDescriptor(reinterpret_cast<char*>(&invalid_surrogate[0])));
393
394 std::vector<uint8_t> unpaired_surrogate_with_multibyte_sequence(
395 { 'L', 'a', '/', 'b', '$', 0xed, 0xb0, 0x80, 0xf0, 0x9f, 0x8f, 0xa0, ';', 0x00 });
396 EXPECT_FALSE(
397 IsValidDescriptor(reinterpret_cast<char*>(&unpaired_surrogate_with_multibyte_sequence[0])));
398}
399
Orion Hodsonc069a302017-01-18 09:23:12 +0000400TEST_F(UtilsTest, ArrayCount) {
401 int i[64];
402 EXPECT_EQ(ArrayCount(i), 64u);
403 char c[7];
404 EXPECT_EQ(ArrayCount(c), 7u);
405}
406
407TEST_F(UtilsTest, BoundsCheckedCast) {
408 char buffer[64];
409 const char* buffer_end = buffer + ArrayCount(buffer);
410 EXPECT_EQ(BoundsCheckedCast<const uint64_t*>(nullptr, buffer, buffer_end), nullptr);
411 EXPECT_EQ(BoundsCheckedCast<const uint64_t*>(buffer, buffer, buffer_end),
412 reinterpret_cast<const uint64_t*>(buffer));
413 EXPECT_EQ(BoundsCheckedCast<const uint64_t*>(buffer + 56, buffer, buffer_end),
414 reinterpret_cast<const uint64_t*>(buffer + 56));
415 EXPECT_EQ(BoundsCheckedCast<const uint64_t*>(buffer - 1, buffer, buffer_end), nullptr);
416 EXPECT_EQ(BoundsCheckedCast<const uint64_t*>(buffer + 57, buffer, buffer_end), nullptr);
417}
418
Andreas Gampe3f093892017-09-14 15:11:01 -0700419TEST_F(UtilsTest, GetAndroidRootSafe) {
420 std::string error_msg;
421
422 // We don't expect null returns for most cases, so don't check and let std::string crash.
423
424 // CommonRuntimeTest sets ANDROID_ROOT, so expect this to be the same.
425 std::string android_root = GetAndroidRootSafe(&error_msg);
426 std::string android_root_env = getenv("ANDROID_ROOT");
427 EXPECT_EQ(android_root, android_root_env);
428
429 // Set ANDROID_ROOT to something else (but the directory must exist). So use dirname.
430 char* root_dup = strdup(android_root_env.c_str());
431 char* dir = dirname(root_dup);
432 ASSERT_EQ(0, setenv("ANDROID_ROOT", dir, 1 /* overwrite */));
433 std::string android_root2 = GetAndroidRootSafe(&error_msg);
434 EXPECT_STREQ(dir, android_root2.c_str());
435 free(root_dup);
436
437 // Set a bogus value for ANDROID_ROOT. This should be an error.
438 ASSERT_EQ(0, setenv("ANDROID_ROOT", "/this/is/obviously/bogus", 1 /* overwrite */));
439 EXPECT_TRUE(GetAndroidRootSafe(&error_msg) == nullptr);
440
441 // Unset ANDROID_ROOT and see that it still returns something (as libart code is running).
442 ASSERT_EQ(0, unsetenv("ANDROID_ROOT"));
443 std::string android_root3 = GetAndroidRootSafe(&error_msg);
444 // This should be the same as the other root (modulo realpath), otherwise the test setup is
445 // broken.
446 UniqueCPtr<char> real_root(realpath(android_root.c_str(), nullptr));
447 UniqueCPtr<char> real_root3(realpath(android_root3.c_str(), nullptr));
448 EXPECT_STREQ(real_root.get(), real_root3.get());
449
450
451 // Reset ANDROID_ROOT, as other things may depend on it.
452 ASSERT_EQ(0, setenv("ANDROID_ROOT", android_root_env.c_str(), 1 /* overwrite */));
453}
454
Elliott Hughes11e45072011-08-16 17:40:46 -0700455} // namespace art