/* * JBoss, Home of Professional Open Source. * Copyright 2006, Red Hat Middleware LLC, and individual contributors * as indicated by the @author tags. See the copyright.txt file in the * distribution for a full listing of individual contributors. * * This 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 software 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 software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jboss.test.aop.bean; import org.jboss.aop.Dispatcher; import org.jboss.aop.Advised; import org.jboss.aspects.remoting.ClusteredRemoting; import org.jboss.aspects.remoting.Remoting; import org.jboss.ha.framework.interfaces.RoundRobin; import org.jboss.logging.Logger; import org.jboss.remoting.InvokerLocator; import org.jboss.system.ServiceMBeanSupport; import javax.management.MBeanRegistration; import javax.management.MBeanServer; import javax.management.ObjectName; /** * * @see Monitorable * @author Bill Burke * @version $Revision: 57211 $ */ public class RemotingTester extends ServiceMBeanSupport implements RemotingTesterMBean, MBeanRegistration { // Constants ---------------------------------------------------- // Attributes --------------------------------------------------- static Logger log = Logger.getLogger(RemotingTester.class); MBeanServer m_mbeanServer; // Static ------------------------------------------------------- // Constructors ------------------------------------------------- public RemotingTester() {} // Public ------------------------------------------------------- // MBeanRegistration implementation ----------------------------------- public ObjectName preRegister(MBeanServer server, ObjectName name) throws Exception { m_mbeanServer = server; return name; } public void postRegister(Boolean registrationDone) {} public void preDeregister() throws Exception {} public void postDeregister() {} protected void startService() throws Exception { } protected void stopService() { } public POJO testRemoting() { try { log.info("Testing REMOTING"); POJO remote = new POJO("hello"); Dispatcher.singleton.registerTarget("myobj", remote); return (POJO)Remoting.createRemoteProxy("myobj", remote.getClass(), "socket://" + System.getProperty("jbosstest.server.host", "localhost") + ":5150"); } catch (Throwable ex) { log.error("failed", ex); throw new RuntimeException(ex.getMessage()); } } public NonadvisedPOJO testNonadvisedRemoting() { try { log.info("Testing NONADVISED REMOTING"); NonadvisedPOJO remote = new NonadvisedPOJO("hello"); Dispatcher.singleton.registerTarget("myobj", remote); return (NonadvisedPOJO)Remoting.createRemoteProxy("myobj", remote.getClass(), "socket://" + System.getProperty("jbosstest.server.host", "localhost") + ":5150"); } catch (Throwable ex) { log.error("failed", ex); throw new RuntimeException(ex.getMessage()); } } public POJO testClusteredRemoting() { try { log.info("Testing CLUSTERED REMOTING"); POJO remote = new POJO("hello"); return (POJO)ClusteredRemoting.clusterObject("clusteredobj", remote, "DefaultPartition", new RoundRobin(), new InvokerLocator("socket://" + System.getProperty("jbosstest.server.host", "localhost") + ":5150")); } catch (Throwable ex) { log.error("failed", ex); throw new RuntimeException(ex.getMessage()); } } public NonadvisedPOJO testClusteredNonadvisedRemoting() { try { log.info("Testing CLUSTERED NONADVISED REMOTING"); NonadvisedPOJO remote = new NonadvisedPOJO("hello"); return (NonadvisedPOJO)ClusteredRemoting.clusterObject("nonadvisedclusteredobj", remote, "DefaultPartition", new RoundRobin(), new InvokerLocator("socket://" + System.getProperty("jbosstest.server.host", "localhost") + ":5150")); } catch (Throwable ex) { log.error("failed", ex); throw new RuntimeException(ex.getMessage()); } } public void unregisterTarget(Object object) { ClusteredRemoting.unregisterClusteredObject(object); } // Inner classes ------------------------------------------------- }