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 * @test 26 * @library /lib/testlibrary 27 * @modules jdk.jartool/sun.tools.jar 28 * jdk.jlink/jdk.tools.jmod 29 * jdk.compiler 30 * @build BasicTest CompilerUtils jdk.testlibrary.* 31 * @run testng BasicTest 32 * @summary Basic test of starting an application as a module 33 */ 34 35 import java.io.File; 36 import java.nio.file.Files; 37 import java.nio.file.Path; 38 import java.nio.file.Paths; 39 40 import jdk.testlibrary.ProcessTools; 41 42 import org.testng.annotations.BeforeTest; 43 import org.testng.annotations.Test; 44 import static org.testng.Assert.*; 45 46 47 @Test 48 public class BasicTest { 49 50 private static final Path USER_DIR = Paths.get(System.getProperty("user.dir")); 51 52 private static final String TEST_SRC = System.getProperty("test.src"); 53 54 private static final Path SRC_DIR = Paths.get(TEST_SRC, "src"); 55 private static final Path MODS_DIR = Paths.get("mods"); 56 57 // the module name of the test module 58 private static final String TEST_MODULE = "test"; 59 60 // the module main class 61 private static final String MAIN_CLASS = "jdk.test.Main"; 62 63 64 @BeforeTest 65 public void compileTestModule() throws Exception { 66 67 // javac -d mods/$TESTMODULE src/$TESTMODULE/** 68 boolean compiled 115 exitValue = exec("-p", subdir, "-m", mid); 116 assertTrue(exitValue == 0); 117 } 118 119 120 /** 121 * The initial module is loaded from a modular JAR file 122 */ 123 public void testRunWithModularJar() throws Exception { 124 Path dir = Files.createTempDirectory(USER_DIR, "mlib"); 125 Path jar = dir.resolve("m.jar"); 126 127 // jar --create ... 128 String classes = MODS_DIR.resolve(TEST_MODULE).toString(); 129 String[] args = { 130 "--create", 131 "--file=" + jar, 132 "--main-class=" + MAIN_CLASS, 133 "-C", classes, "." 134 }; 135 boolean success 136 = new sun.tools.jar.Main(System.out, System.out, "jar") 137 .run(args); 138 assertTrue(success); 139 140 // java --module-path mlib -module $TESTMODULE 141 int exitValue = exec("--module-path", dir.toString(), 142 "--module", TEST_MODULE); 143 assertTrue(exitValue == 0); 144 145 // java --module-path mlib/m.jar -module $TESTMODULE 146 exitValue = exec("--module-path", jar.toString(), 147 "--module", TEST_MODULE); 148 assertTrue(exitValue == 0); 149 } 150 151 152 /** 153 * Attempt to run with the initial module packaged as a JMOD file. 154 */ 155 public void testTryRunWithJMod() throws Exception { 156 Path dir = Files.createTempDirectory(USER_DIR, "mlib"); 157 158 // jmod create ... 159 String cp = MODS_DIR.resolve(TEST_MODULE).toString(); 160 String jmod = dir.resolve("m.jmod").toString(); 161 String[] args = { 162 "create", 163 "--class-path", cp, 164 "--main-class", MAIN_CLASS, 165 jmod 166 }; 167 jdk.tools.jmod.JmodTask task = new jdk.tools.jmod.JmodTask(); 168 assertEquals(task.run(args), 0); 169 170 // java --module-path mods --module $TESTMODULE 171 int exitValue = exec("--module-path", dir.toString(), 172 "--module", TEST_MODULE); 173 assertTrue(exitValue != 0); 174 } 175 176 177 /** 178 * Run the test with a non-existent file on the application module path. 179 * It should be silently ignored. 180 */ 181 public void testRunWithNonExistentEntry() throws Exception { 182 String mp = "DoesNotExist" + File.pathSeparator + MODS_DIR.toString(); 183 String mid = TEST_MODULE + "/" + MAIN_CLASS; 184 185 // java --module-path mods --module $TESTMODULE/$MAINCLASS 186 int exitValue = exec("--module-path", mp, "--module", mid); 187 assertTrue(exitValue == 0); 188 } 212 int exitValue = exec("--module-path", modulepath, "-m", mid); 213 assertTrue(exitValue != 0); 214 } 215 216 217 /** 218 * Attempt to run with -m specifying a modular JAR that does not have 219 * a MainClass attribute 220 */ 221 public void testTryRunWithMissingMainClass() throws Exception { 222 Path dir = Files.createTempDirectory(USER_DIR, "mlib"); 223 224 // jar --create ... 225 String classes = MODS_DIR.resolve(TEST_MODULE).toString(); 226 String jar = dir.resolve("m.jar").toString(); 227 String[] args = { 228 "--create", 229 "--file=" + jar, 230 "-C", classes, "." 231 }; 232 boolean success 233 = new sun.tools.jar.Main(System.out, System.out, "jar") 234 .run(args); 235 assertTrue(success); 236 237 // java --module-path mods -m $TESTMODULE 238 int exitValue = exec("--module-path", dir.toString(), "-m", TEST_MODULE); 239 assertTrue(exitValue != 0); 240 } 241 242 243 /** 244 * Attempt to run with -m specifying a main class that is a different 245 * module to that specified to -m 246 */ 247 public void testTryRunWithMainClassInWrongModule() throws Exception { 248 String modulepath = MODS_DIR.toString(); 249 String mid = "java.base/" + MAIN_CLASS; 250 251 // java --module-path mods --module $TESTMODULE/$MAINCLASS 252 int exitValue = exec("--module-path", modulepath, "--module", mid); 253 assertTrue(exitValue != 0); 254 } 255 | 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 * @test 26 * @library /lib/testlibrary 27 * @modules jdk.compiler 28 * jdk.jartool 29 * jdk.jlink 30 * @build BasicTest CompilerUtils jdk.testlibrary.* 31 * @run testng BasicTest 32 * @summary Basic test of starting an application as a module 33 */ 34 35 import java.io.File; 36 import java.nio.file.Files; 37 import java.nio.file.Path; 38 import java.nio.file.Paths; 39 import java.util.spi.ToolProvider; 40 41 import jdk.testlibrary.ProcessTools; 42 43 import org.testng.annotations.BeforeTest; 44 import org.testng.annotations.Test; 45 import static org.testng.Assert.*; 46 47 48 @Test 49 public class BasicTest { 50 private static final ToolProvider JAR_TOOL = ToolProvider.findFirst("jar").get(); 51 private static final ToolProvider JMOD_TOOL = ToolProvider.findFirst("jmod").get(); 52 53 private static final Path USER_DIR = Paths.get(System.getProperty("user.dir")); 54 55 private static final String TEST_SRC = System.getProperty("test.src"); 56 57 private static final Path SRC_DIR = Paths.get(TEST_SRC, "src"); 58 private static final Path MODS_DIR = Paths.get("mods"); 59 60 // the module name of the test module 61 private static final String TEST_MODULE = "test"; 62 63 // the module main class 64 private static final String MAIN_CLASS = "jdk.test.Main"; 65 66 67 @BeforeTest 68 public void compileTestModule() throws Exception { 69 70 // javac -d mods/$TESTMODULE src/$TESTMODULE/** 71 boolean compiled 118 exitValue = exec("-p", subdir, "-m", mid); 119 assertTrue(exitValue == 0); 120 } 121 122 123 /** 124 * The initial module is loaded from a modular JAR file 125 */ 126 public void testRunWithModularJar() throws Exception { 127 Path dir = Files.createTempDirectory(USER_DIR, "mlib"); 128 Path jar = dir.resolve("m.jar"); 129 130 // jar --create ... 131 String classes = MODS_DIR.resolve(TEST_MODULE).toString(); 132 String[] args = { 133 "--create", 134 "--file=" + jar, 135 "--main-class=" + MAIN_CLASS, 136 "-C", classes, "." 137 }; 138 int rc = JAR_TOOL.run(System.out, System.out, args); 139 assertTrue(rc == 0); 140 141 // java --module-path mlib -module $TESTMODULE 142 int exitValue = exec("--module-path", dir.toString(), 143 "--module", TEST_MODULE); 144 assertTrue(exitValue == 0); 145 146 // java --module-path mlib/m.jar -module $TESTMODULE 147 exitValue = exec("--module-path", jar.toString(), 148 "--module", TEST_MODULE); 149 assertTrue(exitValue == 0); 150 } 151 152 153 /** 154 * Attempt to run with the initial module packaged as a JMOD file. 155 */ 156 public void testTryRunWithJMod() throws Exception { 157 Path dir = Files.createTempDirectory(USER_DIR, "mlib"); 158 159 // jmod create ... 160 String cp = MODS_DIR.resolve(TEST_MODULE).toString(); 161 String jmod = dir.resolve("m.jmod").toString(); 162 String[] args = { 163 "create", 164 "--class-path", cp, 165 "--main-class", MAIN_CLASS, 166 jmod 167 }; 168 169 assertEquals(JMOD_TOOL.run(System.out, System.out, args), 0); 170 171 // java --module-path mods --module $TESTMODULE 172 int exitValue = exec("--module-path", dir.toString(), 173 "--module", TEST_MODULE); 174 assertTrue(exitValue != 0); 175 } 176 177 178 /** 179 * Run the test with a non-existent file on the application module path. 180 * It should be silently ignored. 181 */ 182 public void testRunWithNonExistentEntry() throws Exception { 183 String mp = "DoesNotExist" + File.pathSeparator + MODS_DIR.toString(); 184 String mid = TEST_MODULE + "/" + MAIN_CLASS; 185 186 // java --module-path mods --module $TESTMODULE/$MAINCLASS 187 int exitValue = exec("--module-path", mp, "--module", mid); 188 assertTrue(exitValue == 0); 189 } 213 int exitValue = exec("--module-path", modulepath, "-m", mid); 214 assertTrue(exitValue != 0); 215 } 216 217 218 /** 219 * Attempt to run with -m specifying a modular JAR that does not have 220 * a MainClass attribute 221 */ 222 public void testTryRunWithMissingMainClass() throws Exception { 223 Path dir = Files.createTempDirectory(USER_DIR, "mlib"); 224 225 // jar --create ... 226 String classes = MODS_DIR.resolve(TEST_MODULE).toString(); 227 String jar = dir.resolve("m.jar").toString(); 228 String[] args = { 229 "--create", 230 "--file=" + jar, 231 "-C", classes, "." 232 }; 233 int rc = JAR_TOOL.run(System.out, System.out, args); 234 assertTrue(rc == 0); 235 236 // java --module-path mods -m $TESTMODULE 237 int exitValue = exec("--module-path", dir.toString(), "-m", TEST_MODULE); 238 assertTrue(exitValue != 0); 239 } 240 241 242 /** 243 * Attempt to run with -m specifying a main class that is a different 244 * module to that specified to -m 245 */ 246 public void testTryRunWithMainClassInWrongModule() throws Exception { 247 String modulepath = MODS_DIR.toString(); 248 String mid = "java.base/" + MAIN_CLASS; 249 250 // java --module-path mods --module $TESTMODULE/$MAINCLASS 251 int exitValue = exec("--module-path", modulepath, "--module", mid); 252 assertTrue(exitValue != 0); 253 } 254 |