/*
* Copyright (c) 2015, 2018, 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 8141492 8071982 8141636 8147890 8166175 8168965 8176794 8175218 8147881
* 8181622 8182263 8074407 8187521 8198522
* @summary Test the search feature of javadoc.
* @author bpatel
* @library ../lib
* @modules jdk.javadoc/jdk.javadoc.internal.tool
* @build JavadocTester
* @run main TestSearch
*/
public class TestSearch extends JavadocTester {
public static void main(String... args) throws Exception {
TestSearch tester = new TestSearch();
tester.runTests();
}
@Test
void test1() {
javadoc("-d", "out-1", "-sourcepath", "-use", testSrc("UnnamedPkgClass.java"));
checkExit(Exit.OK);
checkSearchOutput("UnnamedPkgClass.html", true, true);
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(false,
"package-search-index.zip",
"tag-search-index.zip",
"package-search-index.js",
"tag-search-index.js");
checkFiles(true,
"member-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"type-search-index.js");
}
@Test
void test2() {
javadoc("-d", "out-2", "-Xdoclint:none", "-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkInvalidUsageIndexTag();
checkSearchOutput(true);
checkSingleIndex(true, false);
checkSingleIndexSearchTagDuplication();
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(true,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js");
}
@Test
void test2a() {
javadoc("-d", "out-2a", "-Xdoclint:all", "-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.ERROR);
checkDocLintErrors();
checkSearchOutput(true);
checkSingleIndex(true, false);
checkSingleIndexSearchTagDuplication();
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(true,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js");
}
@Test
void test3() {
javadoc("-d", "out-3", "-noindex", "-Xdoclint:none",
"-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkSearchOutput(false);
checkJqueryAndImageFiles(false);
checkFiles(false,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js",
"index-all.html");
}
@Test
void test4() {
javadoc("-d", "out-4", "-html5", "-Xdoclint:none",
"-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkSearchOutput(true);
checkSingleIndex(true, true);
checkSingleIndexSearchTagDuplication();
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(true,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js");
}
@Test
void test5() {
javadoc("-d", "out-5", "-noindex", "-html5", "-Xdoclint:none",
"-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkSearchOutput(false);
checkJqueryAndImageFiles(false);
checkFiles(false,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js",
"index-all.html");
}
@Test
void test6() {
javadoc("-d", "out-6", "-nocomment", "-Xdoclint:none",
"-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkSearchOutput(true);
checkIndexNoComment();
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(true,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js");
}
@Test
void test7() {
javadoc("-d", "out-7", "-nodeprecated", "-Xdoclint:none",
"-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkSearchOutput(true);
checkIndexNoDeprecated();
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(true,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js");
}
@Test
void test8() {
javadoc("-d", "out-8", "-splitindex", "-Xdoclint:none", "-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkInvalidUsageIndexTag();
checkSearchOutput(true);
checkSplitIndex();
checkSplitIndexSearchTagDuplication();
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(true,
"member-search-index.zip",
"package-search-index.zip",
"tag-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"tag-search-index.js",
"type-search-index.js");
}
@Test
void test9() {
javadoc("-d", "out-9", "-sourcepath", testSrc, "-javafx", "-package",
"-use", "pkgfx", "pkg3");
checkExit(Exit.OK);
checkSearchOutput(true);
checkJavaFXOutput();
checkJqueryAndImageFiles(true);
checkSearchJS();
checkFiles(false,
"tag-search-index.zip",
"tag-search-index.js");
checkFiles(true,
"member-search-index.zip",
"package-search-index.zip",
"type-search-index.zip",
"member-search-index.js",
"package-search-index.js",
"type-search-index.js");
}
@Test
void testNoModuleDirectories() {
javadoc("-d", "out-noMdlDir", "--no-module-directories", "-Xdoclint:none",
"-sourcepath", testSrc,
"-use", "pkg", "pkg1", "pkg2", "pkg3");
checkExit(Exit.OK);
checkSearchOutput(true, false);
checkSearchJS();
}
void checkDocLintErrors() {
checkOutput(Output.OUT, true,
"A sample method. Testing search tag for {@index \"unclosed quote}.",
"Another test class. Testing empty {@index }.",
"Constant field. Testing no text in index tag {@index}.",
"A test field. Testing only white-spaces in index tag text {@index }.");
}
void checkSearchOutput(boolean expectedOutput) {
checkSearchOutput("overview-summary.html", expectedOutput, true);
}
void checkSearchOutput(boolean expectedOutput, boolean moduleDirectoriesVar) {
checkSearchOutput("overview-summary.html", expectedOutput, moduleDirectoriesVar);
}
void checkSearchOutput(String fileName, boolean expectedOutput, boolean moduleDirectoriesVar) {
// Test for search related markup
checkOutput(fileName, expectedOutput,
" \n",
"\n",
"\n",
"\n",
"\n",
"",
"var pathtoroot = \"./\";\n"
+ "var useModuleDirectories = " + moduleDirectoriesVar + ";\n"
+ "loadScripts(document, 'script');",
"
\n",
"SEARCH: \n"
+ " \n"
+ " \n");
checkOutput(fileName, true,
"");
}
void checkSingleIndex(boolean expectedOutput, boolean html5) {
String html_span_see_span = html5 ? "html%3Cspan%3Esee%3C/span%3E" : "html-span-see-/span-";
// Test for search tags markup in index file.
checkOutput("index-all.html", expectedOutput,
"
"
+ "phrase with spaces - Search tag in pkg",
"
"
+ "pkg - Search tag in pkg",
"
"
+ "pkg2.5 - Search tag in pkg",
"
"
+ "r - Search tag in pkg",
"
"
+ "search phrase - Search tag in pkg1.RegClass",
"
"
+ "SearchWordWithDescription - Search tag in pkg1.RegClass.CONSTANT_FIELD_1",
"
"
+ "search phrase with desc deprecated - Search tag in pkg2.TestAnnotationType",
"
"
+ "SearchTagDeprecatedClass - Search tag in pkg2.TestClass",
"
"
+ "search phrase deprecated - Search tag in pkg2.TestEnum.ONE",
"
"
+ "search phrase deprecated - Search tag in pkg2.TestEnum.ONE",
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError",
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError",
"
"
+ "SingleWord - Search tag in pkg",
"
nested {@index nested_tag_test} - "
+ "Search tag in pkg.AnotherClass.ModalExclusionType.NO_EXCLUDE",
"
html <span> see </span> - Search "
+ "tag in pkg.AnotherClass.ModalExclusionType.APPLICATION_EXCLUDE",
"
quoted "
+ " - Search tag in pkg.AnotherClass.CONSTANT1",
"
ONE - "
+ "pkg2.TestEnum ",
"
THREE - "
+ "pkg2.TestEnum ",
"
TWO - "
+ "pkg2.TestEnum ");
checkOutput("index-all.html", true,
"",
"");
}
void checkSplitIndex() {
// Test for search tags markup in split index file.
checkOutput("index-files/index-13.html", true,
"
"
+ "search phrase - Search tag in pkg1.RegClass",
"
"
+ "SearchWordWithDescription - Search tag in pkg1.RegClass.CONSTANT_FIELD_1",
"
"
+ "search phrase with desc deprecated - Search tag in pkg2.TestAnnotationType",
"
"
+ "SearchTagDeprecatedClass - Search tag in pkg2.TestClass",
"
"
+ "search phrase deprecated - Search tag in pkg2.TestEnum.ONE",
"
"
+ "search phrase deprecated - Search tag in pkg2.TestEnum.ONE",
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError",
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError",
"
"
+ "SingleWord - Search tag in pkg");
checkOutput("index-files/index-10.html", true,
"
"
+ "phrase with spaces - Search tag in pkg",
"
"
+ "pkg - Search tag in pkg",
"
"
+ "pkg2.5 - Search tag in pkg");
checkOutput("index-files/index-12.html", true,
"
"
+ "r - Search tag in pkg");
checkOutput("index-files/index-8.html", true,
"
nested {@index nested_tag_test} - "
+ "Search tag in pkg.AnotherClass.ModalExclusionType.NO_EXCLUDE");
checkOutput("index-files/index-5.html", true,
"
html <span> see </span> - Search "
+ "tag in pkg.AnotherClass.ModalExclusionType.APPLICATION_EXCLUDE");
checkOutput("index-files/index-11.html", true,
"
quoted "
+ " - Search tag in pkg.AnotherClass.CONSTANT1");
checkOutput("index-files/index-9.html", true,
"
ONE "
+ " - pkg2.TestEnum ");
checkOutput("index-files/index-14.html", true,
"
THREE - "
+ "pkg2.TestEnum ",
"
TWO - "
+ "pkg2.TestEnum ");
}
void checkIndexNoComment() {
// Test for search tags markup in index file when javadoc is executed with -nocomment.
checkOutput("index-all.html", false,
"
"
+ "phrase with spaces - Search tag in pkg",
"
"
+ "pkg - Search tag in pkg",
"
"
+ "pkg2.5 - Search tag in pkg",
"
"
+ "r - Search tag in pkg",
"
"
+ "search phrase - Search tag in pkg1.RegClass",
"
"
+ "SearchWordWithDescription - Search tag in pkg1.RegClass.CONSTANT_FIELD_1",
"
"
+ "search phrase with desc deprecated - Search tag in pkg2.TestAnnotationType",
"
"
+ "SearchTagDeprecatedClass - Search tag in pkg2.TestClass",
"
"
+ "SingleWord - Search tag in pkg",
"",
"");
checkOutput("index-all.html", true,
"
"
+ "search phrase deprecated - Search tag in pkg2.TestEnum.ONE",
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError");
}
void checkIndexNoDeprecated() {
// Test for search tags markup in index file when javadoc is executed using -nodeprecated.
checkOutput("index-all.html", true,
"
"
+ "phrase with spaces - Search tag in pkg",
"
"
+ "search phrase - Search tag in pkg1.RegClass",
"
"
+ "SearchWordWithDescription - Search tag in pkg1.RegClass.CONSTANT_FIELD_1",
"
"
+ "SingleWord - Search tag in pkg");
checkOutput("index-all.html", false,
"
"
+ "search phrase with desc deprecated - Search tag in pkg2.TestAnnotationType",
"
"
+ "SearchTagDeprecatedClass - Search tag in pkg2.TestClass",
"
"
+ "search phrase deprecated - Search tag in pkg2.TestEnum.ONE",
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError",
"",
"");
}
void checkJavaFXOutput() {
checkOutput("index-all.html", false, "test treat as private");
}
void checkInvalidUsageIndexTag() {
checkOutput(Output.OUT, true,
"AnotherClass.java:29: warning - invalid usage of tag {@index",
"AnotherClass.java:41: warning - invalid usage of tag {@index",
"AnotherClass.java:36: warning - invalid usage of tag {@index",
"AnotherClass.java:70: warning - invalid usage of tag {@index");
}
void checkJqueryAndImageFiles(boolean expectedOutput) {
checkFiles(expectedOutput,
"search.js",
"jquery/jquery-1.10.2.js",
"jquery/jquery-ui.js",
"jquery/jquery-ui.css",
"jquery/jquery-ui.min.js",
"jquery/jquery-ui.min.css",
"jquery/jquery-ui.structure.min.css",
"jquery/jquery-ui.structure.css",
"jquery/external/jquery/jquery.js",
"jquery/jszip/dist/jszip.js",
"jquery/jszip/dist/jszip.min.js",
"jquery/jszip-utils/dist/jszip-utils.js",
"jquery/jszip-utils/dist/jszip-utils.min.js",
"jquery/jszip-utils/dist/jszip-utils-ie.js",
"jquery/jszip-utils/dist/jszip-utils-ie.min.js",
"jquery/images/ui-bg_flat_0_aaaaaa_40x100.png",
"jquery/images/ui-icons_454545_256x240.png",
"jquery/images/ui-bg_glass_95_fef1ec_1x400.png",
"jquery/images/ui-bg_glass_75_dadada_1x400.png",
"jquery/images/ui-bg_highlight-soft_75_cccccc_1x100.png",
"jquery/images/ui-icons_888888_256x240.png",
"jquery/images/ui-icons_2e83ff_256x240.png",
"jquery/images/ui-bg_glass_65_ffffff_1x400.png",
"jquery/images/ui-icons_cd0a0a_256x240.png",
"jquery/images/ui-bg_glass_55_fbf9ee_1x400.png",
"jquery/images/ui-icons_222222_256x240.png",
"jquery/images/ui-bg_glass_75_e6e6e6_1x400.png",
"jquery/images/ui-bg_flat_75_ffffff_40x100.png",
"resources/x.png",
"resources/glass.png");
}
void checkSearchJS() {
checkOutput("search.js", true,
"camelCaseRegexp = ($.ui.autocomplete.escapeRegex(request.term)).split(/(?=[A-Z])/).join(\"([a-z0-9_$]*?)\");",
"var camelCaseMatcher = new RegExp(\"^\" + camelCaseRegexp);",
"camelCaseMatcher.test(item.l)",
"var secondaryresult = new Array();",
"function nestedName(e) {",
"function sortAndConcatResults(a1, a2) {",
"if (exactMatcher.test(item.l)) {\n"
+ " presult.unshift(item);",
"$(\"#search\").on('click keydown', function() {\n"
+ " if ($(this).val() == watermark) {\n"
+ " $(this).val('').removeClass('watermark');\n"
+ " }\n"
+ " });",
"function getURLPrefix(ui) {\n"
+ " var urlPrefix=\"\";\n"
+ " if (useModuleDirectories) {\n"
+ " var slash = \"/\";\n"
+ " if (ui.item.category === catModules) {\n"
+ " return ui.item.l + slash;\n"
+ " } else if (ui.item.category === catPackages) {\n"
+ " return ui.item.m + slash;\n"
+ " } else if (ui.item.category === catTypes || ui.item.category === catMembers) {\n"
+ " $.each(packageSearchIndex, function(index, item) {\n"
+ " if (ui.item.p == item.l) {\n"
+ " urlPrefix = item.m + slash;\n"
+ " }\n"
+ " });\n"
+ " return urlPrefix;\n"
+ " }\n"
+ " }\n"
+ " return urlPrefix;\n"
+ "}");
}
void checkSingleIndexSearchTagDuplication() {
// Test for search tags duplication in index file.
checkOutput("index-all.html", true,
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError\n"
+ "
with description ");
checkOutput("index-all.html", false,
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError\n"
+ "
with description \n"
+ "
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError\n"
+ "
with description ");
}
void checkSplitIndexSearchTagDuplication() {
// Test for search tags duplication in index file.
checkOutput("index-files/index-13.html", true,
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError\n"
+ "
with description ");
checkOutput("index-files/index-13.html", false,
"
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError\n"
+ "
with description \n"
+ "
"
+ "SearchTagDeprecatedMethod - Search tag in pkg2.TestError\n"
+ "
with description ");
}
}