2015-11-28 18:52:17 -08:00
|
|
|
/*
|
2021-03-24 19:51:35 +00:00
|
|
|
* Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved.
|
2015-11-28 18:52:17 -08: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
|
2017-11-14 13:44:07 -08:00
|
|
|
* @bug 4934778 4777599 6553182 8146427 8146475 8175055 8185371
|
2018-01-16 08:48:34 +01:00
|
|
|
* @summary Make sure that --help, -helpfile and -nohelp options work correctly.
|
2018-12-21 10:38:33 -08:00
|
|
|
* @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
|
2018-12-21 10:38:33 -08:00
|
|
|
* @build javadoc.tester.* TestHelpOption
|
2015-11-28 18:52:17 -08:00
|
|
|
* @run main TestHelpOption
|
|
|
|
*/
|
|
|
|
|
2016-09-30 13:15:22 -07:00
|
|
|
import java.util.*;
|
|
|
|
import java.util.stream.*;
|
|
|
|
|
2018-12-21 10:38:33 -08:00
|
|
|
import javadoc.tester.JavadocTester;
|
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
public class TestHelpOption extends JavadocTester {
|
|
|
|
|
|
|
|
public static void main(String... args) throws Exception {
|
|
|
|
TestHelpOption tester = new TestHelpOption();
|
|
|
|
tester.runTests();
|
|
|
|
}
|
|
|
|
|
2016-09-30 13:15:22 -07:00
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void testLineLengths() {
|
2016-09-30 13:15:22 -07:00
|
|
|
javadoc("-d", "out1",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-X",
|
|
|
|
testSrc("TestXOption.java"));
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
List<String> longLines = getOutputLines(Output.OUT).stream()
|
|
|
|
.filter(s -> s.length() > 80)
|
|
|
|
.collect(Collectors.toList());
|
|
|
|
checking("line lengths");
|
|
|
|
if (longLines.isEmpty()) {
|
|
|
|
passed("all lines OK");
|
|
|
|
} else {
|
|
|
|
out.println("long lines:");
|
|
|
|
longLines.stream().forEach(s -> out.println(">>>" + s + "<<<"));
|
|
|
|
failed(longLines.size() + " long lines");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void testWithOption() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out1",
|
|
|
|
"-sourcepath", testSrc,
|
2018-01-16 08:48:34 +01:00
|
|
|
"--help",
|
2015-11-28 18:52:17 -08:00
|
|
|
testSrc("Sample.java"));
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
|
|
|
|
checkOutput(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void testWithoutOption() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out2",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
testSrc("Sample.java"));
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void testNohelpOption() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out3",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-nohelp",
|
|
|
|
testSrc("Sample.java"));
|
2020-05-05 13:02:30 -07:00
|
|
|
checkOutput("Sample.html", false, """
|
2021-03-24 19:51:35 +00:00
|
|
|
<li><a href="../help-doc.html#class">Help</a></li>""");
|
2015-11-28 18:52:17 -08:00
|
|
|
checkExit(Exit.OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void testHelpfileOption() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out4",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-helpfile", testSrc("test-help.html"),
|
|
|
|
testSrc("Sample.java"));
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
checkOutput("Sample.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-03-24 19:51:35 +00:00
|
|
|
<li><a href="test-help.html#class">Help</a></li>""");
|
2016-03-14 15:04:57 -07:00
|
|
|
checkOutput("test-help.html", true,
|
|
|
|
"Help, help.");
|
2015-11-28 18:52:17 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void testHelpfileReuseOption() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out5",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-helpfile", testSrc("test-help.html"),
|
|
|
|
"-helpfile", testSrc("test-help.html"),
|
|
|
|
testSrc("Sample.java"));
|
2017-02-25 18:02:06 -08:00
|
|
|
checkExit(Exit.CMDERR);
|
2015-11-28 18:52:17 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void testHelpfileNohelpConflict() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out6",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-helpfile", testSrc("test-help.html"),
|
|
|
|
"-nohelp",
|
|
|
|
testSrc("Sample.java"));
|
2017-02-25 18:02:06 -08:00
|
|
|
checkExit(Exit.CMDERR);
|
2015-11-28 18:52:17 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
private void checkOutput(boolean withOption) {
|
|
|
|
checkOutput(Output.OUT, withOption,
|
|
|
|
"-d ",
|
|
|
|
"-use ",
|
|
|
|
"-version ",
|
|
|
|
"-author ",
|
2016-09-30 13:15:22 -07:00
|
|
|
"-docfilessubdirs\n",
|
2015-11-28 18:52:17 -08:00
|
|
|
"-splitindex ",
|
|
|
|
"-windowtitle ",
|
|
|
|
"-doctitle ",
|
|
|
|
"-header ",
|
|
|
|
"-footer ",
|
|
|
|
"-bottom ",
|
|
|
|
"-link ",
|
|
|
|
"-linkoffline ",
|
|
|
|
"-excludedocfilessubdir ",
|
|
|
|
"-group ",
|
|
|
|
"-nocomment ",
|
2016-09-30 13:15:22 -07:00
|
|
|
"-nodeprecated\n",
|
2015-11-28 18:52:17 -08:00
|
|
|
"-noqualifier ",
|
|
|
|
"-nosince ",
|
|
|
|
"-notimestamp ",
|
2016-09-30 13:15:22 -07:00
|
|
|
"-nodeprecatedlist\n",
|
2015-11-28 18:52:17 -08:00
|
|
|
"-notree ",
|
|
|
|
"-noindex ",
|
|
|
|
"-nohelp ",
|
|
|
|
"-nonavbar ",
|
|
|
|
"-serialwarn ",
|
|
|
|
"-tag ",
|
|
|
|
"-taglet ",
|
|
|
|
"-tagletpath ",
|
|
|
|
"-charset ",
|
|
|
|
"-helpfile ",
|
|
|
|
"-linksource ",
|
|
|
|
"-sourcetab ",
|
|
|
|
"-keywords ",
|
|
|
|
"-stylesheetfile ",
|
2017-11-14 13:44:07 -08:00
|
|
|
"--add-stylesheet ",
|
2021-11-11 09:13:49 +00:00
|
|
|
"--add-script",
|
2016-03-14 15:04:57 -07:00
|
|
|
"-docencoding ",
|
|
|
|
"-html5 ",
|
|
|
|
"-top ",
|
|
|
|
"-author ",
|
|
|
|
"-noqualifier ",
|
|
|
|
"-nosince ",
|
|
|
|
"-notimestamp ",
|
|
|
|
"-sourcetab ");
|
2015-11-28 18:52:17 -08:00
|
|
|
|
2016-12-20 06:06:01 -08:00
|
|
|
checkFileAndOutput("Sample.html", !withOption,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
<li><a href="help-doc.html">Help</a></li>""");
|
2015-11-28 18:52:17 -08:00
|
|
|
}
|
|
|
|
}
|