/* * Copyright (c) 2020, 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 8246712 * @summary doclint incorrectly reports some HTML elements as empty * @modules jdk.javadoc/jdk.javadoc.internal.doclint * @library /tools/lib * @build toolbox.TestRunner toolbox.ToolBox * @run main EmptyHtmlTest
*/
publicstaticvoid main(String... args) throws Exception {
EmptyHtmlTest t = new EmptyHtmlTest();
t.runTests(m -> new Object[] { Path.of(m.getName()) });
}
public EmptyHtmlTest() { super(System.err);
}
ToolBox tb = new ToolBox();
/** * This test is intended to be future-proof, and hence detect any * problems in any inline tags added in the future. * Since there is not yet any mapping between DocTree.Kind and * the corresponding subtype DocTree (see javac Tree.Kind, Tree) * the list of all current inline tag classes is determined by * scanning DocTreeVisitor. * * @param base working directory for the test case * @throws Exception if an error occurs
*/
@Test publicvoid testInlines(Path base) throws Exception { Class<DocTreeVisitor> c = DocTreeVisitor.class; for (Method m : c.getDeclaredMethods()) { if (m.getName().startsWith("visit") && m.getParameterCount() == 2) { Class<?>[] paramTypes = m.getParameterTypes(); Class<?> firstParamType = paramTypes[0]; if (InlineTagTree.class.isAssignableFrom(firstParamType)) {
testInline(base, firstParamType);
}
}
}
}
void testInline(Path base, Class<?> type) throws Exception { // the following can eventually be converted to instanceof pattern switch
Path d = Files.createDirectories(base.resolve(type.getSimpleName())); switch (type.getSimpleName()) { case"DocRootTree" ->
test(d, type, "{@docRoot}");
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.