/*
* Copyright (c) 2012, 2013, 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 8005092
* @summary Test repeated annotations output.
* @author bpatel
* @library ../lib/
* @build JavadocTester TestRepeatedAnnotations
* @run main TestRepeatedAnnotations
*/
public class TestRepeatedAnnotations extends JavadocTester {
//Test information.
private static final String BUG_ID = "8005092";
//Javadoc arguments.
private static final String[] ARGS = new String[] {
"-d", BUG_ID, "-sourcepath", SRC_DIR, "pkg", "pkg1"
};
//Input for string search tests.
private static final String[][] TEST = {
{BUG_ID + FS + "pkg" + FS + "C.html",
"@ContaineeSynthDoc " +
"@ContaineeSynthDoc"},
{BUG_ID + FS + "pkg" + FS + "C.html",
"@ContaineeRegDoc " +
"@ContaineeRegDoc"},
{BUG_ID + FS + "pkg" + FS + "C.html",
"@RegContainerDoc" +
"(value={" +
"@RegContaineeNotDoc," +
"@RegContaineeNotDoc})"},
{BUG_ID + FS + "pkg" + FS + "C.html",
"@ContaineeSynthDoc " +
"@ContaineeSynthDoc " +
"@ContaineeSynthDoc"},
{BUG_ID + FS + "pkg" + FS + "C.html",
"@ContainerSynthDoc(" +
"value=" +
"@ContaineeSynthDoc)"},
{BUG_ID + FS + "pkg" + FS + "C.html",
"@ContaineeSynthDoc " +
"@ContaineeSynthDoc"},
{BUG_ID + FS + "pkg" + FS + "D.html",
"@RegDoc" +
"(x=1)"},
{BUG_ID + FS + "pkg" + FS + "D.html",
"@RegArryDoc" +
"(y=1)"},
{BUG_ID + FS + "pkg" + FS + "D.html",
"@RegArryDoc" +
"(y={1,2})"},
{BUG_ID + FS + "pkg" + FS + "D.html",
"@NonSynthDocContainer" +
"(value=" +
"@RegArryDoc)"},
{BUG_ID + FS + "pkg1" + FS + "C.html",
"@RegContainerValDoc" +
"(value={" +
"@RegContaineeNotDoc," +
"@RegContaineeNotDoc}," +
"y=3)"},
{BUG_ID + FS + "pkg1" + FS + "C.html",
"@ContainerValDoc" +
"(value={" +
"@ContaineeNotDoc," +
"@ContaineeNotDoc}," +
"x=1)"}
};
private static final String[][] NEGATED_TEST = {
{BUG_ID + FS + "pkg" + FS + "C.html",
"@RegContaineeDoc " +
"@RegContaineeDoc"},
{BUG_ID + FS + "pkg" + FS + "C.html",
"@RegContainerNotDoc" +
"(value={" +
"@RegContaineeNotDoc," +
"@RegContaineeNotDoc})"},
{BUG_ID + FS + "pkg1" + FS + "C.html",
"@ContaineeSynthDoc " +
"@ContaineeSynthDoc"},
{BUG_ID + FS + "pkg1" + FS + "C.html",
"@RegContainerValNotDoc" +
"(value={" +
"@RegContaineeDoc," +
"@RegContaineeDoc}," +
"y=4)"},
{BUG_ID + FS + "pkg1" + FS + "C.html",
"@ContainerValNotDoc" +
"(value={" +
"@ContaineeNotDoc," +
"@ContaineeNotDoc}," +
"x=2)"},
{BUG_ID + FS + "pkg1" + FS + "C.html",
"@ContainerSynthNotDoc(" +
"value=" +
"@ContaineeSynthDoc)"}
};
/**
* The entry point of the test.
* @param args the array of command line arguments.
*/
public static void main(String[] args) {
TestRepeatedAnnotations tester = new TestRepeatedAnnotations();
run(tester, ARGS, TEST, NEGATED_TEST);
tester.printSummary();
}
/**
* {@inheritDoc}
*/
public String getBugId() {
return BUG_ID;
}
/**
* {@inheritDoc}
*/
public String getBugName() {
return getClass().getName();
}
}