/*
* Copyright (c) 2004, 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 4973609 8015249 8025633 8026567 6469561 8071982 8162363 8182765 8223364
* @summary Make sure that annotation types with 0 members does not have
* extra HR tags.
* @author jamieh
* @library ../../lib
* @modules jdk.javadoc/jdk.javadoc.internal.tool
* @build javadoc.tester.*
* @run main TestAnnotationTypes
*/
import javadoc.tester.JavadocTester;
public class TestAnnotationTypes extends JavadocTester {
public static void main(String... args) throws Exception {
TestAnnotationTypes tester = new TestAnnotationTypes();
tester.runTests();
}
@Test
public void test() {
javadoc("-d", "out-1",
"-sourcepath", testSrc,
"pkg");
checkExit(Exit.OK);
checkOutput("pkg/AnnotationTypeField.html", true,
"<li>Summary: </li>\n"
+ "<li><a href=\"#annotation.type."
+ "field.summary\">Field</a> | </li>",
"<li>Detail: </li>\n"
+ "<li><a href=\"#annotation.type."
+ "field.detail\">Field</a> | </li>",
"<!-- =========== ANNOTATION TYPE FIELD SUMMARY =========== -->",
"<h2>Field Summary</h2>",
"<th class=\"colSecond\" scope=\"row\"><code><span class=\"memberNameLink\"><a href=\"#DEFAULT_NAME\">DEFAULT_NAME</a></span>"
+ "</code></th>",
"<!-- ============ ANNOTATION TYPE FIELD DETAIL =========== -->",
"<h3><a id=\"DEFAULT_NAME\">DEFAULT_NAME</a></h3>\n"
+ "<div class=\"memberSignature\"><span class=\"modifiers\">static final</span> "
+ "<span class=\"returnType\">java.lang.String</span> "
+ "<span class=\"memberName\">DEFAULT_NAME</span></div>\n");
checkOutput("pkg/AnnotationType.html", true,
"<li>Summary: </li>\n"
+ "<li>Field | </li>",
"<li>Detail: </li>\n"
+ "<li>Field | </li>");
checkOutput("pkg/AnnotationType.html", true,
"<!-- ============ ANNOTATION TYPE MEMBER DETAIL =========== -->",
"<ul class=\"blockList\">",
"<li class=\"blockList\">",
"<section class=\"memberDetails\">",
"<h2>Element Details</h2>",
"<a id=\"annotation.type.element.detail\">",
"<!-- -->",
"</a>",
"<ul class=\"blockList\">",
"<li class=\"blockList\">",
"<section class=\"detail\">",
"<h3><a id=\"value()\">value</a></h3>",
"<div class=\"memberSignature\"><span class=\"returnType\">int</span>"
+ " <span class=\"memberName\">value</span></div>");
checkOutput("pkg/AnnotationType.html", false,
"<HR>\n\n"
+ "<P>\n\n"
+ "<P>"
+ "<!-- ========= END OF CLASS DATA ========= -->" + "<HR>");
}
@Test
public void testLinkSource() {
javadoc("-d", "out-2",
"-linksource",
"-sourcepath", testSrc,
"pkg");
checkExit(Exit.OK);
checkOutput("src-html/pkg/AnnotationType.html", true,
"<title>Source code</title>",
"@Documented public @interface AnnotationType {");
checkOutput("src-html/pkg/AnnotationTypeField.html", true,
"<title>Source code</title>",
"@Documented public @interface AnnotationTypeField {");
checkOutput("pkg/AnnotationType.html", true,
"public @interface <a href=\"../src-html/pkg/AnnotationType.html#line.34"
+ "\">AnnotationType</a></pre>");
checkOutput("pkg/AnnotationTypeField.html", true,
"public @interface <a href=\"../src-html/pkg/AnnotationTypeField.html#line.31"
+ "\">AnnotationTypeField</a></pre>");
}
}