- 
        15. Re: @JMX aspect and aop/mc integrationkabirkhan Nov 13, 2006 4:40 PM (in response to kabirkhan)"bstansberry@jboss.com" wrote: 
 To express my gratitude, here's another one ;-)
 LOL - I shall attempt to fix
- 
        16. Re: @JMX aspect and aop/mc integrationkabirkhan Nov 13, 2006 7:45 PM (in response to kabirkhan)This should be fixed now. The proxy now contains all the constructors from the proxies class, and passes up the parameters. When created by the MC, the AOPConstructorJoinPoint uses the same parameters when instantiating the proxy as the target bean itself, so the NPEs are avoided. 
 http://jira.jboss.com/jira/browse/JBAOP-307
- 
        17. Re: @JMX aspect and aop/mc integrationbrian.stansberry Nov 13, 2006 11:07 PM (in response to kabirkhan)I'm still seeing this after updating the microcontainer and aop libs. Here's the stack trace (just pasting the caused by): Caused by: java.lang.NullPointerException at org.jboss.ha.framework.server.DistributedReplicantManagerImpl.<init>(DistributedReplicantManagerImpl.java:117) at org.jboss.ha.framework.server.DistributedReplicantManagerImpl.<init>(DistributedReplicantManagerImpl.java:102) at AOPContainerProxy$3.<init>(AOPContainerProxy$3.java) at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) at java.lang.reflect.Constructor.newInstance(Constructor.java:494) at java.lang.Class.newInstance0(Class.java:350) at java.lang.Class.newInstance(Class.java:303) at org.jboss.aop.proxy.container.GeneratedAOPProxyFactory.instantiateAndConfigureProxy(GeneratedAOPProxyFactory.java:148) at org.jboss.aop.proxy.container.GeneratedAOPProxyFactory.getProxy(GeneratedAOPProxyFactory.java:122) ... 29 more 
 One thing to note here is the constructor parameter is another bean that also has an @JMX annotation.
- 
        18. Re: @JMX aspect and aop/mc integrationbrian.stansberry Nov 13, 2006 11:48 PM (in response to kabirkhan)Another problem I'm seeing is that many beans implement MBeanRegistration, but those callbacks aren't getting invoked. I think this is because the object registered with the MBeanServer is not the bean itself but rather a StandardMBean created in JMXIntroduction. That object doesn't implement MBeanRegistration. 
 With the beans I'm working with, it's actually not necessary to wrap them in a StandardMBean object before registering them. They are all already compliant standard mbeans of the X implements XMBean variety.
 I'm going to play a bit and see if there's any issue with registering the beans directly.
- 
        19. Re: @JMX aspect and aop/mc integrationstarksm64 Nov 13, 2006 11:59 PM (in response to kabirkhan)That is correct. We really should validate whether the target already implements a particular jmx interface, or just add an attribute to the annotation to indicate if the target should not be wrapped before registration. 
- 
        20. Re: @JMX aspect and aop/mc integrationbrian.stansberry Nov 14, 2006 12:35 AM (in response to kabirkhan)I was playing with the StandardMBean thing and rebuilt the aop-mc-int-dep.jar from source. After that the DistributedReplicantManager NPE went away. Is the microcontainer snapshot on repository.jboss.com up to date? 
- 
        21. Re: @JMX aspect and aop/mc integrationbrian.stansberry Nov 14, 2006 12:48 AM (in response to kabirkhan)Tweaking JMXIntroduction so it just directly registered my beans worked just fine. The problem is there is no way to cleanly express that that's what I want done: 
 1) JMXIntroduction could just try to register context.getTarget(), catch NotCompliantMBeanException, and then create and register the StandardMBean. Problem is this approach ignores the @JMX.exposedInterface value -- what if the bean is Foo implements FooMBean, Bar, and @JMX.exposedInterface=Bar.class? Kind of an edge case, but not clean.
 2) JMXIntroduction could try to register context.getTarget() only if @JMX.exposedInterface=null. This would be a clean solution. Problem is null is not a valid value for an annotation attribute, and the attribute type is Class, so you can't use the "" means null trick. (Hacky idea -- make it "Class exposedInterface() default void.class". The compiler accepts that.)
 3) I tried adding another attribute "boolean registerDirectly() default false;" to @JMX. But the deployment of any beans where it didn't specify the attribute failed in SimpleAnnotationValidator, which makes no attempt to read default values.
