2013-03-28 17:49:39 +00:00
|
|
|
/*
|
2018-01-22 19:15:51 +00:00
|
|
|
* Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved.
|
2013-03-28 17:49:39 +00:00
|
|
|
* 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
|
2018-03-06 18:45:47 +00:00
|
|
|
* @bug 4749567 8071982 8175200 8186332 8185371 8182765
|
2017-11-14 21:44:07 +00:00
|
|
|
* @summary Test the output for -header, -footer, -nooverview, -nodeprecatedlist, -nonavbar, -notree,
|
|
|
|
* -stylesheetfile, --main-stylesheet, --add-stylesheet options.
|
2015-11-29 02:52:17 +00:00
|
|
|
* @author Bhavesh Patel
|
|
|
|
* @library ../lib
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Jan Lahoda <jan.lahoda@oracle.com>
Co-authored-by: Vicente Romero <vicente.romero@oracle.com>
Co-authored-by: Andreas Lundblad <andreas.lundblad@oracle.com>
Co-authored-by: Andrey Nazarov <andrey.x.nazarov@oracle.com>
Co-authored-by: Chris Hegarty <chris.hegarty@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: Kumar Srinivasan <kumar.x.srinivasan@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: jjg, jlahoda, vromero, mcimadamore, bpatel, ksrini, darcy, anazarov, dfuchs
2016-03-17 19:04:28 +00:00
|
|
|
* @modules jdk.javadoc/jdk.javadoc.internal.tool
|
2015-11-29 02:52:17 +00:00
|
|
|
* @build JavadocTester
|
|
|
|
* @run main TestOptions
|
2013-03-28 17:49:39 +00:00
|
|
|
*/
|
|
|
|
|
2016-03-14 22:04:57 +00:00
|
|
|
import java.io.File;
|
|
|
|
|
2015-11-29 02:52:17 +00:00
|
|
|
public class TestOptions extends JavadocTester {
|
2013-03-28 17:49:39 +00:00
|
|
|
|
2015-11-29 02:52:17 +00:00
|
|
|
public static void main(String... args) throws Exception {
|
|
|
|
TestOptions tester = new TestOptions();
|
|
|
|
tester.runTests();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2016-03-14 22:04:57 +00:00
|
|
|
void testHeaderFooter() {
|
|
|
|
javadoc("-d", "out-1",
|
2015-11-29 02:52:17 +00:00
|
|
|
"-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>");
|
2013-03-28 17:49:39 +00:00
|
|
|
}
|
|
|
|
|
2016-03-14 22:04:57 +00:00
|
|
|
@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\">");
|
|
|
|
}
|
|
|
|
|
2017-11-14 21:44:07 +00:00
|
|
|
@Test
|
|
|
|
void testStylesheetFileAltOption() {
|
|
|
|
javadoc("-d", "out-stylesheet-file",
|
|
|
|
"--main-stylesheet", 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 testAdditionalStylesheetFile() {
|
|
|
|
javadoc("-d", "out-additional-css",
|
|
|
|
"--add-stylesheet", new File(testSrc, "additional-stylesheet-1.css").getAbsolutePath(),
|
|
|
|
"--add-stylesheet", new File(testSrc, "additional-stylesheet-2.css").getAbsolutePath(),
|
|
|
|
"--add-stylesheet", new File(testSrc, "additional-stylesheet-3.css").getAbsolutePath(),
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"pkg");
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
|
|
|
|
checkOutput("additional-stylesheet-1.css", true, "Additional javadoc style sheet 1");
|
|
|
|
checkOutput("additional-stylesheet-2.css", true, "Additional javadoc style sheet 2");
|
|
|
|
checkOutput("additional-stylesheet-3.css", true, "Additional javadoc style sheet 3");
|
|
|
|
checkOutput("pkg/Foo.html", true,
|
|
|
|
"<link rel=\"stylesheet\" type=\"text/css\" href=\"../additional-stylesheet-1.css\" title=\"Style\">\n"
|
|
|
|
+ "<link rel=\"stylesheet\" type=\"text/css\" href=\"../additional-stylesheet-2.css\" title=\"Style\">\n"
|
|
|
|
+ "<link rel=\"stylesheet\" type=\"text/css\" href=\"../additional-stylesheet-3.css\" title=\"Style\">");
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testInvalidStylesheetFile() {
|
|
|
|
javadoc("-d", "out-invalid-css",
|
|
|
|
"--main-stylesheet", new File(testSrc, "custom-stylesheet-1.css").getAbsolutePath(),
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"pkg");
|
|
|
|
checkExit(Exit.ERROR);
|
|
|
|
|
|
|
|
checkOutput(Output.OUT, true,
|
|
|
|
"javadoc: error - File not found:",
|
|
|
|
"custom-stylesheet-1.css");
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testInvalidAdditionalStylesheetFiles() {
|
|
|
|
javadoc("-d", "out-invalid-additional-css",
|
|
|
|
"--add-stylesheet", new File(testSrc, "additional-stylesheet-4.css").getAbsolutePath(),
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"pkg");
|
|
|
|
checkExit(Exit.ERROR);
|
|
|
|
|
|
|
|
checkOutput(Output.OUT, true,
|
|
|
|
"javadoc: error - File not found:",
|
|
|
|
"additional-stylesheet-4.css");
|
|
|
|
}
|
|
|
|
|
2016-03-14 22:04:57 +00:00
|
|
|
@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>",
|
2018-03-06 18:45:47 +00:00
|
|
|
"<span class=\"sourceLineNo\">031</span><a id=\"line.31\">"
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "@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="
|
2017-09-27 23:47:07 +00:00
|
|
|
+ "\"../src-html/linksource/Properties.html#line.31\">someProperty</a>()</pre>");
|
2016-03-14 22:04:57 +00:00
|
|
|
|
|
|
|
checkOutput("src-html/linksource/Properties.html", true,
|
|
|
|
"<title>Source code</title>",
|
2018-03-06 18:45:47 +00:00
|
|
|
"<span class=\"sourceLineNo\">031</span><a id=\"line.31\"> "
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "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\">"
|
2017-09-27 23:47:07 +00:00
|
|
|
+ "SomeClass</a>()</pre>",
|
2016-03-14 22:04:57 +00:00
|
|
|
"<pre>public int <a href=\"../src-html/linksource/SomeClass.html#line.36\">"
|
2017-09-27 23:47:07 +00:00
|
|
|
+ "method</a>()</pre>");
|
2016-03-14 22:04:57 +00:00
|
|
|
|
|
|
|
checkOutput("src-html/linksource/SomeClass.html", true,
|
|
|
|
"<title>Source code</title>",
|
2018-03-06 18:45:47 +00:00
|
|
|
"<span class=\"sourceLineNo\">029</span><a id=\"line.29\">"
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "public class SomeClass {</a>",
|
2018-03-06 18:45:47 +00:00
|
|
|
"<span class=\"sourceLineNo\">031</span><a id=\"line.31\"> "
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "public int field;</a>",
|
2018-03-06 18:45:47 +00:00
|
|
|
"<span class=\"sourceLineNo\">033</span><a id=\"line.33\"> "
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "public SomeClass() {</a>",
|
2018-03-06 18:45:47 +00:00
|
|
|
"<span class=\"sourceLineNo\">036</span><a id=\"line.36\"> "
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "public int method() {</a>");
|
|
|
|
|
|
|
|
checkOutput("linksource/SomeEnum.html", true,
|
2018-01-22 19:15:51 +00:00
|
|
|
"<pre>public static final <a href=\"SomeEnum.html\" "
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "title=\"enum in linksource\">SomeEnum</a> <a href="
|
|
|
|
+ "\"../src-html/linksource/SomeEnum.html#line.29\">VALUE1</a></pre>",
|
2018-01-22 19:15:51 +00:00
|
|
|
"<pre>public static final <a href=\"SomeEnum.html\" "
|
2016-03-14 22:04:57 +00:00
|
|
|
+ "title=\"enum in linksource\">SomeEnum</a> <a href="
|
|
|
|
+ "\"../src-html/linksource/SomeEnum.html#line.30\">VALUE2</a></pre>");
|
|
|
|
|
2018-03-06 18:45:47 +00:00
|
|
|
checkOutput("src-html/linksource/SomeEnum.html", true,
|
|
|
|
"<span class=\"sourceLineNo\">029</span><a id=\"line.29\"> VALUE1,</a>",
|
|
|
|
"<span class=\"sourceLineNo\">030</span><a id=\"line.30\"> VALUE2</a>");
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testLinkSource_html4() {
|
|
|
|
javadoc("-d", "out-9-html4",
|
|
|
|
"-html4",
|
|
|
|
"-linksource",
|
|
|
|
"-javafx",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-package",
|
|
|
|
"linksource");
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
|
|
|
|
checkOutput("src-html/linksource/AnnotationTypeField.html", true,
|
|
|
|
"<span class=\"sourceLineNo\">031</span><a name=\"line.31\">"
|
|
|
|
+ "@Documented public @interface AnnotationTypeField {</a>");
|
|
|
|
|
|
|
|
checkOutput("src-html/linksource/Properties.html", true,
|
|
|
|
"<span class=\"sourceLineNo\">031</span><a name=\"line.31\"> "
|
|
|
|
+ "public Object someProperty() {</a>");
|
|
|
|
|
|
|
|
checkOutput("src-html/linksource/SomeClass.html", true,
|
|
|
|
"<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>");
|
|
|
|
|
2016-03-14 22:04:57 +00:00
|
|
|
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>");
|
|
|
|
}
|
|
|
|
}
|