/* * ALMA - Atacama Large Millimiter Array (c) European Southern Observatory, * 2002 Copyright by ESO (in the framework of the ALMA collaboration), All * rights reserved * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published by the * Free Software Foundation; either version 2.1 of the License, or (at your * option) any later version. * * This library 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 Lesser General Public License * for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this library; if not, write to the Free Software Foundation, * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ package alma.perftest.client; import java.util.logging.Logger; import alma.acs.component.client.ComponentClient; import alma.acs.time.Profiler; import alma.perftest.MethodTestComponent; import alma.perftest.MethodTestComponentHelper; public class ClientMethodTest extends ComponentClient { private Profiler m_profiler = null; private String m_compName = null; private String m_msg = ""; private int m_count = 0; private int m_size = 0; private int m_waitTime = 0; public ClientMethodTest(Logger logger, String managerLoc) throws Exception { super(logger, managerLoc, "no client name"); m_profiler = new Profiler(); } public void doSomeStuff() throws Exception { MethodTestComponent tComp = MethodTestComponentHelper.narrow(getContainerServices().getComponent(m_compName)); tComp.setup(m_count, m_size, m_waitTime); for (long i=0; i<m_count; i++) { m_profiler.start(); tComp.testReturnSize(); m_profiler.stop(); } m_profiler.fullDescription(m_msg); } public static void main(String[] args) { String managerLoc = System.getProperty("ACS.manager"); ClientMethodTest hlc = null; try { hlc = new ClientMethodTest(null, managerLoc); //Setup needed stuff hlc.m_compName = args[0]; hlc.m_count = Integer.parseInt(args[1]); hlc.m_size = Integer.parseInt(args[2]); hlc.m_waitTime = Integer.parseInt(args[3]); for(int i = 4; i < args.length; i++) { if (i!=4) { hlc.m_msg = hlc.m_msg + " " + args[i]; } else { hlc.m_msg = args[i]; } } hlc.doSomeStuff(); } catch (Exception e) { e.printStackTrace(System.err); } finally { if (hlc != null) { try { hlc.tearDown(); } catch (Exception e1) { // bad luck } } } } }