8175200: Long method signatures disturb Method Summary table
Reviewed-by: jjg, ksrini
/*
* Copyright (c) 2013, 2017, 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 4749567 8071982 8175200
* @summary Test the output for -header, -footer, -nooverview, -nodeprecatedlist, -nonavbar, -notree, -stylesheetfile options.
* @author Bhavesh Patel
* @library ../lib
* @modules jdk.javadoc/jdk.javadoc.internal.tool
* @build JavadocTester
* @run main TestOptions
*/
import java.io.File;
public class TestOptions extends JavadocTester {
public static void main(String... args) throws Exception {
TestOptions tester = new TestOptions();
tester.runTests();
}
@Test
void testHeaderFooter() {
javadoc("-d", "out-1",
"-header", "Test header",
"-footer", "Test footer",
"-sourcepath", testSrc,
"pkg");
checkExit(Exit.OK);
checkOutput("pkg/package-summary.html", true,
"<div class=\"aboutLanguage\">Test header</div>",
"<div class=\"aboutLanguage\">Test footer</div>");
}
@Test
void testNoOverview() {
javadoc("-d", "out-4",
"-nooverview",
"-sourcepath", testSrc,
"pkg", "deprecated");
checkExit(Exit.OK);
checkFiles(false, "overview-summary.html");
}
@Test
void testNoDeprecatedList() {
javadoc("-d", "out-5",
"-nodeprecatedlist",
"-sourcepath", testSrc,
"deprecated");
checkExit(Exit.OK);
checkFiles(false, "deprecated-list.html");
}
@Test
void testNoNavbar() {
javadoc("-d", "out-6",
"-nonavbar",
"-bottom", "Bottom text",
"-sourcepath", testSrc,
"pkg");
checkExit(Exit.OK);
checkOutput("pkg/Foo.html", false, "navbar");
checkOutput("pkg/Foo.html", true, "Bottom text");
}
@Test
void testNoTree() {
javadoc("-d", "out-7",
"-notree",
"-sourcepath", testSrc,
"pkg");
checkExit(Exit.OK);
checkFiles(false, "overview-tree.html");
checkFiles(false, "pkg/package-tree.html");
checkOutput("pkg/Foo.html", false, "<li><a href=\"package-tree.html\">Tree</a></li>");
}
@Test
void testStylesheetFile() {
javadoc("-d", "out-8",
"-stylesheetfile", new File(testSrc, "custom-stylesheet.css").getAbsolutePath(),
"-sourcepath", testSrc,
"pkg");
checkExit(Exit.OK);
checkOutput("custom-stylesheet.css", true, "Custom javadoc style sheet");
checkOutput("pkg/Foo.html", true, "<link rel=\"stylesheet\" type=\"text/css\" "
+ "href=\"../custom-stylesheet.css\" title=\"Style\">");
}
@Test
void testLinkSource() {
javadoc("-d", "out-9",
"-linksource",
"-javafx",
"-sourcepath", testSrc,
"-package",
"linksource");
checkExit(Exit.OK);
checkOutput("linksource/AnnotationTypeField.html", true,
"<pre>@Documented\npublic @interface <a href="
+ "\"../src-html/linksource/AnnotationTypeField.html#line.31\">"
+ "AnnotationTypeField</a></pre>",
"<h4>DEFAULT_NAME</h4>\n<pre>static final java.lang.String "
+ "<a href=\"../src-html/linksource/AnnotationTypeField.html#line.32\">"
+ "DEFAULT_NAME</a></pre>",
"<h4>name</h4>\n<pre>java.lang.String <a href="
+ "\"../src-html/linksource/AnnotationTypeField.html#line.34\">name</a></pre>");
checkOutput("src-html/linksource/AnnotationTypeField.html", true,
"<title>Source code</title>",
"<span class=\"sourceLineNo\">031</span><a name=\"line.31\">"
+ "@Documented public @interface AnnotationTypeField {</a>");
checkOutput("linksource/Properties.html", true,
"<pre>public class <a href=\"../src-html/linksource/Properties.html#line.29\">"
+ "Properties</a>",
"<pre>public java.lang.Object <a href="
+ "\"../src-html/linksource/Properties.html#line.31\">someProperty</a></pre>",
"<pre>public java.lang.Object <a href="
+ "\"../src-html/linksource/Properties.html#line.31\">someProperty</a>​()</pre>");
checkOutput("src-html/linksource/Properties.html", true,
"<title>Source code</title>",
"<span class=\"sourceLineNo\">031</span><a name=\"line.31\"> "
+ "public Object someProperty() {</a>");
checkOutput("linksource/SomeClass.html", true,
"<pre>public class <a href=\"../src-html/linksource/SomeClass.html#line.29\">"
+ "SomeClass</a>\nextends java.lang.Object</pre>",
"<pre>public int <a href=\"../src-html/linksource/SomeClass.html#line.31\">"
+ "field</a></pre>",
"<pre>public <a href=\"../src-html/linksource/SomeClass.html#line.33\">"
+ "SomeClass</a>​()</pre>",
"<pre>public int <a href=\"../src-html/linksource/SomeClass.html#line.36\">"
+ "method</a>​()</pre>");
checkOutput("src-html/linksource/SomeClass.html", true,
"<title>Source code</title>",
"<span class=\"sourceLineNo\">029</span><a name=\"line.29\">"
+ "public class SomeClass {</a>",
"<span class=\"sourceLineNo\">031</span><a name=\"line.31\"> "
+ "public int field;</a>",
"<span class=\"sourceLineNo\">033</span><a name=\"line.33\"> "
+ "public SomeClass() {</a>",
"<span class=\"sourceLineNo\">036</span><a name=\"line.36\"> "
+ "public int method() {</a>");
checkOutput("linksource/SomeEnum.html", true,
"<pre>public static final <a href=\"../linksource/SomeEnum.html\" "
+ "title=\"enum in linksource\">SomeEnum</a> <a href="
+ "\"../src-html/linksource/SomeEnum.html#line.29\">VALUE1</a></pre>",
"<pre>public static final <a href=\"../linksource/SomeEnum.html\" "
+ "title=\"enum in linksource\">SomeEnum</a> <a href="
+ "\"../src-html/linksource/SomeEnum.html#line.30\">VALUE2</a></pre>");
checkOutput("src-html/linksource/SomeEnum.html", true,
"<span class=\"sourceLineNo\">029</span><a name=\"line.29\"> VALUE1,</a>",
"<span class=\"sourceLineNo\">030</span><a name=\"line.30\"> VALUE2</a>");
}
@Test
void testNoQualifier() {
javadoc("-d", "out-10",
"-noqualifier", "pkg",
"-sourcepath", testSrc,
"pkg", "deprecated");
checkExit(Exit.OK);
checkOutput("pkg/Foo.html", true,
"<li>Foo</li>");
checkOutput("deprecated/Foo.html", true,
"<li>deprecated.Foo</li>");
javadoc("-d", "out-10a",
"-noqualifier", "all",
"-sourcepath", testSrc,
"pkg", "deprecated");
checkExit(Exit.OK);
checkOutput("pkg/Foo.html", true,
"<li>Foo</li>");
checkOutput("deprecated/Foo.html", true,
"<li>Foo</li>");
}
}