- 
        22. Re: @JMX aspect and aop/mc integrationkabirkhan Nov 14, 2006 6:28 AM (in response to kabirkhan)"bstansberry@jboss.com" wrote: 
 I was playing with the StandardMBean thing and rebuilt the aop-mc-int-dep.jar from source. After that the DistributedReplicantManager NPE went away. Is the microcontainer snapshot on repository.jboss.com up to date?
 Now that you mention it, I probably forgot to update it!
- 
        23. Re: @JMX aspect and aop/mc integrationkabirkhan Nov 14, 2006 6:43 AM (in response to kabirkhan)"bstansberry@jboss.com" wrote: 
 1) JMXIntroduction could just try to register context.getTarget(), catch NotCompliantMBeanException, and then create and register the StandardMBean. Problem is this approach ignores the @JMX.exposedInterface value -- what if the bean is Foo implements FooMBean, Bar, and @JMX.exposedInterface=Bar.class? Kind of an edge case, but not clean.
 We could probably do some checking of the exposed interface to see if that matches the standard mbean naming rules?"bstansberry@jboss.com" wrote: 
 2) JMXIntroduction could try to register context.getTarget() only if @JMX.exposedInterface=null. This would be a clean solution. Problem is null is not a valid value for an annotation attribute, and the attribute type is Class, so you can't use the "" means null trick. (Hacky idea -- make it "Class exposedInterface() default void.class". The compiler accepts that.)
 Sounds fine by me"bstansberry@jboss.com" wrote: 
 3) I tried adding another attribute "boolean registerDirectly() default false;" to @JMX. But the deployment of any beans where it didn't specify the attribute failed in SimpleAnnotationValidator, which makes no attempt to read default values.
 Default values can be read, but the java reflection api kindly does not allow us a way to read them. If javassist is on the classpath these values can be read. Since the container jars are in jboss/lib:
 a) We need to move javassist from jboss/server/xxx/lib to jboss/lib so that the mc classloader can see javassist
 OR
 b) I could do something similar to what I have done for the other AOP integration and do a check for when javassist has been deployed.
 I will look into b), but for now you should be able to make progress with a) (which is what we might end up with anyway :-)
- 
        24. Re: @JMX aspect and aop/mc integrationbrian.stansberry Nov 14, 2006 3:15 PM (in response to kabirkhan)Kabir implemented b) above, and I've checked in the addition of the @JMX.registerDirectly() attribute to microcontainer trunk (see http://jira.jboss.com/jira/browse/JBMICROCONT-109). 
- 
        25. Re: @JMX aspect and aop/mc integrationalesj Nov 15, 2006 4:18 AM (in response to kabirkhan)"scott.stark@jboss.org" wrote: 
 We really should validate whether the target already implements a particular jmx interface.
 Is this still reasonable to do?
 Maybe we could still check if the target is candidate for direct registration.
 And changing registerDirectly() to return some enum with 3 possibilities: STRICT, NONE, AUTO (default).
- 
        26. Re: @JMX aspect and aop/mc integrationbrian.stansberry Nov 15, 2006 10:15 AM (in response to kabirkhan)Want to confirm that I understand your semantics: 
 AUTO = try to register directly, if it fails, create and register StandardMBean
 STRICT = try to register directly, if it fails, throw exception
 NONE = just create and register StandardMBean
 This is OK by me, but probably won't get done this week. Also, is use of an enum allowed in the microcontainer (I don't know enough about the retroweaver to know). And can jbossxb populate an enum from a XML string? There was a mention of that on another thread, but I don't know if it happened. If either of the above are issues, we can just use a string.
