summaryrefslogtreecommitdiffstats
path: root/test/096-array-copy-concurrent-gc
diff options
context:
space:
mode:
authorElliott Hughes <enh@google.com>2012-06-18 16:55:54 -0700
committerElliott Hughes <enh@google.com>2012-06-18 16:55:54 -0700
commite536c6485b370f9ecabc95988dd9c60e829ac093 (patch)
treed44ab266a0f4396f682e06bf247bd007290a7610 /test/096-array-copy-concurrent-gc
parentd9fd368311d26bbffc0fc9411c0d5082af27219d (diff)
downloadart-e536c6485b370f9ecabc95988dd9c60e829ac093.tar.gz
art-e536c6485b370f9ecabc95988dd9c60e829ac093.tar.bz2
art-e536c6485b370f9ecabc95988dd9c60e829ac093.zip
Add test 096, added to dalvik since we started on art.
Change-Id: I4306d10afe6ff893b8c5a03c82a99581813f0fbc
Diffstat (limited to 'test/096-array-copy-concurrent-gc')
-rw-r--r--test/096-array-copy-concurrent-gc/expected.txt3
-rw-r--r--test/096-array-copy-concurrent-gc/info.txt2
-rw-r--r--test/096-array-copy-concurrent-gc/src/Main.java86
3 files changed, 91 insertions, 0 deletions
diff --git a/test/096-array-copy-concurrent-gc/expected.txt b/test/096-array-copy-concurrent-gc/expected.txt
new file mode 100644
index 0000000000..23b9dab6b5
--- /dev/null
+++ b/test/096-array-copy-concurrent-gc/expected.txt
@@ -0,0 +1,3 @@
+Initializing...
+Starting the test
+Test OK
diff --git a/test/096-array-copy-concurrent-gc/info.txt b/test/096-array-copy-concurrent-gc/info.txt
new file mode 100644
index 0000000000..37dd8be9bd
--- /dev/null
+++ b/test/096-array-copy-concurrent-gc/info.txt
@@ -0,0 +1,2 @@
+This is a test to verify that System.arraycopy works nice together with
+the concurrent gc.
diff --git a/test/096-array-copy-concurrent-gc/src/Main.java b/test/096-array-copy-concurrent-gc/src/Main.java
new file mode 100644
index 0000000000..c8e538b5e3
--- /dev/null
+++ b/test/096-array-copy-concurrent-gc/src/Main.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright (C) 2011 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.
+ */
+
+/**
+ * Running concurrent gc and doing some System.arraycopy
+ * Several threads is created in order to increase the probability
+ * of thread switches at critical points. Without creating several
+ * threads the test case usually passed even when there were bugs.
+ * Size of array and amount of garbage created is based on experimental
+ * numbers and is a tradeoff between time that the test takes when
+ * it succeeds and the probability that the test discovers a problem.
+ */
+public class Main {
+ public static void main(String args[]) {
+ new ObjectCreatorThread(true).start();
+ new ObjectCreatorThread(false).start();
+ new ObjectCreatorThread(false).start();
+ }
+
+ static class ObjectCreatorThread extends Thread {
+ boolean mDoLog;
+ public ObjectCreatorThread(boolean doLog) {
+ mDoLog = doLog;
+ }
+
+ @Override
+ public void run() {
+ new Main().stressArray(mDoLog);
+ }
+ }
+
+ Object [] array = new Object[10000];
+
+ void stressArray(boolean doLog) {
+ // We want many references in the array
+ // We also want elements close to each other to have large
+ // diff in address so lets skip every 2:nd address so it is null
+ if (doLog) {
+ System.out.println("Initializing...");
+ }
+ for (int i = 0; i < array.length; i+=2) {
+ array[i] = new String("Creating some garbage" + i);
+ }
+
+ if (doLog) {
+ System.out.println("Starting the test");
+ }
+
+ for (int j = 0; j < array.length; j++) {
+ Object obj = array[array.length - 1];
+ System.arraycopy(array, 0, array, 1, array.length - 1);
+ array[0] = obj;
+ new String("Creating some garbage" + Math.random());
+ new String("Creating some garbage" + Math.random());
+ new String("Creating some garbage" + Math.random());
+ new String("Creating some garbage" + Math.random());
+ }
+
+ for (int j = 0; j < array.length; j++) {
+ Object obj = array[0];
+ System.arraycopy(array, 1, array, 0, array.length - 1);
+ array[array.length - 1] = obj;
+ new String("Creating some garbage" + Math.random());
+ new String("Creating some garbage" + Math.random());
+ new String("Creating some garbage" + Math.random());
+ new String("Creating some garbage" + Math.random());
+ }
+
+ if (doLog) {
+ System.out.println("Test OK");
+ }
+ }
+}