9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 */
23
24 /*
25 * @test
26 * @bug 8073056
27 * @summary Repeating annotations throws java.security.AccessControlException with a SecurityManager
28 *
29 * @library /lib/testlibrary
30 * @build jdk.testlibrary.Asserts
31 * @run main RepeatingWithSecurityManager
32 * @run main/othervm RepeatingWithSecurityManager "withSM"
33 */
34
35 import java.lang.annotation.*;
36 import java.util.*;
37
38 import jdk.testlibrary.Asserts;
39
40 public class RepeatingWithSecurityManager {
41 public static void main(String[] args) throws Exception {
42 if (args.length == 1) {
43 SecurityManager sm = new SecurityManager();
44 System.setSecurityManager(sm);
45 }
46
47 Asserts.assertTrue(TwoAnnotations.class.getAnnotationsByType(MyAnnotation.class).length == 2,
48 "Array should contain 2 annotations: " +
49 Arrays.toString(TwoAnnotations.class.getAnnotationsByType(MyAnnotation.class)));
50 }
51
52 @MyAnnotation(name = "foo")
53 @MyAnnotation(name = "bar")
54 private static class TwoAnnotations {
55 }
56
57 @Retention(RetentionPolicy.RUNTIME)
58 @interface MyAnnotations {
|
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 */
23
24 /*
25 * @test
26 * @bug 8073056
27 * @summary Repeating annotations throws java.security.AccessControlException with a SecurityManager
28 *
29 * @library /test/lib
30 * @build jdk.test.lib.Asserts
31 * @run main RepeatingWithSecurityManager
32 * @run main/othervm RepeatingWithSecurityManager "withSM"
33 */
34
35 import java.lang.annotation.*;
36 import java.util.*;
37
38 import jdk.test.lib.Asserts;
39
40 public class RepeatingWithSecurityManager {
41 public static void main(String[] args) throws Exception {
42 if (args.length == 1) {
43 SecurityManager sm = new SecurityManager();
44 System.setSecurityManager(sm);
45 }
46
47 Asserts.assertTrue(TwoAnnotations.class.getAnnotationsByType(MyAnnotation.class).length == 2,
48 "Array should contain 2 annotations: " +
49 Arrays.toString(TwoAnnotations.class.getAnnotationsByType(MyAnnotation.class)));
50 }
51
52 @MyAnnotation(name = "foo")
53 @MyAnnotation(name = "bar")
54 private static class TwoAnnotations {
55 }
56
57 @Retention(RetentionPolicy.RUNTIME)
58 @interface MyAnnotations {
|