/* * Copyright (c) 2013, 2015, 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 * 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ /* * @test * @bug 8005091 8009686 8025633 8026567 * @summary Make sure that type annotations are displayed correctly * @author Bhavesh Patel * @library ../lib * @modules jdk.javadoc * @build JavadocTester * @run main TestTypeAnnotations */ public class TestTypeAnnotations extends JavadocTester { public static void main(String... args) throws Exception { TestTypeAnnotations tester = new TestTypeAnnotations(); tester.runTests(); } @Test void test() { javadoc("-d", "out", "-sourcepath", testSrc, "-private", "typeannos"); checkExit(Exit.OK); // Test for type annotations on Class Extends (ClassExtends.java). checkOutput("typeannos/MyClass.html", true, "extends <a href=\"../typeannos/ClassExtA.html\" title=\"annotation " + "in typeannos\">@ClassExtA</a> <a href=\"../typeannos/ParameterizedClass.html\" " + "title=\"class in typeannos\">ParameterizedClass</a><<a href=\"" + "../typeannos/ClassExtB.html\" title=\"annotation in typeannos\">" + "@ClassExtB</a> java.lang.String>", "implements <a href=\"../typeannos/ClassExtB.html\" title=\"" + "annotation in typeannos\">@ClassExtB</a> java.lang.CharSequence, " + "<a href=\"../typeannos/ClassExtA.html\" title=\"annotation in " + "typeannos\">@ClassExtA</a> <a href=\"../typeannos/ParameterizedInterface.html\" " + "title=\"interface in typeannos\">ParameterizedInterface</a><" + "<a href=\"../typeannos/ClassExtB.html\" title=\"annotation in " + "typeannos\">@ClassExtB</a> java.lang.String></pre>"); checkOutput("typeannos/MyInterface.html", true, "extends <a href=\"../typeannos/ClassExtA.html\" title=\"annotation " + "in typeannos\">@ClassExtA</a> <a href=\"../typeannos/" + "ParameterizedInterface.html\" title=\"interface in typeannos\">" + "ParameterizedInterface</a><<a href=\"../typeannos/ClassExtA.html\" " + "title=\"annotation in typeannos\">@ClassExtA</a> java.lang.String>, " + "<a href=\"../typeannos/ClassExtB.html\" title=\"annotation in " + "typeannos\">@ClassExtB</a> java.lang.CharSequence</pre>"); // Test for type annotations on Class Parameters (ClassParameters.java). checkOutput("typeannos/ExtendsBound.html", true, "class <span class=\"typeNameLabel\">ExtendsBound<K extends <a " + "href=\"../typeannos/ClassParamA.html\" title=\"annotation in " + "typeannos\">@ClassParamA</a> java.lang.String></span>"); checkOutput("typeannos/ExtendsGeneric.html", true, "<pre>class <span class=\"typeNameLabel\">ExtendsGeneric<K extends " + "<a href=\"../typeannos/ClassParamA.html\" title=\"annotation in " + "typeannos\">@ClassParamA</a> <a href=\"../typeannos/Unannotated.html\" " + "title=\"class in typeannos\">Unannotated</a><<a href=\"" + "../typeannos/ClassParamB.html\" title=\"annotation in typeannos\">" + "@ClassParamB</a> java.lang.String>></span>"); checkOutput("typeannos/TwoBounds.html", true, "<pre>class <span class=\"typeNameLabel\">TwoBounds<K extends <a href=\"" + "../typeannos/ClassParamA.html\" title=\"annotation in typeannos\">" + "@ClassParamA</a> java.lang.String,V extends <a href=\"../typeannos/" + "ClassParamB.html\" title=\"annotation in typeannos\">@ClassParamB" + "</a> java.lang.String></span>"); checkOutput("typeannos/Complex1.html", true, "class <span class=\"typeNameLabel\">Complex1<K extends <a href=\"../" + "typeannos/ClassParamA.html\" title=\"annotation in typeannos\">" + "@ClassParamA</a> java.lang.String & java.lang.Runnable></span>"); checkOutput("typeannos/Complex2.html", true, "class <span class=\"typeNameLabel\">Complex2<K extends java.lang." + "String & <a href=\"../typeannos/ClassParamB.html\" title=\"" + "annotation in typeannos\">@ClassParamB</a> java.lang.Runnable></span>"); checkOutput("typeannos/ComplexBoth.html", true, "class <span class=\"typeNameLabel\">ComplexBoth<K extends <a href=\"" + "../typeannos/ClassParamA.html\" title=\"annotation in typeannos\"" + ">@ClassParamA</a> java.lang.String & <a href=\"../typeannos/" + "ClassParamA.html\" title=\"annotation in typeannos\">@ClassParamA" + "</a> java.lang.Runnable></span>"); // Test for type annotations on fields (Fields.java). checkOutput("typeannos/DefaultScope.html", true, "<pre><a href=\"../typeannos/Parameterized.html\" title=\"class in " + "typeannos\">Parameterized</a><<a href=\"../typeannos/FldA.html\" " + "title=\"annotation in typeannos\">@FldA</a> java.lang.String,<a " + "href=\"../typeannos/FldB.html\" title=\"annotation in typeannos\">" + "@FldB</a> java.lang.String> bothTypeArgs</pre>", "<pre><a href=\"../typeannos/FldA.html\" title=\"annotation in " + "typeannos\">@FldA</a> java.lang.String <a href=\"../typeannos/" + "FldB.html\" title=\"annotation in typeannos\">@FldB</a> [] " + "array1Deep</pre>", "<pre>java.lang.String[] <a href=\"../typeannos/FldB.html\" " + "title=\"annotation in typeannos\">@FldB</a> [] array2SecondOld</pre>", "<pre><a href=\"../typeannos/FldD.html\" title=\"annotation in " + "typeannos\">@FldD</a> java.lang.String <a href=\"../typeannos/" + "FldC.html\" title=\"annotation in typeannos\">@FldC</a> <a href=\"" + "../typeannos/FldA.html\" title=\"annotation in typeannos\">@FldA" + "</a> [] <a href=\"../typeannos/FldC.html\" title=\"annotation in " + "typeannos\">@FldC</a> <a href=\"../typeannos/FldB.html\" title=\"" + "annotation in typeannos\">@FldB</a> [] array2Deep</pre>"); checkOutput("typeannos/ModifiedScoped.html", true, "<pre>public final <a href=\"../typeannos/Parameterized.html\" " + "title=\"class in typeannos\">Parameterized</a><<a href=\"../" + "typeannos/FldA.html\" title=\"annotation in typeannos\">@FldA</a> " + "<a href=\"../typeannos/Parameterized.html\" title=\"class in " + "typeannos\">Parameterized</a><<a href=\"../typeannos/FldA.html\" " + "title=\"annotation in typeannos\">@FldA</a> java.lang.String,<a " + "href=\"../typeannos/FldB.html\" title=\"annotation in typeannos\">" + "@FldB</a> java.lang.String>,<a href=\"../typeannos/FldB.html\" " + "title=\"annotation in typeannos\">@FldB</a> java.lang.String> " + "nestedParameterized</pre>", "<pre>public final <a href=\"../typeannos/FldA.html\" " + "title=\"annotation in typeannos\">@FldA</a> java.lang.String[][] " + "array2</pre>"); // Test for type annotations on method return types (MethodReturnType.java). checkOutput("typeannos/MtdDefaultScope.html", true, "<pre>public <T> <a href=\"../typeannos/MRtnA.html\" " + "title=\"annotation in typeannos\">@MRtnA</a> java.lang.String" + " method()</pre>", "<pre><a href=\"../typeannos/MRtnA.html\" title=\"annotation in " + "typeannos\">@MRtnA</a> java.lang.String <a href=\"../typeannos/" + "MRtnA.html\" title=\"annotation in typeannos\">@MRtnA</a> [] <a " + "href=\"../typeannos/MRtnB.html\" title=\"annotation in typeannos\">" + "@MRtnB</a> [] array2Deep()</pre>", "<pre><a href=\"../typeannos/MRtnA.html\" title=\"annotation in " + "typeannos\">@MRtnA</a> java.lang.String[][] array2()</pre>"); checkOutput("typeannos/MtdModifiedScoped.html", true, "<pre>public final <a href=\"../typeannos/MtdParameterized.html\" " + "title=\"class in typeannos\">MtdParameterized</a><<a href=\"../" + "typeannos/MRtnA.html\" title=\"annotation in typeannos\">@MRtnA</a> " + "<a href=\"../typeannos/MtdParameterized.html\" title=\"class in " + "typeannos\">MtdParameterized</a><<a href=\"../typeannos/MRtnA." + "html\" title=\"annotation in typeannos\">@MRtnA</a> java.lang." + "String,<a href=\"../typeannos/MRtnB.html\" title=\"annotation in " + "typeannos\">@MRtnB</a> java.lang.String>,<a href=\"../typeannos/" + "MRtnB.html\" title=\"annotation in typeannos\">@MRtnB</a> java." + "lang.String> nestedMtdParameterized()</pre>"); // Test for type annotations on method type parameters (MethodTypeParameters.java). checkOutput("typeannos/UnscopedUnmodified.html", true, "<pre><K extends <a href=\"../typeannos/MTyParamA.html\" title=\"" + "annotation in typeannos\">@MTyParamA</a> java.lang.String>" + " void methodExtends()</pre>", "<pre><K extends <a href=\"../typeannos/MTyParamA.html\" title=\"" + "annotation in typeannos\">@MTyParamA</a> <a href=\"../typeannos/" + "MtdTyParameterized.html\" title=\"class in typeannos\">" + "MtdTyParameterized</a><<a href=\"../typeannos/MTyParamB.html\" " + "title=\"annotation in typeannos\">@MTyParamB</a> java.lang.String" + ">> void nestedExtends()</pre>"); checkOutput("typeannos/PublicModifiedMethods.html", true, "<pre>public final <K extends <a href=\"../typeannos/" + "MTyParamA.html\" title=\"annotation in typeannos\">@MTyParamA</a> " + "java.lang.String> void methodExtends()</pre>", "<pre>public final <K extends <a href=\"../typeannos/" + "MTyParamA.html\" title=\"annotation in typeannos\">@MTyParamA</a> " + "java.lang.String,V extends <a href=\"../typeannos/MTyParamA.html\" " + "title=\"annotation in typeannos\">@MTyParamA</a> <a href=\"../" + "typeannos/MtdTyParameterized.html\" title=\"class in typeannos\">" + "MtdTyParameterized</a><<a href=\"../typeannos/MTyParamB.html\" " + "title=\"annotation in typeannos\">@MTyParamB</a> java.lang.String" + ">> void dual()</pre>"); // Test for type annotations on parameters (Parameters.java). checkOutput("typeannos/Parameters.html", true, "<pre>void unannotated(<a href=\"../typeannos/" + "ParaParameterized.html\" title=\"class in typeannos\">" + "ParaParameterized</a><java.lang.String,java.lang.String>" + " a)</pre>", "<pre>void nestedParaParameterized(<a href=\"../typeannos/" + "ParaParameterized.html\" title=\"class in typeannos\">" + "ParaParameterized</a><<a href=\"../typeannos/ParamA.html\" " + "title=\"annotation in typeannos\">@ParamA</a> <a href=\"../" + "typeannos/ParaParameterized.html\" title=\"class in typeannos\">" + "ParaParameterized</a><<a href=\"../typeannos/ParamA.html\" " + "title=\"annotation in typeannos\">@ParamA</a> java.lang.String," + "<a href=\"../typeannos/ParamB.html\" title=\"annotation in " + "typeannos\">@ParamB</a> java.lang.String>,<a href=\"../" + "typeannos/ParamB.html\" title=\"annotation in typeannos\">@ParamB" + "</a> java.lang.String> a)</pre>", "<pre>void array2Deep(<a href=\"../typeannos/ParamA.html\" " + "title=\"annotation in typeannos\">@ParamA</a> java.lang.String " + "<a href=\"../typeannos/ParamA.html\" title=\"annotation in " + "typeannos\">@ParamA</a> [] <a href=\"../typeannos/ParamB.html\" " + "title=\"annotation in typeannos\">@ParamB</a> [] a)</pre>"); // Test for type annotations on throws (Throws.java). checkOutput("typeannos/ThrDefaultUnmodified.html", true, "<pre>void oneException()\n" + " throws <a href=\"../typeannos/ThrA.html\" title=\"" + "annotation in typeannos\">@ThrA</a> java.lang.Exception</pre>", "<pre>void twoExceptions()\n" + " throws <a href=\"../typeannos/ThrA.html\" title=\"" + "annotation in typeannos\">@ThrA</a> java.lang.RuntimeException,\n" + " <a href=\"../typeannos/ThrA.html\" title=\"" + "annotation in typeannos\">@ThrA</a> java.lang.Exception</pre>"); checkOutput("typeannos/ThrPublicModified.html", true, "<pre>public final void oneException(java.lang.String a)\n" + " throws <a href=\"../typeannos/ThrA.html\" " + "title=\"annotation in typeannos\">@ThrA</a> java.lang.Exception</pre>", "<pre>public final void twoExceptions(java.lang.String a)\n" + " throws <a href=\"../typeannos/ThrA.html\" " + "title=\"annotation in typeannos\">@ThrA</a> java.lang.RuntimeException,\n" + " <a href=\"../typeannos/ThrA.html\" " + "title=\"annotation in typeannos\">@ThrA</a> java.lang.Exception</pre>"); checkOutput("typeannos/ThrWithValue.html", true, "<pre>void oneException()\n" + " throws <a href=\"../typeannos/ThrB.html\" title=\"" + "annotation in typeannos\">@ThrB</a>(<a href=\"../typeannos/" + "ThrB.html#value--\">value</a>=\"m\") java.lang.Exception</pre>", "<pre>void twoExceptions()\n" + " throws <a href=\"../typeannos/ThrB.html\" title=\"" + "annotation in typeannos\">@ThrB</a>(<a href=\"../typeannos/" + "ThrB.html#value--\">value</a>=\"m\") java.lang.RuntimeException,\n" + " <a href=\"../typeannos/ThrA.html\" title=\"" + "annotation in typeannos\">@ThrA</a> java.lang.Exception</pre>"); // Test for type annotations on type parameters (TypeParameters.java). checkOutput("typeannos/TestMethods.html", true, "<pre><K,V extends <a href=\"../typeannos/TyParaA.html\" title=\"" + "annotation in typeannos\">@TyParaA</a> java.lang.String> " + "void secondAnnotated()</pre>"); // Test for type annotations on wildcard type (Wildcards.java). checkOutput("typeannos/BoundTest.html", true, "<pre>void wcExtends(<a href=\"../typeannos/MyList.html\" " + "title=\"class in typeannos\">MyList</a><? extends <a href=\"" + "../typeannos/WldA.html\" title=\"annotation in typeannos\">@WldA" + "</a> java.lang.String> l)</pre>", "<pre><a href=\"../typeannos/MyList.html\" title=\"class in " + "typeannos\">MyList</a><? super <a href=\"../typeannos/WldA.html\" " + "title=\"annotation in typeannos\">@WldA</a> java.lang.String>" + " returnWcSuper()</pre>"); checkOutput("typeannos/BoundWithValue.html", true, "<pre>void wcSuper(<a href=\"../typeannos/MyList.html\" title=\"" + "class in typeannos\">MyList</a><? super <a href=\"../typeannos/" + "WldB.html\" title=\"annotation in typeannos\">@WldB</a>(<a href=\"" + "../typeannos/WldB.html#value--\">value</a>=\"m\") java.lang." + "String> l)</pre>", "<pre><a href=\"../typeannos/MyList.html\" title=\"class in " + "typeannos\">MyList</a><? extends <a href=\"../typeannos/WldB." + "html\" title=\"annotation in typeannos\">@WldB</a>(<a href=\"../" + "typeannos/WldB.html#value--\">value</a>=\"m\") java.lang.String" + "> returnWcExtends()</pre>"); // Test for receiver annotations (Receivers.java). checkOutput("typeannos/DefaultUnmodified.html", true, "<pre>void withException(<a href=\"../typeannos/RcvrA.html\" " + "title=\"annotation in typeannos\">@RcvrA</a> " + "DefaultUnmodified this)\n" + " throws java." + "lang.Exception</pre>", "<pre>java.lang.String nonVoid(<a href=\"../typeannos/RcvrA." + "html\" title=\"annotation in typeannos\">@RcvrA</a> <a href=\"../" + "typeannos/RcvrB.html\" title=\"annotation in typeannos\">@RcvrB" + "</a>(<a href=\"../typeannos/RcvrB.html#value--\">value</a>=\"m\")" + " DefaultUnmodified this)</pre>", "<pre><T extends java.lang.Runnable> void accept(" + "<a href=\"../typeannos/RcvrA.html\" title=\"annotation in " + "typeannos\">@RcvrA</a> DefaultUnmodified this,\n" + " T r)\n" + " throws java.lang.Exception</pre>"); checkOutput("typeannos/PublicModified.html", true, "<pre>public final java.lang.String nonVoid(<a href=\"" + "../typeannos/RcvrA.html\" title=\"annotation in typeannos\">" + "@RcvrA</a> PublicModified this)</pre>", "<pre>public final <T extends java.lang.Runnable> " + "void accept(<a href=\"../typeannos/RcvrA.html\" title=\"" + "annotation in typeannos\">@RcvrA</a> PublicModified this,\n" + " T r)\n" + " throws java.lang.Exception</pre>"); checkOutput("typeannos/WithValue.html", true, "<pre><T extends java.lang.Runnable> void accept(" + "<a href=\"../typeannos/RcvrB.html\" title=\"annotation in " + "typeannos\">@RcvrB</a>(<a href=\"../typeannos/RcvrB.html#value--\">" + "value</a>=\"m\") WithValue this,\n" + " T r)\n" + " throws java.lang.Exception</pre>"); checkOutput("typeannos/WithFinal.html", true, "<pre>java.lang.String nonVoid(<a href=\"../typeannos/RcvrB." + "html\" title=\"annotation in typeannos\">@RcvrB</a>(<a href=\"../" + "typeannos/RcvrB.html#value--\">value</a>=\"m\") WithFinal" + " this)</pre>"); checkOutput("typeannos/WithBody.html", true, "<pre>void field(<a href=\"../typeannos/RcvrA.html\" title=\"" + "annotation in typeannos\">@RcvrA</a> WithBody this)</pre>"); checkOutput("typeannos/Generic2.html", true, "<pre>void test2(<a href=\"../typeannos/RcvrA.html\" title=\"" + "annotation in typeannos\">@RcvrA</a> Generic2<X> this)</pre>"); } }