test/com/sun/javadoc/testValueTag/TestValueTag.java

Wed, 08 Oct 2014 14:16:40 -0700

author
asaha
date
Wed, 08 Oct 2014 14:16:40 -0700
changeset 2586
f5e5ca7505e2
parent 2147
130b8c0e570e
child 2525
2eb010b6cb22
permissions
-rw-r--r--

Merge

duke@1 1 /*
jjg@1490 2 * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
duke@1 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@1 4 *
duke@1 5 * This code is free software; you can redistribute it and/or modify it
duke@1 6 * under the terms of the GNU General Public License version 2 only, as
duke@1 7 * published by the Free Software Foundation.
duke@1 8 *
duke@1 9 * This code is distributed in the hope that it will be useful, but WITHOUT
duke@1 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@1 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@1 12 * version 2 for more details (a copy is included in the LICENSE file that
duke@1 13 * accompanied this code).
duke@1 14 *
duke@1 15 * You should have received a copy of the GNU General Public License version
duke@1 16 * 2 along with this work; if not, write to the Free Software Foundation,
duke@1 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@1 18 *
ohair@554 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
ohair@554 20 * or visit www.oracle.com if you need additional information or have any
ohair@554 21 * questions.
duke@1 22 */
duke@1 23
duke@1 24 /*
duke@1 25 * @test
bpatel@2147 26 * @bug 4764045 8004825 8026567
duke@1 27 * @summary This test ensures that the value tag works in all
duke@1 28 * use cases. The explainations for each test case are written below.
duke@1 29 * @author jamieh
duke@1 30 * @library ../lib/
bpatel@2062 31 * @build JavadocTester TestValueTag
duke@1 32 * @run main TestValueTag
duke@1 33 */
duke@1 34
duke@1 35 public class TestValueTag extends JavadocTester {
duke@1 36
duke@1 37 //Test information.
duke@1 38 private static final String BUG_ID = "4764045";
duke@1 39
duke@1 40 //Javadoc arguments.
duke@1 41 private static final String[] ARGS =
duke@1 42 new String[] {
bpatel@2062 43 "-d", BUG_ID, "-sourcepath", SRC_DIR, "-tag",
bpatel@2062 44 "todo", "pkg1", "pkg2"
bpatel@2062 45 };
bpatel@2062 46
bpatel@2062 47 private static final String[] ARGS1 =
bpatel@2062 48 new String[] {
jjg@1490 49 "-Xdoclint:none",
bpatel@2062 50 "-d", BUG_ID + "-1", "-sourcepath", SRC_DIR, "-tag",
duke@1 51 "todo", "pkg1", "pkg2"
duke@1 52 };
duke@1 53
duke@1 54 //Input for string search tests.
duke@1 55 private static final String[][] TEST = {
duke@1 56 //Base case: using @value on a constant.
duke@1 57 {BUG_ID + FS + "pkg1" + FS + "Class1.html",
duke@1 58 "Result: \"Test 1 passes\""},
duke@1 59 //Retrieve value of constant in same class.
duke@1 60 {BUG_ID + FS + "pkg1" + FS + "Class1.html",
bpatel@766 61 "Result: <a href=\"../pkg1/Class1.html#TEST_2_PASSES\">\"Test 2 passes\"</a>"},
duke@1 62 {BUG_ID + FS + "pkg1" + FS + "Class1.html",
bpatel@766 63 "Result: <a href=\"../pkg1/Class1.html#TEST_3_PASSES\">\"Test 3 passes\"</a>"},
duke@1 64 {BUG_ID + FS + "pkg1" + FS + "Class1.html",
bpatel@766 65 "Result: <a href=\"../pkg1/Class1.html#TEST_4_PASSES\">\"Test 4 passes\"</a>"},
duke@1 66 {BUG_ID + FS + "pkg1" + FS + "Class1.html",
bpatel@766 67 "Result: <a href=\"../pkg1/Class1.html#TEST_5_PASSES\">\"Test 5 passes\"</a>"},
duke@1 68 {BUG_ID + FS + "pkg1" + FS + "Class1.html",
bpatel@766 69 "Result: <a href=\"../pkg1/Class1.html#TEST_6_PASSES\">\"Test 6 passes\"</a>"},
duke@1 70 //Retrieve value of constant in different class.
duke@1 71 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 72 "Result: <a href=\"../pkg1/Class1.html#TEST_7_PASSES\">\"Test 7 passes\"</a>"},
duke@1 73 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 74 "Result: <a href=\"../pkg1/Class1.html#TEST_8_PASSES\">\"Test 8 passes\"</a>"},
duke@1 75 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 76 "Result: <a href=\"../pkg1/Class1.html#TEST_9_PASSES\">\"Test 9 passes\"</a>"},
duke@1 77 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 78 "Result: <a href=\"../pkg1/Class1.html#TEST_10_PASSES\">\"Test 10 passes\"</a>"},
duke@1 79 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 80 "Result: <a href=\"../pkg1/Class1.html#TEST_11_PASSES\">\"Test 11 passes\"</a>"},
duke@1 81 //Retrieve value of constant in different package
duke@1 82 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 83 "Result: <a href=\"../pkg2/Class3.html#TEST_12_PASSES\">\"Test 12 passes\"</a>"},
duke@1 84 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 85 "Result: <a href=\"../pkg2/Class3.html#TEST_13_PASSES\">\"Test 13 passes\"</a>"},
duke@1 86 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 87 "Result: <a href=\"../pkg2/Class3.html#TEST_14_PASSES\">\"Test 14 passes\"</a>"},
duke@1 88 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 89 "Result: <a href=\"../pkg2/Class3.html#TEST_15_PASSES\">\"Test 15 passes\"</a>"},
duke@1 90 {BUG_ID + FS + "pkg1" + FS + "Class2.html",
bpatel@766 91 "Result: <a href=\"../pkg2/Class3.html#TEST_16_PASSES\">\"Test 16 passes\"</a>"},
duke@1 92 //Retrieve value of constant from a package page
duke@1 93 {BUG_ID + FS + "pkg2" + FS + "package-summary.html",
bpatel@766 94 "Result: <a href=\"../pkg2/Class3.html#TEST_17_PASSES\">\"Test 17 passes\"</a>"},
duke@1 95 //Test @value tag used with custom tag.
duke@1 96 {BUG_ID + FS + "pkg1" + FS + "CustomTagUsage.html",
bpatel@2147 97 "<dt><span class=\"simpleTagLabel\">Todo:</span></dt>" + NL +
jjg@1743 98 "<dd>the value of this constant is 55.</dd>"},
bpatel@2062 99 //Test @value errors printed dues to invalid use or when used with
bpatel@2062 100 //non-constant or with bad references.
bpatel@2062 101 {ERROR_OUTPUT,"error: value does not refer to a constant" + NL +
bpatel@2062 102 " * Result: {@value TEST_12_ERROR}"
bpatel@2062 103 },
bpatel@2062 104 {ERROR_OUTPUT,"error: {@value} not allowed here" + NL +
bpatel@2062 105 " * Result: {@value}"
bpatel@2062 106 },
bpatel@2062 107 {ERROR_OUTPUT,"error: value does not refer to a constant" + NL +
bpatel@2062 108 " * Result: {@value NULL}"
bpatel@2062 109 },
bpatel@2062 110 {ERROR_OUTPUT,"error: {@value} not allowed here" + NL +
bpatel@2062 111 " * Invalid (null): {@value}"
bpatel@2062 112 },
bpatel@2062 113 {ERROR_OUTPUT,"error: {@value} not allowed here" + NL +
bpatel@2062 114 " * Invalid (non-constant field): {@value}"
bpatel@2062 115 },
bpatel@2062 116 {ERROR_OUTPUT,"error: value does not refer to a constant" + NL +
bpatel@2062 117 " * Here is a bad value reference: {@value UnknownClass#unknownConstant}"
bpatel@2062 118 },
bpatel@2062 119 {ERROR_OUTPUT,"error: reference not found" + NL +
bpatel@2062 120 " * Here is a bad value reference: {@value UnknownClass#unknownConstant}"
bpatel@2062 121 },
bpatel@2062 122 {ERROR_OUTPUT,"error: {@value} not allowed here" + NL +
bpatel@2062 123 " * @todo the value of this constant is {@value}"
bpatel@2062 124 }
bpatel@2062 125 };
bpatel@2062 126 private static final String[][] TEST1 = {
duke@1 127 //Test @value warning printed when used with non-constant.
duke@1 128 {WARNING_OUTPUT,"warning - @value tag (which references nonConstant) " +
duke@1 129 "can only be used in constants."
duke@1 130 },
bpatel@2062 131 {WARNING_OUTPUT,"warning - @value tag (which references NULL) " +
bpatel@2062 132 "can only be used in constants."
bpatel@2062 133 },
bpatel@2062 134 {WARNING_OUTPUT,"warning - @value tag (which references TEST_12_ERROR) " +
bpatel@2062 135 "can only be used in constants."
bpatel@2062 136 },
duke@1 137 //Test warning printed for bad reference.
duke@1 138 {WARNING_OUTPUT,"warning - UnknownClass#unknownConstant (referenced by " +
duke@1 139 "@value tag) is an unknown reference."
duke@1 140 },
bpatel@2062 141 //Test warning printed for invalid use of @value.
bpatel@2062 142 {WARNING_OUTPUT,"warning - @value tag cannot be used here."
bpatel@2062 143 }
duke@1 144 };
bpatel@2062 145 private static final String[][] NEGATED_TEST = {
bpatel@2062 146 //Base case: using @value on a constant.
bpatel@2062 147 {BUG_ID + FS + "pkg1" + FS + "Class1.html",
bpatel@2062 148 "Result: <a href=\"../pkg1/Class1.html#TEST_12_ERROR\">\"Test 12 " +
bpatel@2062 149 "generates an error message\"</a>"},
bpatel@2062 150 };
duke@1 151
duke@1 152 /**
duke@1 153 * The entry point of the test.
duke@1 154 * @param args the array of command line arguments.
duke@1 155 */
duke@1 156 public static void main(String[] args) {
duke@1 157 TestValueTag tester = new TestValueTag();
duke@1 158 run(tester, ARGS, TEST, NEGATED_TEST);
bpatel@2062 159 checkForException(tester);
bpatel@2062 160 run(tester, ARGS1, TEST1, NO_TEST);
bpatel@2062 161 checkForException(tester);
duke@1 162 tester.printSummary();
duke@1 163 }
duke@1 164
bpatel@2062 165 public static void checkForException(TestValueTag tester) {
bpatel@2062 166 if (tester.getErrorOutput().contains("DocletAbortException")) {
bpatel@2062 167 throw new AssertionError("javadoc threw DocletAbortException");
bpatel@2062 168 }
bpatel@2062 169 }
bpatel@2062 170
duke@1 171 /**
duke@1 172 * {@inheritDoc}
duke@1 173 */
duke@1 174 public String getBugId() {
duke@1 175 return BUG_ID;
duke@1 176 }
duke@1 177
duke@1 178 /**
duke@1 179 * {@inheritDoc}
duke@1 180 */
duke@1 181 public String getBugName() {
duke@1 182 return getClass().getName();
duke@1 183 }
duke@1 184 }

mercurial