package test.performance.registration;
import junit.framework.TestCase;
import test.performance.PerformanceSUITE;
import javax.management.MBeanServer;
import javax.management.MBeanServerFactory;
import javax.management.ObjectName;
public class RegistrationTEST
extends TestCase
{
private Object obj;
private String name;
private String desc;
public RegistrationTEST(String s, Object obj, String name, String desc)
{
super(s);
this.obj = obj;
this.name = name;
this.desc = desc;
}
public void testIt()
{
System.out.println("\n" + desc);
System.out.println(PerformanceSUITE.REGISTRATION_ITERATION_COUNT + " Registrations/Deregistrations, Repeat: x" + PerformanceSUITE.REPEAT_COUNT);
System.out.println("(this may take a while...)");
long start = 0, end = 0;
float avg = 0l;
int size = 0;
MBeanServer server = MBeanServerFactory.createMBeanServer();
try
{
ObjectName on = new ObjectName(name);
for (int testIterations = 0; testIterations < PerformanceSUITE.REPEAT_COUNT + 1; ++testIterations)
{
start = System.currentTimeMillis();
for (int invocationIterations = 0; invocationIterations < PerformanceSUITE.REGISTRATION_ITERATION_COUNT; ++invocationIterations)
{
server.registerMBean(obj, on);
server.unregisterMBean(on);
}
end = System.currentTimeMillis();
if (testIterations != 0)
{
long time = end - start;
System.out.print( time + " ");
avg += time;
}
}
System.out.println("\nAverage: " + (avg/PerformanceSUITE.REPEAT_COUNT));
}
catch (Exception e)
{
fail(e.toString());
}
finally
{
MBeanServerFactory.releaseMBeanServer(server);
}
}
}