blob: 4a1e477bbddff13c8d7a8225711ee2e508856138 [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
19#include "common_runtime_test.h"
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080020#include "mirror/array.h"
21#include "mirror/array-inl.h"
22#include "mirror/object-inl.h"
23#include "mirror/object_array-inl.h"
24#include "mirror/string.h"
Ian Rogers00f7d0e2012-07-19 15:28:27 -070025#include "scoped_thread_state_change.h"
Mathieu Chartiereb8167a2014-05-07 15:43:14 -070026#include "handle_scope-inl.h"
Elliott Hughes11e45072011-08-16 17:40:46 -070027
Mathieu Chartier661974a2014-01-09 11:23:53 -080028#include <valgrind.h>
29
Elliott Hughes11e45072011-08-16 17:40:46 -070030namespace art {
31
Elliott Hughes9058f2b2012-03-22 18:06:48 -070032std::string PrettyArguments(const char* signature);
33std::string PrettyReturnType(const char* signature);
34
Brian Carlstroma1ce1fe2014-02-24 23:23:58 -080035class UtilsTest : public CommonRuntimeTest {};
Elliott Hughes11e45072011-08-16 17:40:46 -070036
Elliott Hughes5174fe62011-08-23 15:12:35 -070037TEST_F(UtilsTest, PrettyDescriptor_ArrayReferences) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070038 EXPECT_EQ("java.lang.Class[]", PrettyDescriptor("[Ljava/lang/Class;"));
39 EXPECT_EQ("java.lang.Class[][]", PrettyDescriptor("[[Ljava/lang/Class;"));
Elliott Hughes11e45072011-08-16 17:40:46 -070040}
41
Elliott Hughes5174fe62011-08-23 15:12:35 -070042TEST_F(UtilsTest, PrettyDescriptor_ScalarReferences) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070043 EXPECT_EQ("java.lang.String", PrettyDescriptor("Ljava.lang.String;"));
44 EXPECT_EQ("java.lang.String", PrettyDescriptor("Ljava/lang/String;"));
Elliott Hughes11e45072011-08-16 17:40:46 -070045}
46
Elliott Hughes5174fe62011-08-23 15:12:35 -070047TEST_F(UtilsTest, PrettyDescriptor_PrimitiveArrays) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070048 EXPECT_EQ("boolean[]", PrettyDescriptor("[Z"));
49 EXPECT_EQ("boolean[][]", PrettyDescriptor("[[Z"));
50 EXPECT_EQ("byte[]", PrettyDescriptor("[B"));
51 EXPECT_EQ("byte[][]", PrettyDescriptor("[[B"));
52 EXPECT_EQ("char[]", PrettyDescriptor("[C"));
53 EXPECT_EQ("char[][]", PrettyDescriptor("[[C"));
54 EXPECT_EQ("double[]", PrettyDescriptor("[D"));
55 EXPECT_EQ("double[][]", PrettyDescriptor("[[D"));
56 EXPECT_EQ("float[]", PrettyDescriptor("[F"));
57 EXPECT_EQ("float[][]", PrettyDescriptor("[[F"));
58 EXPECT_EQ("int[]", PrettyDescriptor("[I"));
59 EXPECT_EQ("int[][]", PrettyDescriptor("[[I"));
60 EXPECT_EQ("long[]", PrettyDescriptor("[J"));
61 EXPECT_EQ("long[][]", PrettyDescriptor("[[J"));
62 EXPECT_EQ("short[]", PrettyDescriptor("[S"));
63 EXPECT_EQ("short[][]", PrettyDescriptor("[[S"));
Elliott Hughes11e45072011-08-16 17:40:46 -070064}
65
Elliott Hughes5174fe62011-08-23 15:12:35 -070066TEST_F(UtilsTest, PrettyDescriptor_PrimitiveScalars) {
Elliott Hughes9058f2b2012-03-22 18:06:48 -070067 EXPECT_EQ("boolean", PrettyDescriptor("Z"));
68 EXPECT_EQ("byte", PrettyDescriptor("B"));
69 EXPECT_EQ("char", PrettyDescriptor("C"));
70 EXPECT_EQ("double", PrettyDescriptor("D"));
71 EXPECT_EQ("float", PrettyDescriptor("F"));
72 EXPECT_EQ("int", PrettyDescriptor("I"));
73 EXPECT_EQ("long", PrettyDescriptor("J"));
74 EXPECT_EQ("short", PrettyDescriptor("S"));
75}
76
77TEST_F(UtilsTest, PrettyArguments) {
78 EXPECT_EQ("()", PrettyArguments("()V"));
79 EXPECT_EQ("(int)", PrettyArguments("(I)V"));
80 EXPECT_EQ("(int, int)", PrettyArguments("(II)V"));
81 EXPECT_EQ("(int, int, int[][])", PrettyArguments("(II[[I)V"));
82 EXPECT_EQ("(int, int, int[][], java.lang.Poop)", PrettyArguments("(II[[ILjava/lang/Poop;)V"));
83 EXPECT_EQ("(int, int, int[][], java.lang.Poop, java.lang.Poop[][])", PrettyArguments("(II[[ILjava/lang/Poop;[[Ljava/lang/Poop;)V"));
84}
85
86TEST_F(UtilsTest, PrettyReturnType) {
87 EXPECT_EQ("void", PrettyReturnType("()V"));
88 EXPECT_EQ("int", PrettyReturnType("()I"));
89 EXPECT_EQ("int[][]", PrettyReturnType("()[[I"));
90 EXPECT_EQ("java.lang.Poop", PrettyReturnType("()Ljava/lang/Poop;"));
91 EXPECT_EQ("java.lang.Poop[][]", PrettyReturnType("()[[Ljava/lang/Poop;"));
Elliott Hughes11e45072011-08-16 17:40:46 -070092}
93
Elliott Hughes54e7df12011-09-16 11:47:04 -070094TEST_F(UtilsTest, PrettyTypeOf) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -070095 ScopedObjectAccess soa(Thread::Current());
Elliott Hughes54e7df12011-09-16 11:47:04 -070096 EXPECT_EQ("null", PrettyTypeOf(NULL));
Elliott Hughes11e45072011-08-16 17:40:46 -070097
Mathieu Chartiereb8167a2014-05-07 15:43:14 -070098 StackHandleScope<2> hs(soa.Self());
99 Handle<mirror::String> s(hs.NewHandle(mirror::String::AllocFromModifiedUtf8(soa.Self(), "")));
100 EXPECT_EQ("java.lang.String", PrettyTypeOf(s.Get()));
Elliott Hughes11e45072011-08-16 17:40:46 -0700101
Mathieu Chartiereb8167a2014-05-07 15:43:14 -0700102 Handle<mirror::ShortArray> a(hs.NewHandle(mirror::ShortArray::Alloc(soa.Self(), 2)));
103 EXPECT_EQ("short[]", PrettyTypeOf(a.Get()));
Elliott Hughes11e45072011-08-16 17:40:46 -0700104
Ian Rogers98379392014-02-24 16:53:16 -0800105 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "[Ljava/lang/String;");
Elliott Hughes11e45072011-08-16 17:40:46 -0700106 ASSERT_TRUE(c != NULL);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800107 mirror::Object* o = mirror::ObjectArray<mirror::String>::Alloc(soa.Self(), c, 0);
Elliott Hughes54e7df12011-09-16 11:47:04 -0700108 EXPECT_EQ("java.lang.String[]", PrettyTypeOf(o));
109 EXPECT_EQ("java.lang.Class<java.lang.String[]>", PrettyTypeOf(o->GetClass()));
110}
111
112TEST_F(UtilsTest, PrettyClass) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700113 ScopedObjectAccess soa(Thread::Current());
Elliott Hughes54e7df12011-09-16 11:47:04 -0700114 EXPECT_EQ("null", PrettyClass(NULL));
Ian Rogers98379392014-02-24 16:53:16 -0800115 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "[Ljava/lang/String;");
Elliott Hughes54e7df12011-09-16 11:47:04 -0700116 ASSERT_TRUE(c != NULL);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800117 mirror::Object* o = mirror::ObjectArray<mirror::String>::Alloc(soa.Self(), c, 0);
Elliott Hughes54e7df12011-09-16 11:47:04 -0700118 EXPECT_EQ("java.lang.Class<java.lang.String[]>", PrettyClass(o->GetClass()));
119}
120
Ian Rogersd81871c2011-10-03 13:57:23 -0700121TEST_F(UtilsTest, PrettyClassAndClassLoader) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700122 ScopedObjectAccess soa(Thread::Current());
Ian Rogersd81871c2011-10-03 13:57:23 -0700123 EXPECT_EQ("null", PrettyClassAndClassLoader(NULL));
Ian Rogers98379392014-02-24 16:53:16 -0800124 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "[Ljava/lang/String;");
Ian Rogersd81871c2011-10-03 13:57:23 -0700125 ASSERT_TRUE(c != NULL);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800126 mirror::Object* o = mirror::ObjectArray<mirror::String>::Alloc(soa.Self(), c, 0);
Ian Rogersd81871c2011-10-03 13:57:23 -0700127 EXPECT_EQ("java.lang.Class<java.lang.String[],null>", PrettyClassAndClassLoader(o->GetClass()));
128}
129
Elliott Hughes54e7df12011-09-16 11:47:04 -0700130TEST_F(UtilsTest, PrettyField) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700131 ScopedObjectAccess soa(Thread::Current());
Elliott Hughes54e7df12011-09-16 11:47:04 -0700132 EXPECT_EQ("null", PrettyField(NULL));
133
Ian Rogers98379392014-02-24 16:53:16 -0800134 mirror::Class* java_lang_String = class_linker_->FindSystemClass(soa.Self(),
135 "Ljava/lang/String;");
Elliott Hughes54e7df12011-09-16 11:47:04 -0700136
Brian Carlstromea46f952013-07-30 01:26:50 -0700137 mirror::ArtField* f;
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700138 f = java_lang_String->FindDeclaredInstanceField("count", "I");
Elliott Hughes54e7df12011-09-16 11:47:04 -0700139 EXPECT_EQ("int java.lang.String.count", PrettyField(f));
140 EXPECT_EQ("java.lang.String.count", PrettyField(f, false));
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700141 f = java_lang_String->FindDeclaredInstanceField("value", "[C");
Elliott Hughes54e7df12011-09-16 11:47:04 -0700142 EXPECT_EQ("char[] java.lang.String.value", PrettyField(f));
143 EXPECT_EQ("java.lang.String.value", PrettyField(f, false));
Elliott Hughes11e45072011-08-16 17:40:46 -0700144}
145
Ian Rogers3bb17a62012-01-27 23:56:44 -0800146TEST_F(UtilsTest, PrettySize) {
147 EXPECT_EQ("1GB", PrettySize(1 * GB));
148 EXPECT_EQ("2GB", PrettySize(2 * GB));
149 if (sizeof(size_t) > sizeof(uint32_t)) {
150 EXPECT_EQ("100GB", PrettySize(100 * GB));
151 }
Elliott Hughesc967f782012-04-16 10:23:15 -0700152 EXPECT_EQ("1024KB", PrettySize(1 * MB));
Ian Rogers3bb17a62012-01-27 23:56:44 -0800153 EXPECT_EQ("10MB", PrettySize(10 * MB));
154 EXPECT_EQ("100MB", PrettySize(100 * MB));
Elliott Hughesc967f782012-04-16 10:23:15 -0700155 EXPECT_EQ("1024B", PrettySize(1 * KB));
Elliott Hughes409d2732012-04-03 13:34:44 -0700156 EXPECT_EQ("10KB", PrettySize(10 * KB));
157 EXPECT_EQ("100KB", PrettySize(100 * KB));
Elliott Hughesc967f782012-04-16 10:23:15 -0700158 EXPECT_EQ("0B", PrettySize(0));
Ian Rogers3bb17a62012-01-27 23:56:44 -0800159 EXPECT_EQ("1B", PrettySize(1));
160 EXPECT_EQ("10B", PrettySize(10));
161 EXPECT_EQ("100B", PrettySize(100));
Elliott Hughesc967f782012-04-16 10:23:15 -0700162 EXPECT_EQ("512B", PrettySize(512));
Ian Rogers3bb17a62012-01-27 23:56:44 -0800163}
164
165TEST_F(UtilsTest, PrettyDuration) {
166 const uint64_t one_sec = 1000000000;
167 const uint64_t one_ms = 1000000;
168 const uint64_t one_us = 1000;
169
170 EXPECT_EQ("1s", PrettyDuration(1 * one_sec));
171 EXPECT_EQ("10s", PrettyDuration(10 * one_sec));
172 EXPECT_EQ("100s", PrettyDuration(100 * one_sec));
173 EXPECT_EQ("1.001s", PrettyDuration(1 * one_sec + one_ms));
174 EXPECT_EQ("1.000001s", PrettyDuration(1 * one_sec + one_us));
175 EXPECT_EQ("1.000000001s", PrettyDuration(1 * one_sec + 1));
176
177 EXPECT_EQ("1ms", PrettyDuration(1 * one_ms));
178 EXPECT_EQ("10ms", PrettyDuration(10 * one_ms));
179 EXPECT_EQ("100ms", PrettyDuration(100 * one_ms));
180 EXPECT_EQ("1.001ms", PrettyDuration(1 * one_ms + one_us));
181 EXPECT_EQ("1.000001ms", PrettyDuration(1 * one_ms + 1));
182
183 EXPECT_EQ("1us", PrettyDuration(1 * one_us));
184 EXPECT_EQ("10us", PrettyDuration(10 * one_us));
185 EXPECT_EQ("100us", PrettyDuration(100 * one_us));
186 EXPECT_EQ("1.001us", PrettyDuration(1 * one_us + 1));
187
188 EXPECT_EQ("1ns", PrettyDuration(1));
189 EXPECT_EQ("10ns", PrettyDuration(10));
190 EXPECT_EQ("100ns", PrettyDuration(100));
191}
192
Elliott Hughes79082e32011-08-25 12:07:32 -0700193TEST_F(UtilsTest, MangleForJni) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700194 ScopedObjectAccess soa(Thread::Current());
Elliott Hughes79082e32011-08-25 12:07:32 -0700195 EXPECT_EQ("hello_00024world", MangleForJni("hello$world"));
196 EXPECT_EQ("hello_000a9world", MangleForJni("hello\xc2\xa9world"));
197 EXPECT_EQ("hello_1world", MangleForJni("hello_world"));
198 EXPECT_EQ("Ljava_lang_String_2", MangleForJni("Ljava/lang/String;"));
199 EXPECT_EQ("_3C", MangleForJni("[C"));
200}
201
202TEST_F(UtilsTest, JniShortName_JniLongName) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700203 ScopedObjectAccess soa(Thread::Current());
Ian Rogers98379392014-02-24 16:53:16 -0800204 mirror::Class* c = class_linker_->FindSystemClass(soa.Self(), "Ljava/lang/String;");
Elliott Hughes79082e32011-08-25 12:07:32 -0700205 ASSERT_TRUE(c != NULL);
Brian Carlstromea46f952013-07-30 01:26:50 -0700206 mirror::ArtMethod* m;
Elliott Hughes79082e32011-08-25 12:07:32 -0700207
208 m = c->FindVirtualMethod("charAt", "(I)C");
209 ASSERT_TRUE(m != NULL);
210 EXPECT_EQ("Java_java_lang_String_charAt", JniShortName(m));
211 EXPECT_EQ("Java_java_lang_String_charAt__I", JniLongName(m));
212
213 m = c->FindVirtualMethod("indexOf", "(Ljava/lang/String;I)I");
214 ASSERT_TRUE(m != NULL);
215 EXPECT_EQ("Java_java_lang_String_indexOf", JniShortName(m));
216 EXPECT_EQ("Java_java_lang_String_indexOf__Ljava_lang_String_2I", JniLongName(m));
217
218 m = c->FindDirectMethod("copyValueOf", "([CII)Ljava/lang/String;");
219 ASSERT_TRUE(m != NULL);
220 EXPECT_EQ("Java_java_lang_String_copyValueOf", JniShortName(m));
221 EXPECT_EQ("Java_java_lang_String_copyValueOf___3CII", JniLongName(m));
222}
223
Elliott Hughes34023802011-08-30 12:06:17 -0700224TEST_F(UtilsTest, Split) {
225 std::vector<std::string> actual;
226 std::vector<std::string> expected;
227
228 expected.clear();
229
230 actual.clear();
231 Split("", ':', actual);
232 EXPECT_EQ(expected, actual);
233
234 actual.clear();
235 Split(":", ':', actual);
236 EXPECT_EQ(expected, actual);
237
238 expected.clear();
239 expected.push_back("foo");
240
241 actual.clear();
242 Split(":foo", ':', actual);
243 EXPECT_EQ(expected, actual);
244
245 actual.clear();
246 Split("foo:", ':', actual);
247 EXPECT_EQ(expected, actual);
248
249 actual.clear();
250 Split(":foo:", ':', actual);
251 EXPECT_EQ(expected, actual);
252
253 expected.push_back("bar");
254
255 actual.clear();
256 Split("foo:bar", ':', actual);
257 EXPECT_EQ(expected, actual);
258
259 actual.clear();
260 Split(":foo:bar", ':', actual);
261 EXPECT_EQ(expected, actual);
262
263 actual.clear();
264 Split("foo:bar:", ':', actual);
265 EXPECT_EQ(expected, actual);
266
267 actual.clear();
268 Split(":foo:bar:", ':', actual);
269 EXPECT_EQ(expected, actual);
270
271 expected.push_back("baz");
272
273 actual.clear();
274 Split("foo:bar:baz", ':', actual);
275 EXPECT_EQ(expected, actual);
276
277 actual.clear();
278 Split(":foo:bar:baz", ':', actual);
279 EXPECT_EQ(expected, actual);
280
281 actual.clear();
282 Split("foo:bar:baz:", ':', actual);
283 EXPECT_EQ(expected, actual);
284
285 actual.clear();
286 Split(":foo:bar:baz:", ':', actual);
287 EXPECT_EQ(expected, actual);
288}
289
Elliott Hughes48436bb2012-02-07 15:23:28 -0800290TEST_F(UtilsTest, Join) {
291 std::vector<std::string> strings;
292
293 strings.clear();
294 EXPECT_EQ("", Join(strings, ':'));
295
296 strings.clear();
297 strings.push_back("foo");
298 EXPECT_EQ("foo", Join(strings, ':'));
299
300 strings.clear();
301 strings.push_back("");
302 strings.push_back("foo");
303 EXPECT_EQ(":foo", Join(strings, ':'));
304
305 strings.clear();
306 strings.push_back("foo");
307 strings.push_back("");
308 EXPECT_EQ("foo:", Join(strings, ':'));
309
310 strings.clear();
311 strings.push_back("");
312 strings.push_back("foo");
313 strings.push_back("");
314 EXPECT_EQ(":foo:", Join(strings, ':'));
315
316 strings.clear();
317 strings.push_back("foo");
318 strings.push_back("bar");
319 EXPECT_EQ("foo:bar", Join(strings, ':'));
320
321 strings.clear();
322 strings.push_back("foo");
323 strings.push_back("bar");
324 strings.push_back("baz");
325 EXPECT_EQ("foo:bar:baz", Join(strings, ':'));
326}
327
Brian Carlstrom7a967b32012-03-28 15:23:10 -0700328TEST_F(UtilsTest, StartsWith) {
329 EXPECT_FALSE(StartsWith("foo", "bar"));
330 EXPECT_TRUE(StartsWith("foo", "foo"));
331 EXPECT_TRUE(StartsWith("food", "foo"));
332 EXPECT_FALSE(StartsWith("fo", "foo"));
333}
334
335TEST_F(UtilsTest, EndsWith) {
336 EXPECT_FALSE(EndsWith("foo", "bar"));
337 EXPECT_TRUE(EndsWith("foo", "foo"));
338 EXPECT_TRUE(EndsWith("foofoo", "foo"));
339 EXPECT_FALSE(EndsWith("oo", "foo"));
340}
341
Brian Carlstrom19a08362013-10-16 14:37:22 -0700342TEST_F(UtilsTest, GetDalvikCacheFilenameOrDie) {
Narayan Kamath11d9f062014-04-23 20:24:57 +0100343 EXPECT_STREQ("/foo/system@app@Foo.apk@classes.dex",
344 GetDalvikCacheFilenameOrDie("/system/app/Foo.apk", "/foo").c_str());
345
346 EXPECT_STREQ("/foo/data@app@foo-1.apk@classes.dex",
347 GetDalvikCacheFilenameOrDie("/data/app/foo-1.apk", "/foo").c_str());
348 EXPECT_STREQ("/foo/system@framework@core.jar@classes.dex",
349 GetDalvikCacheFilenameOrDie("/system/framework/core.jar", "/foo").c_str());
350 EXPECT_STREQ("/foo/system@framework@boot.art",
351 GetDalvikCacheFilenameOrDie("/system/framework/boot.art", "/foo").c_str());
Brian Carlstrom19a08362013-10-16 14:37:22 -0700352}
353
Brian Carlstrom0e12bdc2014-05-14 17:44:28 -0700354TEST_F(UtilsTest, GetSystemImageFilename) {
355 EXPECT_STREQ("/system/framework/arm/boot.art",
356 GetSystemImageFilename("/system/framework/boot.art", kArm).c_str());
357}
358
359TEST_F(UtilsTest, DexFilenameToOdexFilename) {
360 EXPECT_STREQ("/foo/bar/arm/baz.odex",
361 DexFilenameToOdexFilename("/foo/bar/baz.jar", kArm).c_str());
362}
363
Brian Carlstrom6449c622014-02-10 23:48:36 -0800364TEST_F(UtilsTest, ExecSuccess) {
365 std::vector<std::string> command;
366 if (kIsTargetBuild) {
367 command.push_back("/system/bin/id");
368 } else {
369 command.push_back("/usr/bin/id");
370 }
371 std::string error_msg;
Mathieu Chartier661974a2014-01-09 11:23:53 -0800372 if (RUNNING_ON_VALGRIND == 0) {
373 // Running on valgrind fails due to some memory that leaks in thread alternate signal stacks.
374 EXPECT_TRUE(Exec(command, &error_msg));
375 }
Brian Carlstrom6449c622014-02-10 23:48:36 -0800376 EXPECT_EQ(0U, error_msg.size()) << error_msg;
377}
378
Brian Carlstroma1ce1fe2014-02-24 23:23:58 -0800379TEST_F(UtilsTest, ExecError) {
Brian Carlstrom6449c622014-02-10 23:48:36 -0800380 std::vector<std::string> command;
381 command.push_back("bogus");
382 std::string error_msg;
Mathieu Chartier661974a2014-01-09 11:23:53 -0800383 if (RUNNING_ON_VALGRIND == 0) {
384 // Running on valgrind fails due to some memory that leaks in thread alternate signal stacks.
385 EXPECT_FALSE(Exec(command, &error_msg));
386 EXPECT_NE(0U, error_msg.size());
387 }
Brian Carlstrom6449c622014-02-10 23:48:36 -0800388}
389
Elliott Hughes11e45072011-08-16 17:40:46 -0700390} // namespace art