Hannes Wallnöfer e0c86884e5 8262992: Improve @see output
Reviewed-by: jjg
2021-05-07 10:45:48 +00:00

127 lines
5.9 KiB
Java

/*
* Copyright (c) 2017, 2021, 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 8176231 8189843 8182765 8203791
* @summary Test JavaFX property.
* @library ../../lib/
* @modules jdk.javadoc/jdk.javadoc.internal.tool
* @build javadoc.tester.* TestProperty
* @run main TestProperty
*/
import javadoc.tester.JavadocTester;
public class TestProperty extends JavadocTester {
public static void main(String... args) throws Exception {
TestProperty tester = new TestProperty();
tester.runTests();
}
@Test
public void testArrays() {
javadoc("-d", "out",
"--no-platform-links",
"-javafx",
"--disable-javafx-strict-checks",
"-sourcepath", testSrc,
"pkg");
checkExit(Exit.OK);
checkOutput("pkg/MyClass.html", true,
"""
<div class="member-signature"><span class="modifiers">public final</span>&nbsp;<\
span class="return-type"><a href="ObjectProperty.html" title="class in pkg">Obje\
ctProperty</a>&lt;<a href="MyObj.html" title="class in pkg">MyObj</a>&gt;</span>\
&nbsp;<span class="element-name">goodProperty</span></div>
<div class="block">This is an Object property where the Object is a single Object.</div>
<dl class="notes">
<dt>See Also:</dt>
<dd>
<ul class="see-list">
<li><a href="#getGood()"><code>getGood()</code></a></li>
<li><a href="#setGood(pkg.MyObj)"><code>setGood(MyObj)</code></a></li>
</ul>
</dd>
</dl>""",
"""
<div class="member-signature"><span class="modifiers">public final</span>&nbsp;<\
span class="return-type"><a href="ObjectProperty.html" title="class in pkg">Obje\
ctProperty</a>&lt;<a href="MyObj.html" title="class in pkg">MyObj</a>[]&gt;</spa\
n>&nbsp;<span class="element-name">badProperty</span></div>
<div class="block">This is an Object property where the Object is an array.</div>
<dl class="notes">
<dt>See Also:</dt>
<dd>
<ul class="see-list">
<li><a href="#getBad()"><code>getBad()</code></a></li>
<li><a href="#setBad(pkg.MyObj%5B%5D)"><code>setBad(MyObj[])</code></a></li>
</ul>
</dd>
</dl>""",
// no tab classes should be used in the property table
"""
<div class="col-first even-row-color"><code>final <a href="ObjectProperty.html" \
title="class in pkg">ObjectProperty</a>&lt;<a href="MyObj.html" title="class in \
pkg">MyObj</a>[]&gt;</code></div>
<div class="col-second even-row-color"><code><a href="#badProperty" class="membe\
r-name-link">bad</a></code></div>
<div class="col-last even-row-color">""",
// tab classes should be used in the method table
"""
<div class="col-first even-row-color method-summary-table method-summary-table-t\
ab2 method-summary-table-tab4"><code>final <a href="ObjectProperty.html" title="\
class in pkg">ObjectProperty</a>&lt;<a href="MyObj.html" title="class in pkg">My\
Obj</a>[]&gt;</code></div>
<div class="col-second even-row-color method-summary-table method-summary-table-\
tab2 method-summary-table-tab4"><code><a href="#badProperty()" class="member-nam\
e-link">badProperty</a>()</code></div>"""
);
checkOutput("pkg/MyClassT.html", true,
"""
<div class="member-signature"><span class="modifiers">public final</span>&nbsp;<\
span class="return-type"><a href="ObjectProperty.html" title="class in pkg">Obje\
ctProperty</a>&lt;java.util.List&lt;<a href="MyClassT.html" title="type paramete\
r in MyClassT">T</a>&gt;&gt;</span>&nbsp;<span class="element-name">listProperty</span><\
/div>
<div class="block">This is an Object property where the Object is a single <code>List&lt;T&gt;</code>.</div>
<dl class="notes">
<dt>See Also:</dt>
<dd>
<ul class="see-list">
<li><a href="#getList()"><code>getList()</code></a></li>
<li><a href="#setList(java.util.List)"><code>setList(List)</code></a></li>
</ul>
</dd>
</dl>"""
);
}
}