2015-11-28 18:52:17 -08:00
|
|
|
/*
|
2024-01-29 21:28:49 +00:00
|
|
|
* Copyright (c) 2004, 2023, 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
|
2024-01-29 21:28:49 +00:00
|
|
|
* @bug 4632553 4973607 8026567 8242564
|
2015-11-28 18:52:17 -08:00
|
|
|
* @summary No need to include type name (class, interface, etc.) before
|
|
|
|
* every single type in class tree.
|
|
|
|
* Make sure class tree includes heirarchy for enums and annotation
|
|
|
|
* types.
|
2024-01-29 21:28:49 +00:00
|
|
|
* Make sure class tree handles undefined types in the class
|
|
|
|
* hierarchy.
|
|
|
|
* @library /tools/lib ../../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
|
2024-01-29 21:28:49 +00:00
|
|
|
* @build toolbox.ToolBox javadoc.tester.*
|
2015-11-28 18:52:17 -08:00
|
|
|
* @run main TestClassTree
|
|
|
|
*/
|
|
|
|
|
2024-01-29 21:28:49 +00:00
|
|
|
import java.io.IOException;
|
|
|
|
import java.nio.file.Path;
|
|
|
|
|
2018-12-21 10:38:33 -08:00
|
|
|
import javadoc.tester.JavadocTester;
|
2024-01-29 21:28:49 +00:00
|
|
|
import toolbox.ToolBox;
|
2018-12-21 10:38:33 -08:00
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
public class TestClassTree extends JavadocTester {
|
|
|
|
|
2024-01-29 21:28:49 +00:00
|
|
|
private final ToolBox tb = new ToolBox();
|
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
public static void main(String... args) throws Exception {
|
2022-12-22 21:20:43 +00:00
|
|
|
var tester = new TestClassTree();
|
2015-11-28 18:52:17 -08:00
|
|
|
tester.runTests();
|
|
|
|
}
|
|
|
|
|
2024-01-29 21:28:49 +00:00
|
|
|
/**
|
|
|
|
* Given badpkg package containing class ChildClass with UndefinedClass
|
|
|
|
* base class, implementing UndefinedInterface and a defined
|
|
|
|
* interface
|
|
|
|
* When the javadoc is generated with '--ignore-source-errors option'
|
|
|
|
* Then javadoc exits successfully
|
|
|
|
* And generates html for the ChildClass with UndefinedClass base class
|
|
|
|
* And UndefinedInterface is not present in html
|
|
|
|
*/
|
|
|
|
@Test
|
|
|
|
public void testBadPkg(Path base) throws IOException {
|
|
|
|
Path src = base.resolve("src");
|
|
|
|
tb.writeJavaFiles(src,
|
|
|
|
"""
|
|
|
|
package badpkg;
|
|
|
|
public class ChildClass extends UndefinedClass
|
|
|
|
implements UndefinedInterface, Iterable {
|
|
|
|
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
);
|
|
|
|
|
|
|
|
javadoc("--ignore-source-errors",
|
|
|
|
"-d", base.resolve("badout").toString(),
|
|
|
|
"--no-platform-links",
|
|
|
|
"-sourcepath", src.toString(),
|
|
|
|
"badpkg");
|
|
|
|
|
|
|
|
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
checkOutput("badpkg/package-tree.html", true,
|
|
|
|
"""
|
|
|
|
<li class="circle">badpkg.<a href="ChildClass.html" class="type-name-link" title="\
|
|
|
|
class in badpkg">ChildClass</a> (implements java.lang.Iterable<T>)</li>
|
|
|
|
""");
|
|
|
|
checkOutput("badpkg/ChildClass.html", true,
|
|
|
|
"""
|
|
|
|
<div class="type-signature"><span class="modifiers">public class </span>\
|
|
|
|
<span class="element-name type-name-label">ChildClass</span>
|
|
|
|
<span class="extends-implements">extends UndefinedClass
|
|
|
|
implements java.lang.Iterable</span></div>
|
|
|
|
""");
|
|
|
|
checkOutput("badpkg/ChildClass.html", false, "UndefinedInterface");
|
|
|
|
}
|
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void test() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out",
|
2020-10-07 13:08:34 +00:00
|
|
|
"--no-platform-links",
|
2015-11-28 18:52:17 -08:00
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"pkg");
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
|
|
|
|
checkOutput("pkg/package-tree.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
<ul>
|
2021-02-12 08:32:47 +00:00
|
|
|
<li class="circle">pkg.<a href="ParentClass.html" class="type-name-link" title="\
|
|
|
|
class in pkg">ParentClass</a>""",
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2020-12-18 18:34:25 +00:00
|
|
|
<h2 title="Annotation Interface Hierarchy">Annotation Interface Hierarchy</h2>
|
2020-05-05 13:02:30 -07:00
|
|
|
<ul>
|
2021-02-12 08:32:47 +00:00
|
|
|
<li class="circle">pkg.<a href="AnnotationType.html" class="type-name-link" titl\
|
2021-03-24 20:13:01 +00:00
|
|
|
e="annotation interface in pkg">AnnotationType</a> (implements java.lang.annotat\
|
|
|
|
ion.Annotation)</li>
|
2020-05-05 13:02:30 -07:00
|
|
|
</ul>""",
|
|
|
|
"""
|
2020-12-18 18:34:25 +00:00
|
|
|
<h2 title="Enum Class Hierarchy">Enum Class Hierarchy</h2>
|
2020-05-05 13:02:30 -07:00
|
|
|
<ul>
|
|
|
|
<li class="circle">java.lang.Object
|
|
|
|
<ul>
|
|
|
|
<li class="circle">java.lang.Enum<E> (implements java.lang.Comparable<T\
|
|
|
|
>, java.lang.constant.Constable, java.io.Serializable)
|
|
|
|
<ul>
|
2021-02-12 08:32:47 +00:00
|
|
|
<li class="circle">pkg.<a href="Coin.html" class="type-name-link" title="enum cl\
|
|
|
|
ass in pkg">Coin</a></li>
|
2020-05-05 13:02:30 -07:00
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
</ul>""");
|
2015-11-28 18:52:17 -08:00
|
|
|
|
|
|
|
checkOutput("pkg/package-tree.html", false,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<li class="circle">class pkg.<a href=".ParentClass.html" class="type-name-link" \
|
|
|
|
title="class in pkg">ParentClass</a></li>""");
|
2015-11-28 18:52:17 -08:00
|
|
|
}
|
|
|
|
}
|