diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/082-inline-execute/src/Main.java | 22 | ||||
| -rw-r--r-- | test/114-ParallelGC/src/Main.java | 5 | ||||
| -rwxr-xr-x | test/131-structural-change/build | 31 | ||||
| -rw-r--r-- | test/131-structural-change/expected.txt | 2 | ||||
| -rw-r--r-- | test/131-structural-change/info.txt | 1 | ||||
| -rwxr-xr-x | test/131-structural-change/run | 18 | ||||
| -rw-r--r-- | test/131-structural-change/src-ex/A.java | 20 | ||||
| -rw-r--r-- | test/131-structural-change/src-ex/B.java | 21 | ||||
| -rw-r--r-- | test/131-structural-change/src/A.java | 26 | ||||
| -rw-r--r-- | test/131-structural-change/src/Main.java | 57 | ||||
| -rw-r--r-- | test/Android.run-test.mk | 1 | ||||
| -rwxr-xr-x | test/etc/run-test-jar | 4 | ||||
| -rwxr-xr-x | test/run-test | 2 |
13 files changed, 206 insertions, 4 deletions
diff --git a/test/082-inline-execute/src/Main.java b/test/082-inline-execute/src/Main.java index 56972ff216..862fe066ce 100644 --- a/test/082-inline-execute/src/Main.java +++ b/test/082-inline-execute/src/Main.java @@ -119,6 +119,9 @@ public class Main { } } + // Break up the charAt tests. The optimizing compiler doesn't optimize methods with try-catch yet, + // so we need to separate out the tests that are expected to throw exception + public static void test_String_charAt() { String testStr = "Now is the time"; @@ -127,6 +130,12 @@ public class Main { Assert.assertEquals(' ', testStr.charAt(10)); Assert.assertEquals('e', testStr.charAt(testStr.length()-1)); + test_String_charAtExc(); + test_String_charAtExc2(); + } + + private static void test_String_charAtExc() { + String testStr = "Now is the time"; try { testStr.charAt(-1); Assert.fail(); @@ -146,6 +155,19 @@ public class Main { } } + private static void test_String_charAtExc2() { + try { + test_String_charAtExc3(); + Assert.fail(); + } catch (StringIndexOutOfBoundsException expected) { + } + } + + private static void test_String_charAtExc3() { + String testStr = "Now is the time"; + Assert.assertEquals('N', testStr.charAt(-1)); + } + static int start; private static int[] negIndex = { -100000 }; public static void test_String_indexOf() { diff --git a/test/114-ParallelGC/src/Main.java b/test/114-ParallelGC/src/Main.java index 8e2519dd0a..48f9bd363f 100644 --- a/test/114-ParallelGC/src/Main.java +++ b/test/114-ParallelGC/src/Main.java @@ -24,7 +24,10 @@ import java.util.concurrent.TimeoutException; public class Main implements Runnable { - public final static long TIMEOUT_VALUE = 5; // Timeout in minutes. + // Timeout in minutes. Make it larger than the run-test timeout to get a native thread dump by + // ART on timeout when running on the host. + public final static long TIMEOUT_VALUE = 12; + public final static long MAX_SIZE = 1000; // Maximum size of array-list to allocate. public static void main(String[] args) throws Exception { diff --git a/test/131-structural-change/build b/test/131-structural-change/build new file mode 100755 index 0000000000..7ddc81d9b8 --- /dev/null +++ b/test/131-structural-change/build @@ -0,0 +1,31 @@ +#!/bin/bash +# +# Copyright (C) 2015 The Android Open Source Project +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Stop if something fails. +set -e + +mkdir classes +${JAVAC} -d classes `find src -name '*.java'` + +mkdir classes-ex +${JAVAC} -d classes-ex `find src-ex -name '*.java'` + +if [ ${NEED_DEX} = "true" ]; then + ${DX} -JXmx256m --debug --dex --dump-to=classes.lst --output=classes.dex --dump-width=1000 classes + zip $TEST_NAME.jar classes.dex + ${DX} -JXmx256m --debug --dex --dump-to=classes-ex.lst --output=classes.dex --dump-width=1000 classes-ex + zip ${TEST_NAME}-ex.jar classes.dex +fi diff --git a/test/131-structural-change/expected.txt b/test/131-structural-change/expected.txt new file mode 100644 index 0000000000..cc7713d252 --- /dev/null +++ b/test/131-structural-change/expected.txt @@ -0,0 +1,2 @@ +Should really reach here. +Done. diff --git a/test/131-structural-change/info.txt b/test/131-structural-change/info.txt new file mode 100644 index 0000000000..6d5817bcea --- /dev/null +++ b/test/131-structural-change/info.txt @@ -0,0 +1 @@ +Check whether a structural change in a (non-native) multi-dex scenario is detected. diff --git a/test/131-structural-change/run b/test/131-structural-change/run new file mode 100755 index 0000000000..63fdb8c749 --- /dev/null +++ b/test/131-structural-change/run @@ -0,0 +1,18 @@ +#!/bin/bash +# +# Copyright (C) 2015 The Android Open Source Project +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Use secondary switch to add secondary dex file to class path. +exec ${RUN} "${@}" --secondary diff --git a/test/131-structural-change/src-ex/A.java b/test/131-structural-change/src-ex/A.java new file mode 100644 index 0000000000..800347b716 --- /dev/null +++ b/test/131-structural-change/src-ex/A.java @@ -0,0 +1,20 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +public class A { + public void bar() { + } +} diff --git a/test/131-structural-change/src-ex/B.java b/test/131-structural-change/src-ex/B.java new file mode 100644 index 0000000000..61369db32d --- /dev/null +++ b/test/131-structural-change/src-ex/B.java @@ -0,0 +1,21 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +public class B extends A { + public void test() { + System.out.println("Should not reach this!"); + } +} diff --git a/test/131-structural-change/src/A.java b/test/131-structural-change/src/A.java new file mode 100644 index 0000000000..b07de581d8 --- /dev/null +++ b/test/131-structural-change/src/A.java @@ -0,0 +1,26 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +public class A { + public void foo() { + } + + public void bar() { + } + + public void baz() { + } +} diff --git a/test/131-structural-change/src/Main.java b/test/131-structural-change/src/Main.java new file mode 100644 index 0000000000..8dfa2808a2 --- /dev/null +++ b/test/131-structural-change/src/Main.java @@ -0,0 +1,57 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import java.io.File; +import java.lang.reflect.Constructor; +import java.lang.reflect.Method; + +/** + * Structural hazard test. + */ +public class Main { + public static void main(String[] args) { + new Main().run(); + } + + private void run() { + try { + Class<?> bClass = getClass().getClassLoader().loadClass("A"); + System.out.println("Should really reach here."); + } catch (Exception e) { + e.printStackTrace(System.out); + } + + boolean haveOatFile = hasOat(); + boolean gotError = false; + try { + Class<?> bClass = getClass().getClassLoader().loadClass("B"); + } catch (IncompatibleClassChangeError icce) { + gotError = true; + } catch (Exception e) { + e.printStackTrace(System.out); + } + if (haveOatFile ^ gotError) { + System.out.println("Did not get expected error."); + } + System.out.println("Done."); + } + + static { + System.loadLibrary("arttest"); + } + + private native static boolean hasOat(); +} diff --git a/test/Android.run-test.mk b/test/Android.run-test.mk index dc4ec66ce7..04c590e876 100644 --- a/test/Android.run-test.mk +++ b/test/Android.run-test.mk @@ -282,6 +282,7 @@ TEST_ART_BROKEN_NDEBUG_TESTS := \ 117-nopatchoat \ 118-noimage-dex2oat \ 119-noimage-patchoat \ + 131-structural-change \ ifneq (,$(filter ndebug,$(RUN_TYPES))) ART_TEST_KNOWN_BROKEN += $(call all-run-test-names,$(TARGET_TYPES),ndebug,$(PREBUILD_TYPES), \ diff --git a/test/etc/run-test-jar b/test/etc/run-test-jar index 2710df8dc4..92b1e8233f 100755 --- a/test/etc/run-test-jar +++ b/test/etc/run-test-jar @@ -10,7 +10,7 @@ msg() { ANDROID_ROOT="/system" ARCHITECTURES_32="(arm|x86|mips|none)" -ARCHITECTURES_64="(arm64|x86_64|none)" +ARCHITECTURES_64="(arm64|x86_64|mips64|none)" ARCHITECTURES_PATTERN="${ARCHITECTURES_32}" BOOT_IMAGE="" COMPILE_FLAGS="" @@ -38,7 +38,7 @@ RELOCATE="y" SECONDARY_DEX="" TIME_OUT="y" # Value in minutes. -TIME_OUT_VALUE=5 +TIME_OUT_VALUE=10 USE_GDB="n" USE_JVM="n" VERIFY="y" diff --git a/test/run-test b/test/run-test index d2b1ec9b05..2802b75be7 100755 --- a/test/run-test +++ b/test/run-test @@ -298,7 +298,7 @@ fi # Try to map the suffix64 flag and what we find in ${ANDROID_PRODUCT_OUT}/data/art-test to an architecture name. function guess_arch_name() { grep32bit=`ls ${ANDROID_PRODUCT_OUT}/data/art-test | grep -E '^(arm|x86|mips)$'` - grep64bit=`ls ${ANDROID_PRODUCT_OUT}/data/art-test | grep -E '^(arm64|x86_64)$'` + grep64bit=`ls ${ANDROID_PRODUCT_OUT}/data/art-test | grep -E '^(arm64|x86_64|mips64)$'` if [ "x${suffix64}" = "x64" ]; then target_arch_name=${grep64bit} else |