/* * Copyright (c) 2013, 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 * 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 javadoc.tester.* * @run main TestAnchorNames */ import java.io.IOException; import java.nio.file.Path; import java.nio.file.Paths; import javadoc.tester.JavadocTester; import toolbox.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 public 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 public 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>"); } }