8292892: Javadoc index descriptions are not deterministic
Reviewed-by: jjg
This commit is contained in:
parent
8d1dd6a6cf
commit
844a95b907
@ -131,7 +131,7 @@ public class HtmlIndexBuilder extends IndexBuilder {
|
||||
case FIELD:
|
||||
case ENUM_CONSTANT:
|
||||
TypeElement containingType = item.getContainingTypeElement();
|
||||
item.setContainingPackage(utils.getPackageName(utils.containingPackage(element)));
|
||||
item.setContainingPackage(utils.getPackageName(utils.containingPackage(containingType)));
|
||||
item.setContainingClass(utils.getSimpleName(containingType));
|
||||
if (configuration.showModules && addModuleInfo) {
|
||||
item.setContainingModule(utils.getFullyQualifiedName(utils.containingModule(element)));
|
||||
|
@ -327,7 +327,20 @@ public class IndexBuilder {
|
||||
return (ii1, ii2) -> {
|
||||
// If both are element items, compare the elements
|
||||
if (ii1.isElementItem() && ii2.isElementItem()) {
|
||||
return elementComparator.compare(ii1.getElement(), ii2.getElement());
|
||||
int d = elementComparator.compare(ii1.getElement(), ii2.getElement());
|
||||
if (d == 0) {
|
||||
/*
|
||||
* Members inherited from classes with package access are
|
||||
* documented as though they were declared in the inheriting
|
||||
* subclass (see JDK-4780441).
|
||||
*/
|
||||
Element subclass1 = ii1.getContainingTypeElement();
|
||||
Element subclass2 = ii2.getContainingTypeElement();
|
||||
if (subclass1 != null && subclass2 != null) {
|
||||
d = elementComparator.compare(subclass1, subclass2);
|
||||
}
|
||||
}
|
||||
return d;
|
||||
}
|
||||
|
||||
// If one is an element item, compare labels; if equal, put element item last
|
||||
|
@ -0,0 +1,167 @@
|
||||
/*
|
||||
* Copyright (c) 2022, 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 8292892
|
||||
* @summary Tests that members inherited from classes with package access are
|
||||
* documented in the index as though they were declared in the
|
||||
* inheriting class.
|
||||
* @library ../../lib
|
||||
* @modules jdk.javadoc/jdk.javadoc.internal.tool
|
||||
* @build javadoc.tester.*
|
||||
* @run main TestIndexInherited
|
||||
*/
|
||||
import java.nio.file.Path;
|
||||
import javadoc.tester.JavadocTester;
|
||||
|
||||
/**
|
||||
* Tests the index for members inherited from a class with package access.
|
||||
*/
|
||||
public class TestIndexInherited extends JavadocTester {
|
||||
|
||||
/**
|
||||
* Name of the HTML index file.
|
||||
*/
|
||||
private static final String INDEX_FILE = "index-all.html";
|
||||
|
||||
/**
|
||||
* Name of the JavaScript member search index file.
|
||||
*/
|
||||
private static final String SEARCH_FILE = "member-search-index.js";
|
||||
|
||||
/**
|
||||
* Index entries for members inherited by the subclasses.
|
||||
*/
|
||||
private static final String[] INDEX_INHERITED = {"""
|
||||
<dt><a href="pkg1/ClassB.html#methodA()" class="member-name-link">methodA()</a> \
|
||||
- Method in class pkg1.<a href="pkg1/ClassB.html" title="class in pkg1">ClassB</a></dt>
|
||||
""", """
|
||||
<dt><a href="pkg2/ClassC.html#methodA()" class="member-name-link">methodA()</a> \
|
||||
- Method in class pkg2.<a href="pkg2/ClassC.html" title="class in pkg2">ClassC</a></dt>
|
||||
""", """
|
||||
<dt><a href="pkg1/ClassB.html#STRING_A" class="member-name-link">STRING_A</a> \
|
||||
- Static variable in class pkg1.<a href="pkg1/ClassB.html" title="class in pkg1">ClassB</a></dt>
|
||||
""", """
|
||||
<dt><a href="pkg2/ClassC.html#STRING_A" class="member-name-link">STRING_A</a> \
|
||||
- Static variable in class pkg2.<a href="pkg2/ClassC.html" title="class in pkg2">ClassC</a></dt>
|
||||
"""};
|
||||
|
||||
/**
|
||||
* Search entries for members inherited by the subclasses.
|
||||
*/
|
||||
private static final String[] SEARCH_INHERITED = {"""
|
||||
{"p":"pkg1","c":"ClassB","l":"methodA()"}""", """
|
||||
{"p":"pkg2","c":"ClassC","l":"methodA()"}""", """
|
||||
{"p":"pkg1","c":"ClassB","l":"STRING_A"}""", """
|
||||
{"p":"pkg2","c":"ClassC","l":"STRING_A"}"""};
|
||||
|
||||
/**
|
||||
* Index entries for members declared by the superclass.
|
||||
*/
|
||||
private static final String[] INDEX_DECLARED = {"""
|
||||
<dt><a href="pkg1/ClassA.html#methodA()" class="member-name-link">methodA()</a> \
|
||||
- Method in interface pkg1.<a href="pkg1/ClassA.html" title="interface in pkg1">ClassA</a></dt>
|
||||
""", """
|
||||
<dt><a href="pkg1/ClassA.html#STRING_A" class="member-name-link">STRING_A</a> \
|
||||
- Static variable in interface pkg1.<a href="pkg1/ClassA.html" title="interface in pkg1">ClassA</a></dt>
|
||||
"""};
|
||||
|
||||
/**
|
||||
* Search entries for members declared by the superclass.
|
||||
*/
|
||||
private static final String[] SEARCH_DECLARED = {"""
|
||||
{"p":"pkg1","c":"ClassA","l":"methodA()"}""", """
|
||||
{"p":"pkg1","c":"ClassA","l":"STRING_A"}"""};
|
||||
|
||||
/**
|
||||
* Sole constructor.
|
||||
*/
|
||||
public TestIndexInherited() {
|
||||
}
|
||||
|
||||
/**
|
||||
* Runs the test methods.
|
||||
*
|
||||
* @param args the command-line arguments
|
||||
* @throws Exception if an errors occurs while executing a test method
|
||||
*/
|
||||
public static void main(String... args) throws Exception {
|
||||
var tester = new TestIndexInherited();
|
||||
tester.runTests();
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks that the index includes the inherited members of both public
|
||||
* subclasses, loaded in alphabetical order, and that there is absolutely no
|
||||
* mention of the non-public superclass.
|
||||
*
|
||||
* @param base the base directory for this method's output
|
||||
*/
|
||||
@Test
|
||||
public void testForInherited1(Path base) {
|
||||
String dir = base.resolve("out").toString();
|
||||
javadoc("-d", dir, "-sourcepath", testSrc, "pkg1", "pkg2");
|
||||
checkExit(Exit.OK);
|
||||
checkOrder(INDEX_FILE, INDEX_INHERITED);
|
||||
checkOrder(SEARCH_FILE, SEARCH_INHERITED);
|
||||
checkOutput(INDEX_FILE, false, "ClassA");
|
||||
checkOutput(SEARCH_FILE, false, "ClassA");
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks that the index includes the inherited members of both public
|
||||
* subclasses, loaded in reverse alphabetical order, and that there is
|
||||
* absolutely no mention of the non-public superclass.
|
||||
*
|
||||
* @param base the base directory for this method's output
|
||||
*/
|
||||
@Test
|
||||
public void testForInherited2(Path base) {
|
||||
String dir = base.resolve("out").toString();
|
||||
javadoc("-d", dir, "-sourcepath", testSrc, "pkg2", "pkg1");
|
||||
checkExit(Exit.OK);
|
||||
checkOrder(INDEX_FILE, INDEX_INHERITED);
|
||||
checkOrder(SEARCH_FILE, SEARCH_INHERITED);
|
||||
checkOutput(INDEX_FILE, false, "ClassA");
|
||||
checkOutput(SEARCH_FILE, false, "ClassA");
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks that the index includes the declared members of the non-public
|
||||
* superclass when the Javadoc <i>private</i> option is specified, and that
|
||||
* it no longer includes the inherited members of either public subclass.
|
||||
*
|
||||
* @param base the base directory for this method's output
|
||||
*/
|
||||
@Test
|
||||
public void testForDeclared(Path base) {
|
||||
String dir = base.resolve("out").toString();
|
||||
javadoc("-d", dir, "-sourcepath", testSrc, "-private", "pkg1", "pkg2");
|
||||
checkExit(Exit.OK);
|
||||
checkOrder(INDEX_FILE, INDEX_DECLARED);
|
||||
checkOrder(SEARCH_FILE, SEARCH_DECLARED);
|
||||
checkOutput(INDEX_FILE, false, INDEX_INHERITED);
|
||||
checkOutput(SEARCH_FILE, false, SEARCH_INHERITED);
|
||||
}
|
||||
}
|
@ -0,0 +1,41 @@
|
||||
/*
|
||||
* Copyright (c) 2022, 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.
|
||||
*/
|
||||
package pkg1;
|
||||
|
||||
/**
|
||||
* A class with package access, inaccessible to classes outside its package.
|
||||
*/
|
||||
interface ClassA {
|
||||
|
||||
/**
|
||||
* A string constant with package access.
|
||||
*/
|
||||
static final String STRING_A = "A string in pkg1 with package access.";
|
||||
|
||||
/**
|
||||
* A method with package access.
|
||||
*/
|
||||
default void methodA() {
|
||||
System.out.println(ClassA.class.getName() + ": " + STRING_A);
|
||||
}
|
||||
}
|
@ -0,0 +1,42 @@
|
||||
/*
|
||||
* Copyright (c) 2022, 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.
|
||||
*/
|
||||
package pkg1;
|
||||
|
||||
/**
|
||||
* A public subclass in the same package as its superclass.
|
||||
*/
|
||||
public class ClassB implements ClassA {
|
||||
|
||||
/**
|
||||
* The sole constructor.
|
||||
*/
|
||||
public ClassB() {
|
||||
}
|
||||
|
||||
/**
|
||||
* A public method.
|
||||
*/
|
||||
public void methodB() {
|
||||
System.out.println(ClassB.class.getName() + ": " + STRING_A);
|
||||
}
|
||||
}
|
@ -0,0 +1,55 @@
|
||||
/*
|
||||
* Copyright (c) 2022, 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.
|
||||
*/
|
||||
package pkg2;
|
||||
|
||||
import pkg1.ClassB;
|
||||
|
||||
/**
|
||||
* A public subclass in a different package than its superclass.
|
||||
*/
|
||||
public class ClassC extends ClassB {
|
||||
|
||||
/**
|
||||
* The sole constructor.
|
||||
*/
|
||||
public ClassC() {
|
||||
}
|
||||
|
||||
/**
|
||||
* A public method.
|
||||
*/
|
||||
public void methodC() {
|
||||
methodA();
|
||||
methodB();
|
||||
System.out.println(ClassC.class.getName() + ": " + STRING_A);
|
||||
}
|
||||
|
||||
/**
|
||||
* The main method.
|
||||
*
|
||||
* @param args the command-line arguments
|
||||
*/
|
||||
public static void main(String[] args) {
|
||||
new ClassC().methodC();
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user