test/jdk/javax/management/modelmbean/LoggingExceptionTest.java
author lfoltan
Tue, 20 Feb 2018 07:46:40 -0500
changeset 49026 844bf1deff1a
parent 47216 71c04702a3d5
permissions -rw-r--r--
8196884: VS2017 Multiple Type Cast Conversion Compilation Errors Summary: Change the type of symbolic constant badAddressVal and introduce specific casts to fix multiple type cast conversion compilation errors. Reviewed-by: coleenp, kbarrett
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21596
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     1
/*
30376
2ccf2cf7ea48 8078896: Add @modules as needed to the jdk_svc tests
ykantser
parents: 23010
diff changeset
     2
 * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved.
21596
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     4
 *
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     7
 * published by the Free Software Foundation.
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     8
 *
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    13
 * accompanied this code).
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    14
 *
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    18
 *
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    21
 * questions.
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    22
 */
0e3a39f29dbc 8027696: Incorrect copyright header in the tests
serb
parents: 263
diff changeset
    23
263
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    24
/*
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    25
 * @test
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    26
 * @bug 6471865 6675768
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    27
 * @summary DescriptorSupport constructors throw IAE when traces are enabled;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    28
 * RequiredModelMBean.addAttributeChangeNotificationListener throws exception
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    29
 * when traces enabled and no attributes.
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    30
 * @author Luis-Miguel Alventosa
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    31
 * @author Paul Cheeseman
44423
306c020eb154 8176176: fix @modules in jdk_svc tests
iignatyev
parents: 30376
diff changeset
    32
 *
306c020eb154 8176176: fix @modules in jdk_svc tests
iignatyev
parents: 30376
diff changeset
    33
 * @modules java.logging
306c020eb154 8176176: fix @modules in jdk_svc tests
iignatyev
parents: 30376
diff changeset
    34
 *          java.management
263
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    35
 */
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    36
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    37
import java.util.logging.ConsoleHandler;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    38
import java.util.logging.Handler;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    39
import java.util.logging.Level;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    40
import java.util.logging.Logger;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    41
import javax.management.Notification;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    42
import javax.management.NotificationListener;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    43
import javax.management.modelmbean.DescriptorSupport;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    44
import javax.management.modelmbean.RequiredModelMBean;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    45
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    46
public class LoggingExceptionTest {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    47
    private static final String tests[] = new String[] {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    48
        "DescriptorSupport()",
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    49
        "DescriptorSupport(int)",
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    50
        "DescriptorSupport(String)",
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    51
        "DescriptorSupport(String...)",
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    52
        "DescriptorSupport(String[], Object[])",
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    53
        "DescriptorSupport(DescriptorSupport)",
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    54
        "RequiredModelMBean.addAttributeChangeNotificationListener",
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    55
    };
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    56
    public static void main(String[] args) {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    57
        Handler handler = new ConsoleHandler();
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    58
        Logger logger = Logger.getLogger("javax.management.modelmbean");
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    59
        logger.addHandler(handler);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    60
        logger.setLevel(Level.FINEST);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    61
        try {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    62
            for (int i = 0; i < tests.length; i++) {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    63
                System.out.println(">>> DescriptorSupportLoggingTest: Test Case " + i);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    64
                DescriptorSupport ds;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    65
                String msg = "Instantiate " + tests[i];
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    66
                System.out.println(msg);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    67
                switch (i) {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    68
                    case 0:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    69
                        ds = new DescriptorSupport();
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    70
                        break;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    71
                    case 1:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    72
                        ds = new DescriptorSupport(10);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    73
                        break;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    74
                    case 2:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    75
                        ds = new DescriptorSupport(new DescriptorSupport().toXMLString());
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    76
                        break;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    77
                    case 3:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    78
                        ds = new DescriptorSupport("name1=value1", "name2=value2");
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    79
                        break;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    80
                    case 4:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    81
                        ds = new DescriptorSupport(new String[] {"name"}, new Object[] {"value"});
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    82
                        break;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    83
                    case 5:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    84
                        ds = new DescriptorSupport(new DescriptorSupport());
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    85
                        break;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    86
                    case 6:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    87
                        RequiredModelMBean mbean = new RequiredModelMBean();
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    88
                        NotificationListener nl = new NotificationListener() {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    89
                            public void handleNotification(Notification notification,
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    90
                                                           Object handback) {}
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    91
                        };
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    92
                        mbean.addAttributeChangeNotificationListener(nl, null, null);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    93
                        break;
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    94
                    default:
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    95
                        throw new AssertionError();
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    96
                }
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    97
                System.out.println(msg + " OK");
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    98
            }
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
    99
        } catch (Exception e) {
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   100
            System.out.println("Got unexpected exception = " + e);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   101
            String msg = "Test FAILED!";
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   102
            System.out.println(msg);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   103
            throw new IllegalArgumentException(msg);
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   104
        }
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   105
        System.out.println("Test PASSED!");
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   106
    }
db2a63668df3 6675768: NoSuchElementException thrown in RequiredModelMBean when tracing enabled
emcmanus
parents:
diff changeset
   107
}