jdk-24/jdk/test/javax/management/monitor/CounterMonitorTest.java

244 lines
7.9 KiB
Java
Raw Normal View History

2007-12-01 00:00:00 +00:00
/*
* Copyright 2004 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 4981829
* @summary Test that the counter monitor, when running in difference mode,
* emits a notification every time the threshold is exceeded.
* @author Luis-Miguel Alventosa
* @run clean CounterMonitorTest
* @run build CounterMonitorTest
* @run main CounterMonitorTest
*/
import javax.management.*;
import javax.management.monitor.*;
public class CounterMonitorTest implements NotificationListener {
// threshold number
private Number threshold = new Integer(2);
// modulus number
private Number modulus = new Integer(7);
// offset number
private int offset = 0;
// difference mode flag
private boolean differenceModeFlag = true;
// notify flag
private boolean notifyFlag = true;
// granularity period
private int granularityperiod = 500;
// counter values
private int[] values = new int[] {4, 6, 9, 11};
// time to wait for notification (in seconds)
private int timeout = 5;
// flag to notify that a message has been received
private volatile boolean messageReceived = false;
// MBean class
public class StdObservedObject implements StdObservedObjectMBean {
public Object getNbObjects() {
return count;
}
public void setNbObjects(Object n) {
count = n;
}
private Object count= null;
}
// MBean interface
public interface StdObservedObjectMBean {
public Object getNbObjects();
public void setNbObjects(Object n);
}
// Notification handler
public void handleNotification(Notification notification,
Object handback) {
MonitorNotification n = (MonitorNotification) notification;
echo("\tInside handleNotification...");
String type = n.getType();
try {
if (type.equals(MonitorNotification.THRESHOLD_VALUE_EXCEEDED)) {
echo("\t\t" + n.getObservedAttribute() +
" has reached or exceeded the threshold");
echo("\t\tDerived Gauge = " + n.getDerivedGauge());
messageReceived = true;
synchronized (this) {
notifyAll();
}
} else {
echo("\t\tSkipping notification of type: " + type);
}
} catch (Exception e) {
echo("\tError in handleNotification!");
e.printStackTrace(System.out);
}
}
/**
* Update the counter and check for notifications
*/
public void thresholdNotification() throws Exception {
CounterMonitor counterMonitor = new CounterMonitor();
try {
MBeanServer server = MBeanServerFactory.newMBeanServer();
String domain = server.getDefaultDomain();
// Create a new CounterMonitor MBean and add it to the MBeanServer.
//
echo(">>> CREATE a new CounterMonitor MBean");
ObjectName counterMonitorName = new ObjectName(
domain + ":type=" + CounterMonitor.class.getName());
server.registerMBean(counterMonitor, counterMonitorName);
echo(">>> ADD a listener to the CounterMonitor");
counterMonitor.addNotificationListener(this, null, null);
//
// MANAGEMENT OF A STANDARD MBEAN
//
echo(">>> CREATE a new StdObservedObject MBean");
ObjectName stdObsObjName =
new ObjectName(domain + ":type=StdObservedObject");
StdObservedObject stdObsObj = new StdObservedObject();
server.registerMBean(stdObsObj, stdObsObjName);
echo(">>> SET the attributes of the CounterMonitor:");
counterMonitor.addObservedObject(stdObsObjName);
echo("\tATTRIBUTE \"ObservedObject\" = " + stdObsObjName);
counterMonitor.setObservedAttribute("NbObjects");
echo("\tATTRIBUTE \"ObservedAttribute\" = NbObjects");
counterMonitor.setNotify(notifyFlag);
echo("\tATTRIBUTE \"Notify\" = " + notifyFlag);
counterMonitor.setInitThreshold(threshold);
echo("\tATTRIBUTE \"Threshold\" = " + threshold);
counterMonitor.setGranularityPeriod(granularityperiod);
echo("\tATTRIBUTE \"GranularityPeriod\" = " + granularityperiod);
counterMonitor.setModulus(modulus);
echo("\tATTRIBUTE \"Modulus\" = " + modulus);
counterMonitor.setDifferenceMode(differenceModeFlag);
echo("\tATTRIBUTE \"DifferenceMode\" = " + differenceModeFlag);
echo(">>> START the CounterMonitor");
counterMonitor.start();
// Set initial value
//
Integer data = new Integer(0);
echo(">>> Set data = " + data.intValue());
Attribute attrib = new Attribute("NbObjects", data);
server.setAttribute(stdObsObjName, attrib);
// Wait for granularity period (multiplied by 2 for sure)
//
Thread.sleep(granularityperiod * 2);
// Loop through the values
//
for (int i = 0; i < values.length; i++) {
data = new Integer(values[i]);
echo(">>> Set data = " + data.intValue());
attrib = new Attribute("NbObjects", data);
server.setAttribute(stdObsObjName, attrib);
echo("\tdoWait in Counter Monitor");
doWait();
// Check if notification was received
//
if (messageReceived) {
echo("\tOKAY: Notification received");
} else {
echo("\tError: notification missed or not emitted");
throw new IllegalStateException("Notification lost");
}
messageReceived = false;
}
} finally {
counterMonitor.stop();
}
echo(">>> Bye! Bye!");
}
/*
* Wait until timeout reached
*/
void doWait() {
for (int i = 0; i < timeout; i++) {
echo("\tdoWait: Waiting for " + timeout + " seconds. " +
"i = " + i + ", messageReceived = " + messageReceived);
if (messageReceived) {
break;
}
try {
synchronized (this) {
wait(1000);
}
} catch (InterruptedException e) {
// OK: Ignore...
}
}
}
/*
* Print message
*/
void echo(String message) {
System.out.println(message);
}
/*
* Standalone entry point.
*
* Run the test and report to stdout.
*/
public static void main (String args[]) throws Exception {
CounterMonitorTest test = new CounterMonitorTest();
test.thresholdNotification();
}
}