Package org.jboss.jbossts.qa.AITResources02Clients

Source Code of org.jboss.jbossts.qa.AITResources02Clients.Client04

/*
* JBoss, Home of Professional Open Source
* Copyright 2007, Red Hat Middleware LLC, and individual contributors
* as indicated by the @author tags.
* See the copyright.txt in the distribution for a
* full listing of individual contributors.
* This copyrighted material is made available to anyone wishing to use,
* modify, copy, or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License, v. 2.1.
* This program is distributed in the hope that it will be useful, but WITHOUT A
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public License,
* v.2.1 along with this distribution; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA  02110-1301, USA.
*
* (C) 2005-2006,
* @author JBoss Inc.
*/
///////////////////////////////////////////////////////////////////////////////////////////
//
// Copyright (C) 2001, HP Bluestone Arjuna.
//
// File        : Client04.javatmpl (AITResources02)
//
// Description : Memory Test version of Client02. (counter increase & check - with trans).
//
//               Client performs a specified number of remote calls before
//               the memory growth is checked. If client or server memory growth
//               exceeds specified parameters then the test fails and "Failed" is output.
//               Otherwise "Passed" is output.
//
// Author      : Stewart Wheater
//
// History     : 1.0   25 Feb 2000  S Wheater       Creation.
//               1.1   07 Jul 2001  M Buckingham    Added facility to use client/server
//                                                  thresholds in config file
//                                                  MemoryTestProfile.
//
///////////////////////////////////////////////////////////////////////////////////////////

package org.jboss.jbossts.qa.AITResources02Clients;

/*
* Copyright (C) 1999-2001 by HP Bluestone Software, Inc. All rights Reserved.
*
* HP Arjuna Labs,
* Newcastle upon Tyne,
* Tyne and Wear,
* UK.
*
* $Id: Client04.java,v 1.2 2003/06/26 11:43:10 rbegg Exp $
*/

/*
* Try to get around the differences between Ansi CPP and
* K&R cpp with concatenation.
*/

/*
* Copyright (C) 1999-2001 by HP Bluestone Software, Inc. All rights Reserved.
*
* HP Arjuna Labs,
* Newcastle upon Tyne,
* Tyne and Wear,
* UK.
*
* $Id: Client04.java,v 1.2 2003/06/26 11:43:10 rbegg Exp $
*/


import com.arjuna.ats.jts.extensions.AtomicTransaction;
import org.jboss.jbossts.qa.AITResources02.*;
import org.jboss.jbossts.qa.Utils.*;

public class Client04
{
  public static void main(String[] args)
  {
    try
    {
      ORBInterface.initORB(args, null);
      OAInterface.initOA();

      String counterIOR = ServerIORStore.loadIOR(args[args.length - 4]);
      Counter counter = CounterHelper.narrow(ORBInterface.orb().string_to_object(counterIOR));

      int numberOfCalls = Integer.parseInt(args[args.length - 3]);

      float clientIncreaseThreshold;
      float serverIncreaseThreshold;

      // If no threshold value then use default.
      if (MemoryTestProfileStore.getNoThresholdValue().equals(args[args.length - 2]))
      {
        clientIncreaseThreshold = Float.parseFloat(MemoryTestProfileStore.getDefaultClientIncreaseThreshold());
      }
      else // Use passed threshold
      {
        clientIncreaseThreshold = Float.parseFloat(args[args.length - 2]);
      }

      // If no threshold value then use default.
      if (MemoryTestProfileStore.getNoThresholdValue().equals(args[args.length - 1]))
      {
        serverIncreaseThreshold = Float.parseFloat(MemoryTestProfileStore.getDefaultServerIncreaseThreshold());
      }
      else // Use passed threshold
      {
        serverIncreaseThreshold = Float.parseFloat(args[args.length - 1]);
      }

      for (int index = 0; index < 2; index++)
      {
        AtomicTransaction atomicTransaction = new AtomicTransaction();

        atomicTransaction.begin();

        counter.increase(OTS.current().get_control());

        if ((index % 2) == 0)
        {
          atomicTransaction.commit(true);
        }
        else
        {
          atomicTransaction.rollback();
        }
      }

      int clientMemory0 = (int) JVMStats.getMemory();
      int serverMemory0 = counter.getMemory();

      for (int index = 0; index < numberOfCalls; index++)
      {
        AtomicTransaction atomicTransaction = new AtomicTransaction();

        atomicTransaction.begin();

        counter.increase(OTS.current().get_control());

        if ((index % 2) == 0)
        {
          atomicTransaction.commit(true);
        }
        else
        {
          atomicTransaction.rollback();
        }
      }

      int clientMemory1 = (int) JVMStats.getMemory();
      int serverMemory1 = counter.getMemory();

      float clientMemoryIncrease = ((float) (clientMemory1 - clientMemory0)) / ((float) clientMemory0);
      float serverMemoryIncrease = ((float) (serverMemory1 - serverMemory0)) / ((float) serverMemory0);

      System.err.println("Client memory increase threshold : " + (float) (100.0 * clientIncreaseThreshold) + "%");
      System.err.println("Server memory increase threshold : " + (float) (100.0 * serverIncreaseThreshold) + "%");

      System.err.println("Client percentage memory increase: " + (float) (100.0 * clientMemoryIncrease) + "%");
      System.err.println("Client memory increase per call  : " + (clientMemory1 - clientMemory0) / numberOfCalls);
      System.err.println("Server percentage memory increase: " + (float) (100.0 * serverMemoryIncrease) + "%");
      System.err.println("Server memory increase per call  : " + (serverMemory1 - serverMemory0) / numberOfCalls);

      if ((clientMemoryIncrease < clientIncreaseThreshold) && (serverMemoryIncrease < clientIncreaseThreshold))
      {
        System.out.println("Passed");
      }
      else
      {
        System.out.println("Failed");
      }
    }
    catch (Exception exception)
    {
      System.out.println("Failed");
      System.err.println("Client04.main: " + exception);
      exception.printStackTrace(System.err);
    }

    try
    {
      OAInterface.shutdownOA();
      ORBInterface.shutdownORB();
    }
    catch (Exception exception)
    {
      System.err.println("Client04.main: " + exception);
      exception.printStackTrace(System.err);
    }
  }
}
TOP

Related Classes of org.jboss.jbossts.qa.AITResources02Clients.Client04

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.