| /* |
| * Copyright (c) 2013, 2018, 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 8025633 8025524 8081854 8187521 8182765 |
| * @summary Test for valid name attribute in HTML anchors. |
| * @author Bhavesh Patel |
| * @library /tools/lib ../lib |
| * @modules jdk.javadoc/jdk.javadoc.internal.tool |
| * @build toolbox.ToolBox JavadocTester |
| * @run main TestAnchorNames |
| */ |
| |
| import java.io.IOException; |
| import java.nio.file.Path; |
| import java.nio.file.Paths; |
| |
| import toolbox.*; |
| |
| public class TestAnchorNames extends JavadocTester { |
| |
| public final ToolBox tb; |
| public static void main(String... args) throws Exception { |
| TestAnchorNames tester = new TestAnchorNames(); |
| tester.runTests(m -> new Object[] { Paths.get(m.getName()) }); |
| } |
| |
| public TestAnchorNames() { |
| tb = new ToolBox(); |
| } |
| |
| @Test |
| void testHtml4(Path ignore) { |
| setAutomaticCheckLinks(false); // @ignore JDK-8202622 |
| javadoc("-d", "out-html4", |
| "-html4", |
| "-sourcepath", testSrc, |
| "-source", "8", //so that '_' can be used as an identifier |
| "-use", |
| "pkg1"); |
| setAutomaticCheckLinks(true); // @ignore JDK-8202622 |
| checkExit(Exit.OK); |
| |
| // Test some section markers and links to these markers |
| checkOutput("pkg1/RegClass.html", true, |
| "<a name=\"skip.navbar.top\">", |
| "<a href=\"#skip.navbar.top\" title=\"Skip navigation links\">", |
| "<a name=\"nested.class.summary\">", |
| "<a href=\"#nested.class.summary\">", |
| "<a name=\"method.summary\">", |
| "<a href=\"#method.summary\">", |
| "<a name=\"field.detail\">", |
| "<a href=\"#field.detail\">", |
| "<a name=\"constructor.detail\">", |
| "<a href=\"#constructor.detail\">"); |
| |
| // Test some members and link to these members |
| checkOutput("pkg1/RegClass.html", true, |
| //The marker for this appears in the serialized-form.html which we will |
| //test below |
| "<a href=\"../serialized-form.html#pkg1.RegClass\">"); |
| |
| // Test some fields |
| checkOutput("pkg1/RegClass.html", true, |
| "<a name=\"Z:Z_\">", |
| "<a href=\"#Z:Z_\">", |
| "<a name=\"Z:Z_:D\">", |
| "<a href=\"#Z:Z_:D\">", |
| "<a name=\"Z:Z:D_\">", |
| "<a href=\"#Z:Z:D_\">", |
| "<a name=\"Z:Z:Dfield\">", |
| "<a href=\"#Z:Z:Dfield\">", |
| "<a name=\"fieldInCla:D:D\">", |
| "<a href=\"#fieldInCla:D:D\">", |
| "<a name=\"S_:D:D:D:D:DINT\">", |
| "<a href=\"#S_:D:D:D:D:DINT\">", |
| "<a name=\"method:D:D\">", |
| "<a href=\"#method:D:D\">"); |
| |
| checkOutput("pkg1/DeprMemClass.html", true, |
| "<a name=\"Z:Z_field_In_Class\">", |
| "<a href=\"#Z:Z_field_In_Class\">"); |
| |
| // Test constructor |
| checkOutput("pkg1/RegClass.html", true, |
| "<a name=\"RegClass-java.lang.String-int-\">", |
| "<a href=\"#RegClass-java.lang.String-int-\">"); |
| |
| // Test some methods |
| checkOutput("pkg1/RegClass.html", true, |
| "<a name=\"Z:Z_methodInClass-java.lang.String-\">", |
| "<a href=\"#Z:Z_methodInClass-java.lang.String-\">", |
| "<a name=\"method--\">", |
| "<a href=\"#method--\">", |
| "<a name=\"foo-java.util.Map-\">", |
| "<a href=\"#foo-java.util.Map-\">", |
| "<a name=\"methodInCla:Ds-java.lang.String:A-\">", |
| "<a href=\"#methodInCla:Ds-java.lang.String:A-\">", |
| "<a name=\"Z:Z_methodInClas:D-java.lang.String-int-\">", |
| "<a href=\"#Z:Z_methodInClas:D-java.lang.String-int-\">", |
| "<a name=\"methodD-pkg1.RegClass.:DA-\">", |
| "<a href=\"#methodD-pkg1.RegClass.:DA-\">", |
| "<a name=\"methodD-pkg1.RegClass.D:A-\">", |
| "<a href=\"#methodD-pkg1.RegClass.D:A-\">"); |
| |
| checkOutput("pkg1/DeprMemClass.html", true, |
| "<a name=\"Z:Z:Dmethod_In_Class--\">", |
| "<a href=\"#Z:Z:Dmethod_In_Class--\">"); |
| |
| // Test enum |
| checkOutput("pkg1/RegClass.Te$t_Enum.html", true, |
| "<a name=\"Z:Z:DFLD2\">", |
| "<a href=\"#Z:Z:DFLD2\">"); |
| |
| // Test nested class |
| checkOutput("pkg1/RegClass._NestedClas$.html", true, |
| "<a name=\"Z:Z_NestedClas:D--\">", |
| "<a href=\"#Z:Z_NestedClas:D--\">"); |
| |
| // Test class use page |
| checkOutput("pkg1/class-use/DeprMemClass.html", true, |
| "<a href=\"../RegClass.html#d____mc\">"); |
| |
| // Test deprecated list page |
| checkOutput("deprecated-list.html", true, |
| "<a href=\"pkg1/DeprMemClass.html#Z:Z_field_In_Class\">", |
| "<a href=\"pkg1/DeprMemClass.html#Z:Z:Dmethod_In_Class--\">"); |
| |
| // Test constant values page |
| checkOutput("constant-values.html", true, |
| "<a href=\"pkg1/RegClass.html#S_:D:D:D:D:DINT\">"); |
| |
| // Test serialized form page |
| checkOutput("serialized-form.html", true, |
| //This is the marker for the link that appears in the pkg1.RegClass.html page |
| "<a name=\"pkg1.RegClass\">"); |
| |
| // Test member name index page |
| checkOutput("index-all.html", true, |
| "<a name=\"I:Z:Z:D\">", |
| "<a href=\"#I:Z:Z:D\">$", |
| "<a href=\"#I:Z:Z_\">_"); |
| |
| // The marker name conversion should only affect HTML anchors. It should not |
| // affect the labels. |
| checkOutput("pkg1/RegClass.html", false, |
| " Z:Z_", |
| " Z:Z:Dfield", |
| " Z:Z_field_In_Class", |
| " S_:D:D:D:D:DINT"); |
| } |
| |
| @Test |
| void testHtml5(Path ignore) { |
| javadoc("-d", "out-html5", |
| "-sourcepath", testSrc, |
| "-source", "8", //so that '_' can be used as an identifier |
| "-use", |
| "pkg1"); |
| checkExit(Exit.OK); |
| |
| // Test some section markers and links to these markers |
| checkOutput("pkg1/RegClass.html", true, |
| "<a id=\"skip.navbar.top\">", |
| "<a href=\"#skip.navbar.top\" title=\"Skip navigation links\">", |
| "<a id=\"nested.class.summary\">", |
| "<a href=\"#nested.class.summary\">", |
| "<a id=\"method.summary\">", |
| "<a href=\"#method.summary\">", |
| "<a id=\"field.detail\">", |
| "<a href=\"#field.detail\">", |
| "<a id=\"constructor.detail\">", |
| "<a href=\"#constructor.detail\">"); |
| |
| // Test some members and link to these members |
| checkOutput("pkg1/RegClass.html", true, |
| //The marker for this appears in the serialized-form.html which we will |
| //test below |
| "<a href=\"../serialized-form.html#pkg1.RegClass\">"); |
| |
| // Test some fields |
| checkOutput("pkg1/RegClass.html", true, |
| "<a id=\"_\">", |
| "<a href=\"#_\">", |
| "<a id=\"_$\">", |
| "<a href=\"#_$\">", |
| "<a id=\"$_\">", |
| "<a href=\"#$_\">", |
| "<a id=\"$field\">", |
| "<a href=\"#$field\">", |
| "<a id=\"fieldInCla$$\">", |
| "<a href=\"#fieldInCla$$\">", |
| "<a id=\"S_$$$$$INT\">", |
| "<a href=\"#S_$$$$$INT\">", |
| "<a id=\"method$$\">", |
| "<a href=\"#method$$\">"); |
| |
| checkOutput("pkg1/DeprMemClass.html", true, |
| "<a id=\"_field_In_Class\">", |
| "<a href=\"#_field_In_Class\">"); |
| |
| // Test constructor |
| checkOutput("pkg1/RegClass.html", true, |
| "<a id=\"<init>(java.lang.String,int)\">", |
| "<a href=\"#%3Cinit%3E(java.lang.String,int)\">"); |
| |
| // Test some methods |
| checkOutput("pkg1/RegClass.html", true, |
| "<a id=\"_methodInClass(java.lang.String)\">", |
| "<a href=\"#_methodInClass(java.lang.String)\">", |
| "<a id=\"method()\">", |
| "<a href=\"#method()\">", |
| "<a id=\"foo(java.util.Map)\">", |
| "<a href=\"#foo(java.util.Map)\">", |
| "<a id=\"methodInCla$s(java.lang.String[])\">", |
| "<a href=\"#methodInCla$s(java.lang.String%5B%5D)\">", |
| "<a id=\"_methodInClas$(java.lang.String,int)\">", |
| "<a href=\"#_methodInClas$(java.lang.String,int)\">", |
| "<a id=\"methodD(pkg1.RegClass.$A)\">", |
| "<a href=\"#methodD(pkg1.RegClass.$A)\">", |
| "<a id=\"methodD(pkg1.RegClass.D[])\">", |
| "<a href=\"#methodD(pkg1.RegClass.D%5B%5D)\">"); |
| |
| checkOutput("pkg1/DeprMemClass.html", true, |
| "<a id=\"$method_In_Class()\">", |
| "<a href=\"#$method_In_Class()\">"); |
| |
| // Test enum |
| checkOutput("pkg1/RegClass.Te$t_Enum.html", true, |
| "<a id=\"$FLD2\">", |
| "<a href=\"#$FLD2\">"); |
| |
| // Test nested class |
| checkOutput("pkg1/RegClass._NestedClas$.html", true, |
| "<a id=\"<init>()\">", |
| "<a href=\"#%3Cinit%3E()\">"); |
| |
| // Test class use page |
| checkOutput("pkg1/class-use/DeprMemClass.html", true, |
| "<a href=\"../RegClass.html#d____mc\">"); |
| |
| // Test deprecated list page |
| checkOutput("deprecated-list.html", true, |
| "<a href=\"pkg1/DeprMemClass.html#_field_In_Class\">", |
| "<a href=\"pkg1/DeprMemClass.html#$method_In_Class()\">"); |
| |
| // Test constant values page |
| checkOutput("constant-values.html", true, |
| "<a href=\"pkg1/RegClass.html#S_$$$$$INT\">"); |
| |
| // Test serialized form page |
| checkOutput("serialized-form.html", true, |
| //This is the marker for the link that appears in the pkg1.RegClass.html page |
| "<a id=\"pkg1.RegClass\">"); |
| |
| // Test member name index page |
| checkOutput("index-all.html", true, |
| "<a id=\"I:$\">", |
| "<a href=\"#I:$\">$", |
| "<a href=\"#I:_\">_"); |
| } |
| |
| /** |
| * The following test is somewhat simplistic, but it is useful |
| * in conjunction with the W3C Validation Service at https://validator.w3.org/nu/#file |
| * @param base A working directory for this method, in which some UTF-8 source files |
| * will be generated |
| * @throws IOException if there is a problem generating the source files |
| */ |
| @Test |
| void testNonAscii(Path base) throws IOException { |
| Path src = base.resolve("src"); |
| tb.writeJavaFiles(src, |
| "package p; public class Def {\n" |
| + " public int \u00e0\u00e9;\n" // a`e' |
| + " public void \u00c0\u00c9() { }\n" // A`E' |
| + " public int \u03b1\u03b2\u03b3;\n" // alpha beta gamma |
| + " public void \u0391\u0392\u0393() { }\n" // ALPHA BETA GAMMA |
| + "}", |
| "package p; \n" |
| + "/**\n" |
| + " * {@link Def#\u00e0\u00e9 àé}<br>\n" |
| + " * {@link Def#\u00c0\u00c9() ÀÉ}<br>\n" |
| + " * {@link Def#\u03b1\u03b2\u03b3 αβγ}<br>\n" |
| + " * {@link Def#\u0391\u0392\u0393() ΑΒΓ}<br>\n" |
| + " */\n" |
| + "public class Ref { }"); |
| |
| javadoc("-d", "out-nonAscii", |
| "-sourcepath", src.toString(), |
| "-html5", |
| "-encoding", "utf-8", |
| "p"); |
| checkExit(Exit.OK); |
| |
| checkOutput("p/Def.html", true, |
| "<a id=\"\u00e0\u00e9\">", |
| "<a id=\"\u00c0\u00c9()\">", |
| "<a id=\"\u03b1\u03b2\u03b3\">", |
| "<a id=\"\u0391\u0392\u0393()\">"); |
| |
| checkOutput("p/Ref.html", true, |
| "<a href=\"Def.html#%C3%A0%C3%A9\"><code>àé</code></a>", |
| "<a href=\"Def.html#%C3%80%C3%89()\"><code>ÀÉ</code></a>", |
| "<a href=\"Def.html#%CE%B1%CE%B2%CE%B3\"><code>αβγ</code></a>", |
| "<a href=\"Def.html#%CE%91%CE%92%CE%93()\"><code>ΑΒΓ</code></a>"); |
| |
| } |
| } |