2015-11-28 18:52:17 -08:00
|
|
|
/*
|
2024-02-26 12:10:58 +00:00
|
|
|
* Copyright (c) 2002, 2024, 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-09-27 16:47:07 -07:00
|
|
|
* @bug 4496290 4985072 7006178 7068595 8016328 8050031 8048351 8081854 8071982 8162363 8175200 8186332
|
2024-02-26 12:10:58 +00:00
|
|
|
* 8182765 8196202 8202626 8261976 8323698
|
2015-11-28 18:52:17 -08:00
|
|
|
* @summary A simple test to ensure class-use files are correct.
|
2024-02-26 12:10:58 +00:00
|
|
|
* @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
|
2018-12-21 10:38:33 -08:00
|
|
|
* @build javadoc.tester.*
|
2015-11-28 18:52:17 -08:00
|
|
|
* @run main TestUseOption
|
|
|
|
*/
|
|
|
|
|
2018-12-21 10:38:33 -08:00
|
|
|
import javadoc.tester.JavadocTester;
|
2024-02-26 12:10:58 +00:00
|
|
|
import toolbox.ToolBox;
|
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.nio.file.Files;
|
|
|
|
import java.nio.file.Path;
|
2018-12-21 10:38:33 -08:00
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
public class TestUseOption extends JavadocTester {
|
|
|
|
|
|
|
|
public static void main(String... args) throws Exception {
|
2022-12-22 21:20:43 +00:00
|
|
|
var tester = new TestUseOption();
|
2015-11-28 18:52:17 -08:00
|
|
|
tester.runTests();
|
|
|
|
}
|
|
|
|
|
2024-02-26 12:10:58 +00:00
|
|
|
private final ToolBox tb = new ToolBox();
|
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void test1() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out-1",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-use",
|
|
|
|
"pkg1", "pkg2");
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
|
|
|
|
// Eight tests for class use.
|
|
|
|
for (int i = 1; i <= 8; i++) {
|
|
|
|
checkOutput("pkg1/class-use/C1.html", true,
|
|
|
|
"Test " + i + " passes");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Three more tests for package use.
|
|
|
|
for (int i = 1; i <= 3; i++) {
|
|
|
|
checkOutput("pkg1/package-use.html", true,
|
|
|
|
"Test " + i + " passes");
|
|
|
|
}
|
|
|
|
|
|
|
|
checkOrder("pkg1/class-use/UsedClass.html",
|
|
|
|
"Field in C1.",
|
|
|
|
"Field in C2.",
|
|
|
|
"Field in C4.",
|
|
|
|
"Field in C5.",
|
|
|
|
"Field in C6.",
|
|
|
|
"Field in C7.",
|
|
|
|
"Field in C8.",
|
|
|
|
"Method in C1.",
|
|
|
|
"Method in C2.",
|
|
|
|
"Method in C4.",
|
|
|
|
"Method in C5.",
|
|
|
|
"Method in C6.",
|
|
|
|
"Method in C7.",
|
|
|
|
"Method in C8."
|
|
|
|
);
|
|
|
|
|
|
|
|
checkOutput("pkg1/class-use/UsedClass.html", true,
|
|
|
|
"that return types with arguments of type"
|
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedClass.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C1.html#methodInC1ReturningType()" class="member-name-link">methodInC1ReturningType</a>"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
Classes in <a href="../package-summary.html">pkg1</a> that implement <a href="..\
|
|
|
|
/UsedInterface.html" title="interface in pkg1">UsedInterface</a>"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterfaceA.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
Classes in <a href="../package-summary.html">pkg1</a> that implement <a href="..\
|
|
|
|
/UsedInterfaceA.html" title="interface in pkg1">UsedInterfaceA</a>"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedClass.html", false,
|
|
|
|
"methodInC1Protected"
|
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../AnAbstract.html" class="type-name-link" title="class in pkg1">AnAbstract</a>"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2018-03-06 10:45:47 -08:00
|
|
|
"../C10.html#withReturningTypeParameters()"
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2018-03-06 10:45:47 -08:00
|
|
|
"../C10.html#withTypeParametersOfType(java.lang.Class)"
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
"../package-summary.html">pkg1</a> that return <a href="../UsedInterface.html" title="interface in pkg1\""""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C10.html#addAll(pkg1.UsedInterface...)" class="member-name-link">addAll</a>"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C10.html#create(pkg1.UsedInterfaceA,pkg1.UsedInterface,java.lang.String)" class="member-name-link">"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C10.html#withTypeParametersOfType(java.lang.Class)" class="member-name-link">withTypeParametersOfType</a>"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
2016-03-14 15:04:57 -07:00
|
|
|
checkOutput("pkg1/class-use/UsedInterface.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
Subinterfaces of <a href="../UsedInterface.html" title="interface in pkg1">UsedI\
|
|
|
|
nterface</a> in <a href="../package-summary.html">pkg1""",
|
|
|
|
"""
|
2020-10-12 09:36:43 +00:00
|
|
|
<div class="col-first even-row-color"><code>interface </code></div>
|
2021-02-12 08:32:47 +00:00
|
|
|
<div class="col-second even-row-color"><code><a href="\
|
|
|
|
../SubInterface.html" class="type-name-link" title="interface in pkg1">SubInterface</a><T>\
|
2020-10-12 09:36:43 +00:00
|
|
|
</code></div>"""
|
2016-03-14 15:04:57 -07:00
|
|
|
);
|
2018-03-06 10:45:47 -08:00
|
|
|
checkOutput("pkg1/class-use/UsedThrowable.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
Methods in <a href="../package-summary.html">pkg1</a> that throw <a href="../Use\
|
|
|
|
dThrowable.html" title="class in pkg1">UsedThrowable</a>""",
|
|
|
|
"""
|
2020-10-12 09:36:43 +00:00
|
|
|
<div class="col-first even-row-color"><code>void</code></div>
|
|
|
|
<div class="col-second even-row-color"><span class="type-name-label">C1.</span><code>\
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C1.html#methodInC1ThrowsThrowable()" class="member-name-link">\
|
|
|
|
methodInC1ThrowsThrowable</a>()</code></div>"""
|
2018-03-06 10:45:47 -08:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void test2() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out-2",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-use",
|
2016-03-14 15:04:57 -07:00
|
|
|
testSrc("C.java"), testSrc("UsedInC.java"), "pkg3");
|
2015-11-28 18:52:17 -08:00
|
|
|
checkExit(Exit.OK);
|
|
|
|
|
|
|
|
checkOutput("class-use/UsedInC.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-23 08:42:51 +00:00
|
|
|
Uses of <a href="../UsedInC.html" title="class in Unnamed Package">UsedInC</a> i\
|
|
|
|
n <a href="../package-summary.html">Unnamed Package</a>"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("class-use/UsedInC.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
|
|
|
<li>
|
2021-02-23 18:55:13 +00:00
|
|
|
<section class="detail" id="unnamed-package">
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2015-11-28 18:52:17 -08:00
|
|
|
);
|
|
|
|
checkOutput("package-use.html", true,
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-23 18:55:13 +00:00
|
|
|
<div class="col-first even-row-color"><a href="class-use/UsedInC.html#unnamed-package">UsedInC</a></div>""",
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-23 18:55:13 +00:00
|
|
|
<div class="col-first even-row-color"><a href="#unnamed-package">Unnamed Package</a></div>
|
2020-10-12 09:36:43 +00:00
|
|
|
<div class="col-last even-row-color"> </div>"""
|
2018-03-06 10:45:47 -08:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-11-28 18:52:17 -08:00
|
|
|
@Test
|
2018-12-21 10:38:33 -08:00
|
|
|
public void test3() {
|
2015-11-28 18:52:17 -08:00
|
|
|
javadoc("-d", "out-3",
|
|
|
|
"-sourcepath", testSrc,
|
|
|
|
"-use",
|
|
|
|
"-package", "unique");
|
|
|
|
checkExit(Exit.OK);
|
2018-03-06 10:45:47 -08:00
|
|
|
checkUnique("unique/class-use/UseMe.html",
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C1.html#umethod1(unique.UseMe,unique.UseMe%5B%5D)" class="member-name-link">""",
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C1.html#umethod2(unique.UseMe,unique.UseMe)" class="member-name-link">""",
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C1.html#umethod3(unique.UseMe,unique.UseMe)" class="member-name-link">""",
|
2020-05-05 13:02:30 -07:00
|
|
|
"""
|
2021-02-12 08:32:47 +00:00
|
|
|
<a href="../C1.html#%3Cinit%3E(unique.UseMe,unique.UseMe)" class="member-name-link">""");
|
2018-03-06 10:45:47 -08:00
|
|
|
}
|
2024-02-26 12:10:58 +00:00
|
|
|
|
|
|
|
@Test
|
|
|
|
public void testSuperclassAndInterfaceTypeArgument(Path base) throws IOException {
|
|
|
|
Path src = base.resolve("src");
|
|
|
|
|
|
|
|
Files.createDirectories(src);
|
|
|
|
tb.writeJavaFiles(src,
|
|
|
|
"""
|
|
|
|
public class One {}
|
|
|
|
""",
|
|
|
|
"""
|
|
|
|
import java.util.*;
|
|
|
|
public class Two extends ArrayList<One> implements Comparator<One> {
|
|
|
|
}
|
|
|
|
""",
|
|
|
|
"""
|
|
|
|
import java.util.*;
|
|
|
|
public interface Three extends Comparator<One> {
|
|
|
|
}
|
|
|
|
""");
|
|
|
|
|
|
|
|
javadoc(
|
|
|
|
"-use",
|
|
|
|
"-d", base.resolve("out").toString(),
|
|
|
|
src.resolve("One.java").toString(),
|
|
|
|
src.resolve("Two.java").toString(),
|
|
|
|
src.resolve("Three.java").toString()
|
|
|
|
);
|
|
|
|
checkExit(Exit.OK);
|
|
|
|
|
|
|
|
checkOrder("class-use/One.html",
|
|
|
|
"""
|
|
|
|
<div class="caption"><span>Subclasses with type arguments of \
|
|
|
|
type <a href="../One.html" title="class in Unnamed Package">One</a> \
|
|
|
|
in <a href="../package-summary.html">Unnamed Package</a></span></div>
|
|
|
|
""",
|
|
|
|
"""
|
|
|
|
<div class="summary-table three-column-summary">
|
|
|
|
<div class="table-header col-first">Modifier and Type</div>
|
|
|
|
<div class="table-header col-second">Class</div>
|
|
|
|
<div class="table-header col-last">Description</div>
|
|
|
|
<div class="col-first even-row-color"><code>class </code></div>
|
|
|
|
<div class="col-second even-row-color"><code><a href="../Two.html" class="type-name-link" \
|
|
|
|
title="class in Unnamed Package">Two</a></code></div>
|
|
|
|
<div class="col-last even-row-color"> </div>
|
|
|
|
</div>
|
|
|
|
""",
|
|
|
|
"""
|
|
|
|
<div class="caption"><span>Subinterfaces with type arguments of \
|
|
|
|
type <a href="../One.html" title="class in Unnamed Package">One</a> \
|
|
|
|
in <a href="../package-summary.html">Unnamed Package</a></span></div>
|
|
|
|
""",
|
|
|
|
"""
|
|
|
|
<div class="summary-table three-column-summary">
|
|
|
|
<div class="table-header col-first">Modifier and Type</div>
|
|
|
|
<div class="table-header col-second">Interface</div>
|
|
|
|
<div class="table-header col-last">Description</div>
|
|
|
|
<div class="col-first even-row-color"><code>interface </code></div>
|
|
|
|
<div class="col-second even-row-color"><code><a href="../Three.html" class="type-name-link" title="interface in Unnamed Package">Three</a></code></div>
|
|
|
|
<div class="col-last even-row-color"> </div>
|
|
|
|
</div>
|
|
|
|
""",
|
|
|
|
"""
|
|
|
|
<div class="caption"><span>Classes in <a href="../package-summary.html">\
|
|
|
|
Unnamed Package</a> that implement interfaces with type arguments of type \
|
|
|
|
<a href="../One.html" title="class in Unnamed Package">One</a></span></div>
|
|
|
|
""",
|
|
|
|
"""
|
|
|
|
<div class="summary-table three-column-summary">
|
|
|
|
<div class="table-header col-first">Modifier and Type</div>
|
|
|
|
<div class="table-header col-second">Class</div>
|
|
|
|
<div class="table-header col-last">Description</div>
|
|
|
|
<div class="col-first even-row-color"><code>class </code></div>
|
|
|
|
<div class="col-second even-row-color"><code><a href="../Two.html" class="type-name-link" \
|
|
|
|
title="class in Unnamed Package">Two</a></code></div>
|
|
|
|
<div class="col-last even-row-color"> </div>
|
|
|
|
</div>
|
|
|
|
""");
|
|
|
|
}
|
2015-11-28 18:52:17 -08:00
|
|
|
}
|