Author: davsclaus Date: Tue Dec 7 17:08:21 2010 New Revision: 1043131 URL: http://svn.apache.org/viewvc?rev=1043131&view=rev Log: CAMEL-3279: Custom beans can now also be managed from JMX using their own set of operations/attributes.
Added: camel/trunk/camel-core/src/main/java/org/apache/camel/management/mbean/ManagedBeanProcessor.java camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomBeanTest.java - copied, changed from r1043074, camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomProcessorTest.java Modified: camel/trunk/camel-core/src/main/java/org/apache/camel/component/bean/BeanProcessor.java camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java camel/trunk/camel-core/src/main/java/org/apache/camel/management/DefaultManagementLifecycleStrategy.java camel/trunk/camel-core/src/main/java/org/apache/camel/management/JmxMBeanAssembler.java camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitterThrowExceptionInExpressionTest.java Modified: camel/trunk/camel-core/src/main/java/org/apache/camel/component/bean/BeanProcessor.java URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/main/java/org/apache/camel/component/bean/BeanProcessor.java?rev=1043131&r1=1043130&r2=1043131&view=diff ============================================================================== --- camel/trunk/camel-core/src/main/java/org/apache/camel/component/bean/BeanProcessor.java (original) +++ camel/trunk/camel-core/src/main/java/org/apache/camel/component/bean/BeanProcessor.java Tue Dec 7 17:08:21 2010 @@ -211,6 +211,10 @@ public class BeanProcessor extends Servi return beanHolder.getProcessor(); } + public Object getBean() { + return beanHolder.getBean(); + } + // Properties // ----------------------------------------------------------------------- Modified: camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java?rev=1043131&r1=1043130&r2=1043131&view=diff ============================================================================== --- camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java (original) +++ camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java Tue Dec 7 17:08:21 2010 @@ -33,7 +33,6 @@ import org.apache.camel.ProducerTemplate import org.apache.camel.Service; import org.apache.camel.component.bean.BeanProcessor; import org.apache.camel.component.bean.ProxyHelper; -import org.apache.camel.component.seda.CollectionProducer; import org.apache.camel.processor.UnitOfWorkProcessor; import org.apache.camel.processor.UnitOfWorkProducer; import org.apache.camel.util.CamelContextHelper; Modified: camel/trunk/camel-core/src/main/java/org/apache/camel/management/DefaultManagementLifecycleStrategy.java URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/main/java/org/apache/camel/management/DefaultManagementLifecycleStrategy.java?rev=1043131&r1=1043130&r2=1043131&view=diff ============================================================================== --- camel/trunk/camel-core/src/main/java/org/apache/camel/management/DefaultManagementLifecycleStrategy.java (original) +++ camel/trunk/camel-core/src/main/java/org/apache/camel/management/DefaultManagementLifecycleStrategy.java Tue Dec 7 17:08:21 2010 @@ -39,12 +39,14 @@ import org.apache.camel.Route; import org.apache.camel.Service; import org.apache.camel.VetoCamelContextStartException; import org.apache.camel.builder.ErrorHandlerBuilder; +import org.apache.camel.component.bean.BeanProcessor; import org.apache.camel.impl.DefaultCamelContextNameStrategy; import org.apache.camel.impl.EventDrivenConsumerRoute; import org.apache.camel.impl.ExplicitCamelContextNameStrategy; import org.apache.camel.impl.ProducerCache; import org.apache.camel.impl.ScheduledPollConsumer; import org.apache.camel.impl.ThrottlingInflightRoutePolicy; +import org.apache.camel.management.mbean.ManagedBeanProcessor; import org.apache.camel.management.mbean.ManagedBrowsableEndpoint; import org.apache.camel.management.mbean.ManagedCamelContext; import org.apache.camel.management.mbean.ManagedComponent; @@ -470,6 +472,8 @@ public class DefaultManagementLifecycleS answer = new ManagedThrottler(context, (Throttler) target, definition); } else if (target instanceof SendProcessor) { answer = new ManagedSendProcessor(context, (SendProcessor) target, definition); + } else if (target instanceof BeanProcessor) { + answer = new ManagedBeanProcessor(context, (BeanProcessor) target, definition); } else if (target instanceof ManagementAware) { return ((ManagementAware) target).getManagedObject(processor); } Modified: camel/trunk/camel-core/src/main/java/org/apache/camel/management/JmxMBeanAssembler.java URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/main/java/org/apache/camel/management/JmxMBeanAssembler.java?rev=1043131&r1=1043130&r2=1043131&view=diff ============================================================================== --- camel/trunk/camel-core/src/main/java/org/apache/camel/management/JmxMBeanAssembler.java (original) +++ camel/trunk/camel-core/src/main/java/org/apache/camel/management/JmxMBeanAssembler.java Tue Dec 7 17:08:21 2010 @@ -39,7 +39,7 @@ import org.springframework.jmx.export.as * @version $Revision$ */ public class JmxMBeanAssembler { - private final static Log LOG = LogFactory.getLog(JmxMBeanAssembler.class); + private static final Log LOG = LogFactory.getLog(JmxMBeanAssembler.class); private final MetadataMBeanInfoAssembler assembler; private final MBeanServer server; @@ -55,9 +55,9 @@ public class JmxMBeanAssembler { // prefer to use the managed instance if it has been annotated with Spring JMX annotations if (obj instanceof ManagedInstance) { Object custom = ((ManagedInstance) obj).getInstance(); - if (ObjectHelper.hasAnnotation(custom.getClass().getAnnotations(), ManagedResource.class)) { - if (LOG.isDebugEnabled()) { - LOG.debug("Assembling MBeanInfo for: " + name.toString() + " from custom @ManagedResource object: " + custom); + if (custom != null && ObjectHelper.hasAnnotation(custom.getClass().getAnnotations(), ManagedResource.class)) { + if (LOG.isTraceEnabled()) { + LOG.trace("Assembling MBeanInfo for: " + name.toString() + " from custom @ManagedResource object: " + custom); } // get the mbean info from the custom managed object mbi = assembler.getMBeanInfo(custom, name.toString()); @@ -68,8 +68,8 @@ public class JmxMBeanAssembler { if (mbi == null) { // use the default provided mbean which has been annotated with Spring JMX annotations - if (LOG.isDebugEnabled()) { - LOG.debug("Assembling MBeanInfo for: " + name.toString() + " from @ManagedResource object: " + obj); + if (LOG.isTraceEnabled()) { + LOG.trace("Assembling MBeanInfo for: " + name.toString() + " from @ManagedResource object: " + obj); } mbi = assembler.getMBeanInfo(obj, name.toString()); } Added: camel/trunk/camel-core/src/main/java/org/apache/camel/management/mbean/ManagedBeanProcessor.java URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/main/java/org/apache/camel/management/mbean/ManagedBeanProcessor.java?rev=1043131&view=auto ============================================================================== --- camel/trunk/camel-core/src/main/java/org/apache/camel/management/mbean/ManagedBeanProcessor.java (added) +++ camel/trunk/camel-core/src/main/java/org/apache/camel/management/mbean/ManagedBeanProcessor.java Tue Dec 7 17:08:21 2010 @@ -0,0 +1,43 @@ +/** + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.apache.camel.management.mbean; + +import org.apache.camel.CamelContext; +import org.apache.camel.component.bean.BeanProcessor; +import org.apache.camel.model.ProcessorDefinition; +import org.springframework.jmx.export.annotation.ManagedResource; + +/** + * @version $Revision$ + */ +...@managedresource(description = "Managed Bean Processor") +public class ManagedBeanProcessor extends ManagedProcessor { + + public ManagedBeanProcessor(CamelContext context, BeanProcessor processor, ProcessorDefinition<?> definition) { + super(context, processor, definition); + } + + @Override + public BeanProcessor getProcessor() { + return (BeanProcessor) super.getProcessor(); + } + + @Override + public Object getInstance() { + return getProcessor().getBean(); + } +} Modified: camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitterThrowExceptionInExpressionTest.java URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitterThrowExceptionInExpressionTest.java?rev=1043131&r1=1043130&r2=1043131&view=diff ============================================================================== --- camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitterThrowExceptionInExpressionTest.java (original) +++ camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitterThrowExceptionInExpressionTest.java Tue Dec 7 17:08:21 2010 @@ -27,7 +27,7 @@ import org.apache.camel.builder.RouteBui */ public class SplitterThrowExceptionInExpressionTest extends ContextTestSupport { - public void testSplitterAndVerifyMock () throws Exception { + public void testSplitterAndVerifyMock() throws Exception { getMockEndpoint("mock:error").expectedMessageCount(0); getMockEndpoint("mock:error2").expectedMessageCount(1); getMockEndpoint("mock:split").expectedMessageCount(0); Copied: camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomBeanTest.java (from r1043074, camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomProcessorTest.java) URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomBeanTest.java?p2=camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomBeanTest.java&p1=camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomProcessorTest.java&r1=1043074&r2=1043131&rev=1043131&view=diff ============================================================================== --- camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomProcessorTest.java (original) +++ camel/trunk/camel-core/src/test/java/org/apache/camel/management/ManagedCustomBeanTest.java Tue Dec 7 17:08:21 2010 @@ -16,14 +16,14 @@ */ package org.apache.camel.management; +import java.util.Map; import javax.management.Attribute; import javax.management.MBeanServer; import javax.management.ObjectName; import org.apache.camel.CamelContext; import org.apache.camel.ContextTestSupport; -import org.apache.camel.Exchange; -import org.apache.camel.Processor; +import org.apache.camel.Headers; import org.apache.camel.builder.RouteBuilder; import org.springframework.jmx.export.annotation.ManagedAttribute; import org.springframework.jmx.export.annotation.ManagedResource; @@ -31,7 +31,7 @@ import org.springframework.jmx.export.an /** * @version $Revision: 950375 $ */ -public class ManagedCustomProcessorTest extends ContextTestSupport { +public class ManagedCustomBeanTest extends ContextTestSupport { @Override protected boolean useJmx() { @@ -47,13 +47,13 @@ public class ManagedCustomProcessorTest return context; } - public void testManageCustomProcessor() throws Exception { + public void testManageCustomBean() throws Exception { MBeanServer mbeanServer = context.getManagementStrategy().getManagementAgent().getMBeanServer(); ObjectName on = ObjectName.getInstance("org.apache.camel:context=localhost/camel-1,type=processors,name=\"custom\""); getMockEndpoint("mock:result").expectedMessageCount(1); getMockEndpoint("mock:result").expectedHeaderReceived("foo", "hey"); - template.sendBody("direct:start", "Hello World"); + template.sendBody("direct:start", "World"); assertMockEndpointsSatisfied(); String foo = (String) mbeanServer.getAttribute(on, "Foo"); @@ -66,7 +66,7 @@ public class ManagedCustomProcessorTest getMockEndpoint("mock:result").expectedMessageCount(1); getMockEndpoint("mock:result").expectedHeaderReceived("foo", "changed"); - template.sendBody("direct:start", "Bye World"); + template.sendBody("direct:start", "Camel"); assertMockEndpointsSatisfied(); } @@ -76,15 +76,15 @@ public class ManagedCustomProcessorTest @Override public void configure() throws Exception { from("direct:start").routeId("foo") - .process(new MyCustomProcessor()).id("custom") + .bean(new MyCustomBean()).id("custom") .to("mock:result"); } }; } // START SNIPPET: e1 - @ManagedResource("My Managed Component") - public static class MyCustomProcessor implements Processor { + @ManagedResource("My Managed Bean") + public static class MyCustomBean { private String foo = "hey"; @ManagedAttribute @@ -97,8 +97,9 @@ public class ManagedCustomProcessorTest this.foo = foo; } - public void process(Exchange exchange) throws Exception { - exchange.getIn().setHeader("foo", getFoo()); + public String doSomething(String body, @Headers Map headers) throws Exception { + headers.put("foo", foo); + return "Hello " + body; } } // END SNIPPET: e1