From 2fecfdfb5038ff24a792ff97f06aa8570102faa4 Mon Sep 17 00:00:00 2001 From: Jonathan Gibbons Date: Thu, 18 Sep 2008 13:47:43 -0700 Subject: [PATCH] 6728697: tools/javac/versionOpt.sh fails on OpenJDK builds Reviewed-by: darcy --- langtools/test/Makefile | 1 - langtools/test/bootclasspath-exclude.jtx | 7 -- langtools/test/tools/javac/VersionOpt.java | 104 +++++++++++++++++++++ langtools/test/tools/javac/versionOpt.sh | 87 ----------------- 4 files changed, 104 insertions(+), 95 deletions(-) delete mode 100644 langtools/test/bootclasspath-exclude.jtx create mode 100644 langtools/test/tools/javac/VersionOpt.java delete mode 100644 langtools/test/tools/javac/versionOpt.sh diff --git a/langtools/test/Makefile b/langtools/test/Makefile index 4f5c3b21604..d09f2f4debc 100644 --- a/langtools/test/Makefile +++ b/langtools/test/Makefile @@ -105,7 +105,6 @@ jtreg-tests: FRC -w:$(TEST_OUTPUT_DIR)/JTwork \ -jdk:$(TESTJAVA) \ -Xbootclasspath/p:$(TESTBOOTCLASSPATH) \ - -exclude:bootclasspath-exclude.jtx \ $(JAVA_TOOL_OPTIONS:%=-vmoption:%) \ $(JAVA_ARGS:%=-vmoption:%) \ $(TESTDIRS) diff --git a/langtools/test/bootclasspath-exclude.jtx b/langtools/test/bootclasspath-exclude.jtx deleted file mode 100644 index 7993d37b64b..00000000000 --- a/langtools/test/bootclasspath-exclude.jtx +++ /dev/null @@ -1,7 +0,0 @@ -# When you run the tests using a recent build of JDK and -Xbootclasspath/p:JAR -# some tests may fail. Specifically, javac has a test which verifies the content -# of the version string by comparing it against a value that is derived from -# the JRE version string. This file can be given to jtreg to exclude such tests. -# It should *NOT* be used in full SQE runs. - -tools/javac/versionOpt.sh diff --git a/langtools/test/tools/javac/VersionOpt.java b/langtools/test/tools/javac/VersionOpt.java new file mode 100644 index 00000000000..43b62cee2d8 --- /dev/null +++ b/langtools/test/tools/javac/VersionOpt.java @@ -0,0 +1,104 @@ + +/* + * Copyright 2005-2008 Sun Microsystems, Inc. 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 + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6728697 + * @summary tools/javac/versionOpt.sh fails on OpenJDK builds + * Test checks the version strings displayed by javac, using + * strings that come out of the Java runtime. + */ + +import java.io.File; +import java.io.PrintWriter; +import java.io.StringWriter; +import java.net.URL; + +public class VersionOpt { + public static void main(String... args) throws Exception { + new VersionOpt().run(); + } + + void run() throws Exception { + // Test functions by comparing the version string from javac against + // a "golden" version generated automatically from the underlying JVM. + // As such, it is only effective in testing the "standard" compiler, + // and not any development version being tested via -Xbootclasspath. + // Check the version of the compiler being used, and let the test pass + // automatically if is is a development version. + Class javacClass = com.sun.tools.javac.Main.class; + URL javacURL = getClass().getClassLoader().getResource(javacClass.getName().replace(".", "/") + ".class"); + if (!javacURL.getProtocol().equals("jar") || !javacURL.getFile().contains("!")) { + System.err.println("javac not found in tools.jar: " + javacURL); + System.err.println("rest of test skipped"); + return; + } + String javacHome = javacURL.getFile().substring(0, javacURL.getFile().indexOf("!")); + + File javaHome = new File(System.getProperty("java.home")); + if (javaHome.getName().equals("jre")) + javaHome = javaHome.getParentFile(); + File toolsJar = new File(new File(javaHome, "lib"), "tools.jar"); + + if (!javacHome.equals(toolsJar.toURI().toString())){ + System.err.println("javac not found in tools.jar: " + javacHome); + System.err.println("rest of test skipped"); + return; + } + + System.out.println("javac found in " + toolsJar); + + String javaVersion = System.getProperty("java.version"); + String javaRuntimeVersion = System.getProperty("java.runtime.version"); + System.out.println("java.version: " + javaVersion); + System.out.println("java.runtime.version: " + javaRuntimeVersion); + + StringWriter sw = new StringWriter(); + com.sun.tools.javac.Main.compile(new String[] { "-version" }, new PrintWriter(sw)); + String javacVersion = sw.toString().trim(); + + sw = new StringWriter(); + com.sun.tools.javac.Main.compile(new String[] { "-fullversion" }, new PrintWriter(sw)); + String javacFullVersion = sw.toString().trim(); + System.out.println("javac -version: " + javacVersion); + System.out.println("javac -fullversion: " + javacFullVersion); + + checkEqual("javac -version", javacVersion, "javac " + javaVersion); + checkEqual("javac -fullversion", javacFullVersion, "javac full version \"" + javaRuntimeVersion + "\""); + + if (errors > 0) + throw new Exception(errors + " errors found"); + } + + void checkEqual(String kind, String found, String expect) { + if (!found.equals(expect)) { + System.err.println("error: unexpected value for " + kind); + System.err.println("expect: >>" + expect + "<<"); + System.err.println(" found: >>" + found + "<<"); + errors++; + } + } + + int errors; +} diff --git a/langtools/test/tools/javac/versionOpt.sh b/langtools/test/tools/javac/versionOpt.sh deleted file mode 100644 index e390f80de4d..00000000000 --- a/langtools/test/tools/javac/versionOpt.sh +++ /dev/null @@ -1,87 +0,0 @@ -#!/bin/sh - -# -# Copyright 2005 Sun Microsystems, Inc. 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 -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, -# CA 95054 USA or visit www.sun.com if you need additional information or -# have any questions. -# - - -# @test -# @bug 4461214 6227587 -# @summary support-version and -fullversion -# @run shell versionOpt.sh - -if [ "${TESTJAVA}" = "" ] -then - echo "TESTJAVA not set. Test cannot execute. Failed." - exit 1 -fi -echo "TESTJAVA=${TESTJAVA}" - -# set platform-dependent variables -OS=`uname -s` -case "$OS" in - SunOS | Linux ) - NULL=/dev/null - PS=":" - FS="/" - ;; - Windows* ) - NULL=NUL - PS=";" - FS="\\" - ;; - * ) - echo "Unrecognized system!" - exit 1; - ;; -esac - -# create reference files based on java values -"${TESTJAVA}${FS}bin${FS}java" ${TESTVMOPTS} -version 2>&1 | \ - sed -e 's/java version "\([^"]*\)"/javac \1/' -e '2,$d' > version.ref.out - -"${TESTJAVA}${FS}bin${FS}java" ${TESTVMOPTS} -fullversion 2>&1 | \ - sed -e 's/java full version/javac full version/' -e '2,$d' > fullversion.ref.out - -# run javac -"${TESTJAVA}${FS}bin${FS}javac" ${TESTTOOLVMOPTS} -version 2> version.out -cat version.out -diff -c version.ref.out version.out -version_result=$? - -"${TESTJAVA}${FS}bin${FS}javac" ${TESTTOOLVMOPTS} -fullversion 2> fullversion.out -cat fullversion.out -diff -c fullversion.ref.out fullversion.out -fullversion_result=$? - -if [ $version_result -eq 0 -a $fullversion_result -eq 0 ] -then - echo "Passed" - exit 0 -else - echo "Failed" - exit 1 -fi - - - -