- 
        27. Re: @JMX aspect and aop/mc integrationkabirkhan Nov 15, 2006 10:32 AM (in response to kabirkhan)The MC AnnotationCreator supports the types for annotations, so you could pass in enums. 
 See org.jboss.test.annotation.factory.test.AnnotationCreatorTest in the container project:String expr = "@org.jboss.test.annotation.factory.support.Complex(ch='a', string=\"Test123\", flt=9.9, dbl=123456789.99, shrt=1, lng=987654321, integer=123, bool=true, annotation=@org.jboss.test.annotation.factory.support.SimpleValue(\"Yes\"), array={\"Test\", \"123\"}, clazz=java.lang.Long.class, enumVal=org.jboss.test.annotation.factory.support.MyEnum.TWO)";
- 
        28. Re: @JMX aspect and aop/mc integrationalesj Nov 15, 2006 10:41 AM (in response to kabirkhan)With AUTO I wouldn't go register it directly and see if it fails. I would go and validate it first, if it passes then register it directly - ok it can still fail - but we at least know we tried our best. 
 With STRICT we also validate first - if it doesn't even pass validation throw an exception - and if it later fails ofcourse.
 NONE is ok as it is.
 >> can jbossxb populate an enum from a XML string?
 Sure. You are the one writting binding code. See org.jboss.kernel.plugins.deployment.xml.[name]Handler.
 How this goes with retro stuff - don't know yet. :-(
- 
        29. Re: @JMX aspect and aop/mc integrationstarksm64 Nov 15, 2006 12:41 PM (in response to kabirkhan)"bstansberry@jboss.com" wrote: 
 Also, is use of an enum allowed in the microcontainer (I don't know enough about the retroweaver to know). And can jbossxb populate an enum from a XML string? There was a mention of that on another thread, but I don't know if it happened. If either of the above are issues, we can just use a string.
 jbossretro supports enums fine. The mc does not treat enums and strings as interchangable as is the case for other primiatives and their object wrappers. I added a testEnum to the org.jboss.test.kernel.config.test.ConfigureAttributeFromStringTestCase test and its failing:java.lang.IllegalArgumentException: Wrong arguments. setEnumProperty for target org.jboss.test.kernel.config.support.SimpleBean@150bd4d expected=[org.jboss.test.kernel.config.support.SimpleBean$Alphabet] actual=[java.lang.String] at org.jboss.reflect.plugins.introspection.ReflectionUtils.handleErrors(ReflectionUtils.java:224) at org.jboss.reflect.plugins.introspection.ReflectionUtils.invoke(ReflectionUtils.java:59) at org.jboss.reflect.plugins.introspection.ReflectMethodInfoImpl.invoke(ReflectMethodInfoImpl.java:108) at org.jboss.joinpoint.plugins.BasicMethodJoinPoint.dispatch(BasicMethodJoinPoint.java:66) at org.jboss.test.kernel.config.test.AbstractKernelConfigTest.configure(AbstractKernelConfigTest.java:130) at org.jboss.test.kernel.config.test.ConfigureAttributeFromStringTestCase.configureSimpleBean(ConfigureAttributeFromStringTestCase.java:239) at org.jboss.test.kernel.config.test.ConfigureAttributeFromStringTestCase.testEnum(ConfigureAttributeFromStringTestCase.java:209) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at junit.framework.TestCase.runTest(TestCase.java:154) at junit.framework.TestCase.runBare(TestCase.java:127) at junit.framework.TestResult$1.protect(TestResult.java:106) at junit.framework.TestResult.runProtected(TestResult.java:124) at junit.framework.TestResult.run(TestResult.java:109) at junit.framework.TestCase.run(TestCase.java:118) at org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestReference.run(JUnit3TestReference.java:128) at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:460) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:673) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:386) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196) 
 I'll take a look at it today and if its simple add it for the beta mc release.
 
     
     
    