test/hotspot/jtreg/runtime/appcds/cacheObject/CheckArchivedModuleApp.java
changeset 57567 b000362a89a0
parent 57566 ad84ae073248
child 57568 460ac76019f4
equal deleted inserted replaced
57566:ad84ae073248 57567:b000362a89a0
     1 /*
       
     2  * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved.
       
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
       
     4  *
       
     5  * This code is free software; you can redistribute it and/or modify it
       
     6  * under the terms of the GNU General Public License version 2 only, as
       
     7  * published by the Free Software Foundation.
       
     8  *
       
     9  * This code is distributed in the hope that it will be useful, but WITHOUT
       
    10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
       
    11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
       
    12  * version 2 for more details (a copy is included in the LICENSE file that
       
    13  * accompanied this code).
       
    14  *
       
    15  * You should have received a copy of the GNU General Public License version
       
    16  * 2 along with this work; if not, write to the Free Software Foundation,
       
    17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
       
    18  *
       
    19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
       
    20  * or visit www.oracle.com if you need additional information or have any
       
    21  * questions.
       
    22  *
       
    23  */
       
    24 
       
    25 import java.io.File;
       
    26 import java.lang.module.Configuration;
       
    27 import java.lang.module.ModuleDescriptor;
       
    28 import java.util.List;
       
    29 import java.util.Set;
       
    30 import sun.hotspot.WhiteBox;
       
    31 
       
    32 //
       
    33 // Test archived system module graph when open archive heap objects are mapped:
       
    34 //
       
    35 public class CheckArchivedModuleApp {
       
    36     static WhiteBox wb;
       
    37     public static void main(String args[]) throws Exception {
       
    38         wb = WhiteBox.getWhiteBox();
       
    39 
       
    40         if (!wb.areOpenArchiveHeapObjectsMapped()) {
       
    41             System.out.println("Archived open_archive_heap objects are not mapped.");
       
    42             System.out.println("This may happen during normal operation. Test Skipped.");
       
    43             return;
       
    44         }
       
    45 
       
    46         if (args.length != 2) {
       
    47            throw new RuntimeException(
       
    48                "FAILED. Incorrect argument length: " + args.length);
       
    49         }
       
    50 
       
    51         boolean expectArchivedDescriptors = "yes".equals(args[0]);
       
    52         boolean expectArchivedConfiguration = "yes".equals(args[1]);
       
    53         // -XX:+EnableJVMCI adds extra system modules, in which case the system
       
    54         // module objects are not archived.
       
    55         Boolean enableJVMCI = wb.getBooleanVMFlag("EnableJVMCI");
       
    56         if (enableJVMCI != null && enableJVMCI) {
       
    57             expectArchivedDescriptors = false;
       
    58             expectArchivedConfiguration = false;
       
    59         }
       
    60 
       
    61         checkModuleDescriptors(expectArchivedDescriptors);
       
    62         checkConfiguration(expectArchivedConfiguration);
       
    63         checkEmptyConfiguration(expectArchivedConfiguration);
       
    64     }
       
    65 
       
    66     private static void checkModuleDescriptors(boolean expectArchivedDescriptors) {
       
    67         Set<Module> modules = ModuleLayer.boot().modules();
       
    68         for (Module m : modules) {
       
    69             ModuleDescriptor md = m.getDescriptor();
       
    70             String name = md.name();
       
    71             if (expectArchivedDescriptors) {
       
    72                 if (wb.isShared(md)) {
       
    73                     System.out.println(name + " is archived. Expected.");
       
    74                 } else {
       
    75                     throw new RuntimeException(
       
    76                         "FAILED. " + name + " is not archived. Expect archived.");
       
    77                 }
       
    78             } else {
       
    79                 if (!wb.isShared(md)) {
       
    80                     System.out.println(name + " is not archived. Expected.");
       
    81                 } else {
       
    82                     throw new RuntimeException(
       
    83                         "FAILED. " + name + " is archived. Expect not archived.");
       
    84                 }
       
    85             }
       
    86         }
       
    87     }
       
    88 
       
    89     private static void checkEmptyConfiguration(boolean expectArchivedConfiguration) {
       
    90         // Configuration.EMPTY_CONFIGURATION uses the singletons,
       
    91         // ListN.EMPTY_LIST, SetN.EMPTY_SET and MapN.EMPTY_MAP in
       
    92         // ImmutableCollections for the 'parents', 'modules' and
       
    93         // 'graph' fields. The ImmutableCollections singletons
       
    94         // can be accessed via List.of(), Set.of() and Map.of() APIs.
       
    95         // Configuration public APIs also allow access to the
       
    96         // EMPTY_CONFIGURATION's 'parents' and 'modules'. When the
       
    97         // archived java heap data is enabled at runtime, make sure
       
    98         // the EMPTY_CONFIGURATION.parents and EMPTY_CONFIGURATION.modules
       
    99         // are the archived ImmutableCollections singletons.
       
   100         Configuration emptyCf = Configuration.empty();
       
   101         List emptyCfParents = emptyCf.parents();
       
   102         Set emptyCfModules = emptyCf.modules();
       
   103         if (expectArchivedConfiguration) {
       
   104             if (emptyCfParents == List.of() &&
       
   105                 wb.isShared(emptyCfParents)) {
       
   106                 System.out.println("Empty Configuration has expected parents.");
       
   107             } else {
       
   108                 throw new RuntimeException(
       
   109                     "FAILED. Unexpected parents for empty Configuration.");
       
   110             }
       
   111             if (emptyCfModules == Set.of() &&
       
   112                 wb.isShared(emptyCfModules)) {
       
   113                 System.out.println("Empty Configuration has expected module set.");
       
   114             } else {
       
   115                 throw new RuntimeException(
       
   116                     "FAILED. Unexpected module set for empty Configuration.");
       
   117             }
       
   118         }
       
   119     }
       
   120 
       
   121 
       
   122 
       
   123     private static void checkConfiguration(boolean expectArchivedConfiguration) {
       
   124         Configuration cf = ModuleLayer.boot().configuration();
       
   125 
       
   126         if (expectArchivedConfiguration) {
       
   127             if (wb.isShared(cf)) {
       
   128                 System.out.println("Boot layer configuration is archived. Expected.");
       
   129             } else {
       
   130                 throw new RuntimeException(
       
   131                     "FAILED. Boot layer configuration is not archived.");
       
   132             }
       
   133         } else {
       
   134             if (!wb.isShared(cf)) {
       
   135                 System.out.println("Boot layer configuration is not archived. Expected.");
       
   136             } else {
       
   137                 throw new RuntimeException(
       
   138                     "FAILED. Boot layer configuration is archived.");
       
   139             }
       
   140         }
       
   141     }
       
   142 }