hotspot/test/gc/g1/TestStringDeduplicationTools.java
author sangheki
Thu, 10 Aug 2017 18:09:19 -0700
changeset 46795 623a5e42deb6
parent 42307 cefc81dc1d52
permissions -rw-r--r--
8173335: Improve logging for j.l.ref.reference processing Summary: Add logs for each phases of references and stats for each worker threads Reviewed-by: tschatzl, shade
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     1
/*
40631
ed82623d7831 8157957: ClassNotFoundException: jdk.test.lib.JDKToolFinder
ctornqvi
parents: 35061
diff changeset
     2
 * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     4
 *
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     7
 * published by the Free Software Foundation.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     8
 *
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    13
 * accompanied this code).
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    14
 *
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    18
 *
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    21
 * questions.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    22
 */
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    23
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    24
/*
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    25
 * Common code for string deduplication tests
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    26
 */
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    27
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    28
import java.lang.management.*;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    29
import java.lang.reflect.*;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    30
import java.security.*;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    31
import java.util.*;
40631
ed82623d7831 8157957: ClassNotFoundException: jdk.test.lib.JDKToolFinder
ctornqvi
parents: 35061
diff changeset
    32
import jdk.test.lib.process.ProcessTools;
ed82623d7831 8157957: ClassNotFoundException: jdk.test.lib.JDKToolFinder
ctornqvi
parents: 35061
diff changeset
    33
