From e810681b908886f540d92c6d9faf910cbaeadbe3 Mon Sep 17 00:00:00 2001 From: Jesper Wilhelmsson Date: Thu, 17 Jan 2019 00:55:19 +0100 Subject: [PATCH 1/2] Added tag jdk-12+28 for changeset 659b004b6a1b --- .hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags b/.hgtags index 20a2534e7b3..ce49a0233f3 100644 --- a/.hgtags +++ b/.hgtags @@ -530,3 +530,4 @@ eef755718cb24813031a842bbfc716a6cea18e9a jdk-12+23 7496df94b3b79f3da53925d2d137317715f11d97 jdk-12+25 de9fd809bb475401aad188eab2264226788aad81 jdk-12+26 f15d443f97318e9b40e6f451e327ff69ed4ec361 jdk-12+27 +659b004b6a1bd8c31e766cbdf328d8f8473fd4d7 jdk-12+28 From be44ced10aa299f60e9227cc25a7541fd4203271 Mon Sep 17 00:00:00 2001 From: Mark Reinhold Date: Wed, 16 Jan 2019 16:27:21 -0800 Subject: [PATCH 2/2] 8216532: tools/launcher/Test7029048.java fails (Solaris) Reviewed-by: rriggs --- test/jdk/tools/launcher/Test7029048.java | 68 ++++++++++++------------ 1 file changed, 34 insertions(+), 34 deletions(-) diff --git a/test/jdk/tools/launcher/Test7029048.java b/test/jdk/tools/launcher/Test7029048.java index 13f7619857c..f87eb9e702a 100644 --- a/test/jdk/tools/launcher/Test7029048.java +++ b/test/jdk/tools/launcher/Test7029048.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,16 +24,12 @@ /* * @test * @bug 7029048 - * @summary Checks for LD_LIBRARY_PATH on *nixes + * @summary Ensure that the launcher defends against user settings of the + * LD_LIBRARY_PATH environment variable on Unixes * @compile -XDignore.symbol.file ExecutionEnvironment.java Test7029048.java * @run main Test7029048 */ -/* - * 7029048: test for LD_LIBRARY_PATH set to different paths which may or - * may not contain a libjvm.so, but we test to ensure that the launcher - * behaves correctly in all cases. - */ import java.io.File; import java.io.IOException; import java.nio.file.Files; @@ -67,7 +63,6 @@ public class Test7029048 extends TestHelper { private static final Map env = new HashMap<>(); - static String getValue(String name, List in) { for (String x : in) { String[] s = x.split("="); @@ -99,37 +94,34 @@ public class Test7029048 extends TestHelper { * print a "null" string. */ if (envValue == null) { - System.out.println(tr); throw new RuntimeException("NPE, likely a program crash ??"); } - String values[] = envValue.split(File.pathSeparator); - if (values.length == nLLPComponents) { - System.out.println(caseID + " :OK"); + int len = (envValue.equals("null") + ? 0 : envValue.split(File.pathSeparator).length); + if (len == nLLPComponents) { + System.out.println(caseID + ": OK"); passes++; } else { System.out.println("FAIL: test7029048, " + caseID); System.out.println(" expected " + nLLPComponents - + " but got " + values.length); + + " but got " + len); System.out.println(envValue); - System.out.println(tr); errors++; } } /* - * A crucial piece, specifies what we should expect, given the conditions. - * That is for a given enum type, the value indicates how many absolute - * environment variables that can be expected. This value is used to base - * the actual expected values by adding the set environment variable usually - * it is 1, but it could be more if the test wishes to set more paths in - * the future. + * Describe the cases that we test. Each case sets the environment + * variable LD_LIBRARY_PATH to a different value. The value associated + * with a case is the number of path elements that we expect the launcher + * to add to that variable. */ - private static enum LLP_VAR { - LLP_SET_NON_EXISTENT_PATH(0), // env set, but the path does not exist - LLP_SET_EMPTY_PATH(0), // env set, with a path but no libjvm.so - LLP_SET_WITH_JVM(3); // env set, with a libjvm.so + private static enum TestCase { + NO_DIR(0), // Directory does not exist + NO_LIBJVM(0), // Directory exists, but no libjvm.so + LIBJVM(3); // Directory exists, with a libjvm.so private final int value; - LLP_VAR(int i) { + TestCase(int i) { this.value = i; } } @@ -139,16 +131,16 @@ public class Test7029048 extends TestHelper { */ static void test7029048() throws IOException { String desc = null; - for (LLP_VAR v : LLP_VAR.values()) { + for (TestCase v : TestCase.values()) { switch (v) { - case LLP_SET_WITH_JVM: + case LIBJVM: // copy the files into the directory structures copyFile(srcLibjvmSo, dstServerLibjvm); // does not matter if it is client or a server copyFile(srcLibjvmSo, dstClientLibjvm); desc = "LD_LIBRARY_PATH should be set"; break; - case LLP_SET_EMPTY_PATH: + case NO_LIBJVM: if (!dstClientDir.exists()) { Files.createDirectories(dstClientDir.toPath()); } else { @@ -161,13 +153,13 @@ public class Test7029048 extends TestHelper { Files.deleteIfExists(dstServerLibjvm.toPath()); } - desc = "LD_LIBRARY_PATH should not be set"; + desc = "LD_LIBRARY_PATH should not be set (no libjvm.so)"; break; - case LLP_SET_NON_EXISTENT_PATH: + case NO_DIR: if (dstLibDir.exists()) { recursiveDelete(dstLibDir); } - desc = "LD_LIBRARY_PATH should not be set"; + desc = "LD_LIBRARY_PATH should not be set (no directory)"; break; default: throw new RuntimeException("unknown case"); @@ -178,14 +170,18 @@ public class Test7029048 extends TestHelper { */ env.clear(); env.put(LD_LIBRARY_PATH, dstServerDir.getAbsolutePath()); - run(env, v.value + 1, "Case 1: " + desc); + run(env, + v.value + 1, // Add one to account for our setting + "Case 1: " + desc); /* * Case 2: repeat with client path */ env.clear(); env.put(LD_LIBRARY_PATH, dstClientDir.getAbsolutePath()); - run(env, v.value + 1, "Case 2: " + desc); + run(env, + v.value + 1, // Add one to account for our setting + "Case 2: " + desc); if (isSolaris) { /* @@ -194,7 +190,10 @@ public class Test7029048 extends TestHelper { */ env.clear(); env.put(LD_LIBRARY_PATH_64, dstServerDir.getAbsolutePath()); - run(env, v.value + 1, "Case 3: " + desc); + run(env, + v.value, // Do not add one, since we didn't set + // LD_LIBRARY_PATH here + "Case 3: " + desc); } } return; @@ -227,4 +226,5 @@ public class Test7029048 extends TestHelper { System.out.println("Test7029048: PASS " + passes); } } + }