Path: blob/master/test/jdk/java/lang/module/ModuleFinderWithSecurityManager.java
41149 views
/*1* Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/**24* @test25* @run main/othervm -Djava.security.manager=allow ModuleFinderWithSecurityManager allow26* @run main/othervm -Djava.security.manager=allow ModuleFinderWithSecurityManager deny27* @summary Basic test for ModuleFinder.ofSystem() with security manager28*/2930import java.lang.module.ModuleFinder;31import java.lang.module.ModuleReference;32import java.nio.file.Path;33import java.nio.file.Paths;34import java.util.Set;3536public class ModuleFinderWithSecurityManager {37public static void main(String[] args) throws Exception {38boolean allow = args[0].equals("allow");3940// set security policy to allow access41if (allow) {42String testSrc = System.getProperty("test.src");43if (testSrc == null)44testSrc = ".";45Path policyFile = Paths.get(testSrc, "java.policy");46System.setProperty("java.security.policy", policyFile.toString());47}4849System.setSecurityManager(new SecurityManager());5051ModuleFinder finder = null;52try {53finder = ModuleFinder.ofSystem();54if (!allow) throw new RuntimeException("SecurityException expected");55} catch (SecurityException e) {56if (allow) throw new RuntimeException("SecurityException not expected");57}5859// no additional permissions should be required to locate modules60if (finder != null) {61ModuleReference base = finder.find("java.base").orElse(null);62if (base == null)63throw new RuntimeException("java.base not found");64Set<ModuleReference> allModules = finder.findAll();65if (!allModules.contains(base))66throw new RuntimeException("java.base not in all modules");67}68}69}707172