import jdk.test.lib.process.OutputAnalyzer;
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    34
import sun.misc.*;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    35
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    36
class TestStringDeduplicationTools {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    37
    private static final String YoungGC = "YoungGC";
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    38
    private static final String FullGC  = "FullGC";
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    39
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    40
    private static final int Xmn = 50;  // MB
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    41
    private static final int Xms = 100; // MB
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    42
    private static final int Xmx = 100; // MB
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    43
    private static final int MB = 1024 * 1024;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    44
    private static final int StringLength = 50;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    45
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    46
    private static Field valueField;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    47
    private static Unsafe unsafe;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    48
    private static byte[] dummy;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    49
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    50
    static {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    51
        try {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    52
            Field field = Unsafe.class.getDeclaredField("theUnsafe");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    53
            field.setAccessible(true);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    54
            unsafe = (Unsafe)field.get(null);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    55
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    56
            valueField = String.class.getDeclaredField("value");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    57
            valueField.setAccessible(true);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    58
        } catch (Exception e) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    59
            throw new RuntimeException(e);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    60
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    61
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    62
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    63
    private static Object getValue(String string) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    64
        try {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    65
            return valueField.get(string);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    66
        } catch (Exception e) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    67
            throw new RuntimeException(e);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    68
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    69
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    70
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    71
    private static void doFullGc(int numberOfTimes) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    72
        for (int i = 0; i < numberOfTimes; i++) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    73
            System.out.println("Begin: Full GC " + (i + 1) + "/" + numberOfTimes);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    74
            System.gc();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    75
            System.out.println("End: Full GC " + (i + 1) + "/" + numberOfTimes);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    76
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    77
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    78
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    79
    private static void doYoungGc(int numberOfTimes) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    80
        // Provoke at least numberOfTimes young GCs
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    81
        final int objectSize = 128;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    82
        final int maxObjectInYoung = (Xmn * MB) / objectSize;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    83
        for (int i = 0; i < numberOfTimes; i++) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    84
            System.out.println("Begin: Young GC " + (i + 1) + "/" + numberOfTimes);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    85
            for (int j = 0; j < maxObjectInYoung + 1; j++) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    86
                dummy = new byte[objectSize];
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    87
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    88
            System.out.println("End: Young GC " + (i + 1) + "/" + numberOfTimes);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    89
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    90
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    91
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    92
    private static void forceDeduplication(int ageThreshold, String gcType) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    93
        // Force deduplication to happen by either causing a FullGC or a YoungGC.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    94
        // We do several collections to also provoke a situation where the the
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    95
        // deduplication thread needs to yield while processing the queue. This
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    96
        // also tests that the references in the deduplication queue are adjusted
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    97
        // accordingly.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    98
        if (gcType.equals(FullGC)) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
    99
            doFullGc(3);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   100
        } else {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   101
            doYoungGc(ageThreshold + 3);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   102
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   103
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   104
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   105
    private static String generateString(int id) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   106
        StringBuilder builder = new StringBuilder(StringLength);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   107
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   108
        builder.append("DeduplicationTestString:" + id + ":");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   109
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   110
        while (builder.length() < StringLength) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   111
            builder.append('X');
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   112
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   113
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   114
        return builder.toString();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   115
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   116
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   117
    private static ArrayList<String> createStrings(int total, int unique) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   118
        System.out.println("Creating strings: total=" + total + ", unique=" + unique);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   119
        if (total % unique != 0) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   120
            throw new RuntimeException("Total must be divisible by unique");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   121
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   122
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   123
        ArrayList<String> list = new ArrayList<String>(total);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   124
        for (int j = 0; j < total / unique; j++) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   125
            for (int i = 0; i < unique; i++) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   126
                list.add(generateString(i));
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   127
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   128
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   129
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   130
        return list;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   131
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   132
26328
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   133
    /**
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   134
     * Verifies that the given list contains expected number of unique strings.
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   135
     * It's possible that deduplication hasn't completed yet, so the method
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   136
     * will perform several attempts to check with a little pause between.
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   137
     * The method throws RuntimeException to signal that verification failed.
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   138
     *
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   139
     * @param list strings to check
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   140
     * @param uniqueExpected expected number of unique strings
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   141
     * @throws RuntimeException if check fails
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   142
     */
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   143
    private static void verifyStrings(ArrayList<String> list, int uniqueExpected) {
26328
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   144
        boolean passed = false;
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   145
        for (int attempts = 0; attempts < 10; attempts++) {
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   146
            // Check number of deduplicated strings
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   147
            ArrayList<Object> unique = new ArrayList<Object>(uniqueExpected);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   148
            for (String string: list) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   149
                Object value = getValue(string);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   150
                boolean uniqueValue = true;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   151
                for (Object obj: unique) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   152
                    if (obj == value) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   153
                        uniqueValue = false;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   154
                        break;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   155
                    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   156
                }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   157
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   158
                if (uniqueValue) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   159
                    unique.add(value);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   160
                }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   161
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   162
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   163
            System.out.println("Verifying strings: total=" + list.size() +
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   164
                               ", uniqueFound=" + unique.size() +
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   165
                               ", uniqueExpected=" + uniqueExpected);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   166
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   167
            if (unique.size() == uniqueExpected) {
26328
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   168
                System.out.println("Deduplication completed (as fast as " + attempts + " iterations)");
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   169
                passed = true;
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   170
                break;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   171
            } else {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   172
                System.out.println("Deduplication not completed, waiting...");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   173
                // Give the deduplication thread time to complete
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   174
                try {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   175
                    Thread.sleep(1000);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   176
                } catch (Exception e) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   177
                    throw new RuntimeException(e);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   178
                }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   179
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   180
        }
26328
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   181
        if (!passed) {
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   182
            throw new RuntimeException("String verification failed");
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   183
        }
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   184
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   185
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   186
    private static OutputAnalyzer runTest(String... extraArgs) throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   187
        String[] defaultArgs = new String[] {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   188
            "-Xmn" + Xmn + "m",
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   189
            "-Xms" + Xms + "m",
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   190
            "-Xmx" + Xmx + "m",
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   191
            "-XX:+UseG1GC",
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   192
            "-XX:+UnlockDiagnosticVMOptions",
42307
cefc81dc1d52 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40631
diff changeset
   193
            "--add-opens=java.base/java.lang=ALL-UNNAMED",
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   194
            "-XX:+VerifyAfterGC" // Always verify after GC
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   195
        };
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   196
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   197
        ArrayList<String> args = new ArrayList<String>();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   198
        args.addAll(Arrays.asList(defaultArgs));
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   199
        args.addAll(Arrays.asList(extraArgs));
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   200
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   201
        ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(args.toArray(new String[args.size()]));
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   202
        OutputAnalyzer output = new OutputAnalyzer(pb.start());
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   203
        System.err.println(output.getStderr());
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   204
        System.out.println(output.getStdout());
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   205
        return output;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   206
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   207
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   208
    private static class DeduplicationTest {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   209
        public static void main(String[] args) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   210
            System.out.println("Begin: DeduplicationTest");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   211
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   212
            final int numberOfStrings = Integer.parseUnsignedInt(args[0]);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   213
            final int numberOfUniqueStrings = Integer.parseUnsignedInt(args[1]);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   214
            final int ageThreshold = Integer.parseUnsignedInt(args[2]);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   215
            final String gcType = args[3];
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   216
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   217
            ArrayList<String> list = createStrings(numberOfStrings, numberOfUniqueStrings);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   218
            forceDeduplication(ageThreshold, gcType);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   219
            verifyStrings(list, numberOfUniqueStrings);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   220
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   221
            System.out.println("End: DeduplicationTest");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   222
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   223
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   224
        public static OutputAnalyzer run(int numberOfStrings, int ageThreshold, String gcType, String... extraArgs) throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   225
            String[] defaultArgs = new String[] {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   226
                "-XX:+UseStringDeduplication",
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   227
                "-XX:StringDeduplicationAgeThreshold=" + ageThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   228
                DeduplicationTest.class.getName(),
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   229
                "" + numberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   230
                "" + numberOfStrings / 2,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   231
                "" + ageThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   232
                gcType
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   233
            };
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   234
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   235
            ArrayList<String> args = new ArrayList<String>();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   236
            args.addAll(Arrays.asList(extraArgs));
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   237
            args.addAll(Arrays.asList(defaultArgs));
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   238
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   239
            return runTest(args.toArray(new String[args.size()]));
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   240
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   241
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   242
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   243
    private static class InternedTest {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   244
        public static void main(String[] args) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   245
            // This test verifies that interned strings are always
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   246
            // deduplicated when being interned, and never after
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   247
            // being interned.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   248
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   249
            System.out.println("Begin: InternedTest");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   250
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   251
            final int ageThreshold = Integer.parseUnsignedInt(args[0]);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   252
            final String baseString = "DeduplicationTestString:" + InternedTest.class.getName();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   253
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   254
            // Create duplicate of baseString
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   255
            StringBuilder sb1 = new StringBuilder(baseString);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   256
            String dupString1 = sb1.toString();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   257
            if (getValue(dupString1) == getValue(baseString)) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   258
                throw new RuntimeException("Values should not match");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   259
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   260
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   261
            // Force baseString to be inspected for deduplication
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   262
            // and be inserted into the deduplication hashtable.
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   263
            forceDeduplication(ageThreshold, FullGC);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   264
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   265
            // Wait for deduplication to occur
26328
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   266
            for (int attempts = 0; attempts < 10; attempts++) {
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   267
                if (getValue(dupString1) == getValue(baseString)) {
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   268
                    break;
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   269
                }
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   270
                System.out.println("Waiting...");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   271
                try {
26328
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   272
                    Thread.sleep(1000);
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   273
                } catch (Exception e) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   274
                    throw new RuntimeException(e);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   275
                }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   276
            }
26328
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   277
            if (getValue(dupString1) != getValue(baseString)) {
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   278
                throw new RuntimeException("Deduplication has not occurred");
8a3e0337bbb5 8050464: G1 string deduplication tests hang/timeout and leave running processes consuming all resources
dfazunen
parents: 24842
diff changeset
   279
            }
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   280
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   281
            // Create a new duplicate of baseString
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   282
            StringBuilder sb2 = new StringBuilder(baseString);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   283
            String dupString2 = sb2.toString();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   284
            if (getValue(dupString2) == getValue(baseString)) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   285
                throw new RuntimeException("Values should not match");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   286
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   287
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   288
            // Intern the new duplicate
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   289
            Object beforeInternedValue = getValue(dupString2);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   290
            String internedString = dupString2.intern();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   291
            if (internedString != dupString2) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   292
                throw new RuntimeException("String should match");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   293
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   294
            if (getValue(internedString) != getValue(baseString)) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   295
                throw new RuntimeException("Values should match");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   296
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   297
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   298
            // Check original value of interned string, to make sure
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   299
            // deduplication happened on the interned string and not
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   300
            // on the base string
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   301
            if (beforeInternedValue == getValue(baseString)) {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   302
                throw new RuntimeException("Values should not match");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   303
            }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   304
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   305
            System.out.println("End: InternedTest");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   306
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   307
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   308
        public static OutputAnalyzer run() throws Exception {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   309
            return runTest("-Xlog:gc=debug,gc+stringdedup=trace",
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   310
                           "-XX:+UseStringDeduplication",
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   311
                           "-XX:StringDeduplicationAgeThreshold=" + DefaultAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   312
                           InternedTest.class.getName(),
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   313
                           "" + DefaultAgeThreshold);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   314
        }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   315
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   316
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   317
    /*
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   318
     * Tests
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   319
     */
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   320
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   321
    private static final int LargeNumberOfStrings = 10000;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   322
    private static final int SmallNumberOfStrings = 10;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   323
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   324
    private static final int MaxAgeThreshold      = 15;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   325
    private static final int DefaultAgeThreshold  = 3;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   326
    private static final int MinAgeThreshold      = 1;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   327
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   328
    private static final int TooLowAgeThreshold   = MinAgeThreshold - 1;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   329
    private static final int TooHighAgeThreshold  = MaxAgeThreshold + 1;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   330
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   331
    public static void testYoungGC() throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   332
        // Do young GC to age strings to provoke deduplication
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   333
        OutputAnalyzer output = DeduplicationTest.run(LargeNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   334
                                                      DefaultAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   335
                                                      YoungGC,
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   336
                                                      "-Xlog:gc,gc+stringdedup=trace");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   337
        output.shouldNotContain("Full GC");
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   338
        output.shouldContain("Pause Young (G1 Evacuation Pause)");
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   339
        output.shouldContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   340
        output.shouldContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   341
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   342
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   343
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   344
    public static void testFullGC() throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   345
        // Do full GC to age strings to provoke deduplication
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   346
        OutputAnalyzer output = DeduplicationTest.run(LargeNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   347
                                                      DefaultAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   348
                                                      FullGC,
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   349
                                                      "-Xlog:gc,gc+stringdedup=trace");
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   350
        output.shouldNotContain("Pause Young (G1 Evacuation Pause)");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   351
        output.shouldContain("Full GC");
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   352
        output.shouldContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   353
        output.shouldContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   354
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   355
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   356
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   357
    public static void testTableResize() throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   358
        // Test with StringDeduplicationResizeALot
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   359
        OutputAnalyzer output = DeduplicationTest.run(LargeNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   360
                                                      DefaultAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   361
                                                      YoungGC,
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   362
                                                      "-Xlog:gc,gc+stringdedup=trace",
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   363
                                                      "-XX:+StringDeduplicationResizeALot");
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   364
        output.shouldContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   365
        output.shouldContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   366
        output.shouldNotContain("Resize Count: 0");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   367
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   368
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   369
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   370
    public static void testTableRehash() throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   371
        // Test with StringDeduplicationRehashALot
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   372
        OutputAnalyzer output = DeduplicationTest.run(LargeNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   373
                                                      DefaultAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   374
                                                      YoungGC,
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   375
                                                      "-Xlog:gc,gc+stringdedup=trace",
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   376
                                                      "-XX:+StringDeduplicationRehashALot");
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   377
        output.shouldContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   378
        output.shouldContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   379
        output.shouldNotContain("Rehash Count: 0");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   380
        output.shouldNotContain("Hash Seed: 0x0");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   381
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   382
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   383
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   384
    public static void testAgeThreshold() throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   385
        OutputAnalyzer output;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   386
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   387
        // Test with max age theshold
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   388
        output = DeduplicationTest.run(SmallNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   389
                                       MaxAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   390
                                       YoungGC,
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   391
                                       "-Xlog:gc,gc+stringdedup=trace");
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   392
        output.shouldContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   393
        output.shouldContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   394
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   395
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   396
        // Test with min age theshold
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   397
        output = DeduplicationTest.run(SmallNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   398
                                       MinAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   399
                                       YoungGC,
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   400
                                       "-Xlog:gc,gc+stringdedup=trace");
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   401
        output.shouldContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   402
        output.shouldContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   403
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   404
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   405
        // Test with too low age threshold
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   406
        output = DeduplicationTest.run(SmallNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   407
                                       TooLowAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   408
                                       YoungGC);
31371
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 30604
diff changeset
   409
        output.shouldContain("outside the allowed range");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   410
        output.shouldHaveExitValue(1);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   411
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   412
        // Test with too high age threshold
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   413
        output = DeduplicationTest.run(SmallNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   414
                                       TooHighAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   415
                                       YoungGC);
31371
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 30604
diff changeset
   416
        output.shouldContain("outside the allowed range");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   417
        output.shouldHaveExitValue(1);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   418
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   419
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   420
    public static void testPrintOptions() throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   421
        OutputAnalyzer output;
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   422
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   423
        // Test without -Xlog:gc
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   424
        output = DeduplicationTest.run(SmallNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   425
                                       DefaultAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   426
                                       YoungGC);
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   427
        output.shouldNotContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   428
        output.shouldNotContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   429
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   430
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   431
        // Test with -Xlog:gc+stringdedup
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   432
        output = DeduplicationTest.run(SmallNumberOfStrings,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   433
                                       DefaultAgeThreshold,
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   434
                                       YoungGC,
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   435
                                       "-Xlog:gc+stringdedup");
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 31371
diff changeset
   436
        output.shouldContain("Concurrent String Deduplication");
23472
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   437
        output.shouldNotContain("Deduplicated:");
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   438
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   439
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   440
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   441
    public static void testInterned() throws Exception {
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   442
        // Test that interned strings are deduplicated before being interned
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   443
        OutputAnalyzer output = InternedTest.run();
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   444
        output.shouldHaveExitValue(0);
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   445
    }
35e93890ed88 8029075: String deduplication in G1
pliden
parents:
diff changeset
   446
}