Uploaded image for project: 'Application Server 7'
  1. Application Server 7
  2. AS7-1696

Arquillian test WAR/EAR deploys on AS7 via JMX protocol, but fails with "IllegalStateException: Cannot obtain Arquillian config for ..."

    XMLWordPrintable

Details

    • Bug
    • Resolution: Won't Do
    • Major
    • None
    • 7.0.1.Final
    • Test Suite
    • None
    • Hide
      • have an instance of JBoss AS 7.0.1.Final or 7.1.0.Alpha1-SNAPSHOT running on 127.0.0.1
      • unzip the attached project
      • navigate to {home}

        /tempArqTest/

      • run the test with {{mvn clean test -Pjbossas-remote-7 -Dmaven.repo.local= {your_local_repo}

        -Dtest=TestNewService}}

      Show
      have an instance of JBoss AS 7.0.1.Final or 7.1.0.Alpha1-SNAPSHOT running on 127.0.0.1 unzip the attached project navigate to {home} /tempArqTest/ run the test with {{mvn clean test -Pjbossas-remote-7 -Dmaven.repo.local= {your_local_repo} -Dtest=TestNewService}}

    Description

      This issue has been discussed at http://community.jboss.org/message/623963, and the suggested workaround using the Servlet protocol works. However creating this JIRA at Aslak Knutsen's request.

      The attached project includes a very simple test. When run, the EAR archive is deployed to the remote instance of AS 7.0.1.Final or 7.1.0.Alpha1-SNAPSHOT, but the config for the test itself, although the code is annotated with @RunWith and @Test, cannot be found:

      // from server logging
      
      21:43:35,746 INFO  [org.jboss.as.server.deployment] (pool-1-thread-7) Content added at location C:\jboss-as-7.1.0.Alpha1-SNAPSHOT\standalone\data\content\95\d3f543b1775223b963fe549546147322b07a2c\content
      21:43:35,747 INFO  [org.jboss.as.server.deployment] (MSC service thread 1-14) Starting deployment of "main-test.ear"
      21:43:35,822 INFO  [org.jboss.as.jpa] (MSC service thread 1-21) added javax.persistence.api dependency to main-test.ear
      21:43:35,825 INFO  [org.jboss.weld] (MSC service thread 1-18) Processing CDI deployment: main-test.ear
      21:43:35,842 INFO  [org.jboss.weld] (MSC service thread 1-2) Starting Services for CDI deployment: main-test.ear
      21:43:35,843 INFO  [org.jboss.weld] (MSC service thread 1-6) Starting weld service
      21:43:35,854 INFO  [org.jboss.seam.solder.Version] (MSC service thread 1-6) Seam Solder null (build id: null)
      21:43:35,871 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.transaction.UTTransaction from being installed as bean due to @Veto annotation
      21:43:35,885 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.transaction.SeSynchronizations from being installed as bean due to @Veto annotation
      21:43:35,890 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.transaction.CMTTransaction from being installed as bean due to @Veto annotation
      21:43:35,891 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.transaction.EntityTransaction from being installed as bean due to @Veto annotation
      21:43:35,900 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.persistence.hibernate.HibernateManagedSessionExtensionImpl from being installed as bean due to @Veto annotation
      21:43:35,900 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.transaction.NoTransaction from being installed as bean due to @Veto annotation
      17845.326: [GC
      Desired survivor size 48300032 bytes, new threshold 1 (max 15)
       905911K->652820K(3094272K), 0.0104778 secs]
      21:43:36,043 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.solder.core.VersionLoggerUtil from being installed as bean due to @Veto annotation
      21:43:36,095 INFO  [org.jboss.seam.solder.core.CoreExtension] (MSC service thread 1-6) Preventing class org.jboss.seam.solder.resourceLoader.ResourceProvider from being installed as bean due to @Veto annotation
      21:43:36,186 INFO  [org.jboss.as.server.controller] (pool-1-thread-7) Deployed "main-test.ear"
      21:43:36,275 DEBUG [org.jboss.as.arquillian] (RMI TCP Connection(18)-127.0.0.1) Getting Arquillian config for: temp.tests.TestNewService
      21:43:36,275 DEBUG [org.jboss.as.arquillian] (RMI TCP Connection(18)-127.0.0.1) Waiting on Arquillian config for: temp.tests.TestNewService
      21:44:06,277 DEBUG [org.jboss.as.arquillian] (RMI TCP Connection(18)-127.0.0.1) Getting Arquillian config for: temp.tests.TestNewService
      21:44:06,326 INFO  [org.jboss.weld] (MSC service thread 1-22) Stopping weld service
      21:44:06,336 INFO  [org.jboss.as.server.controller] (pool-1-thread-7) Undeployed "main-test.ear"
      21:44:06,339 INFO  [org.jboss.as.server.deployment] (MSC service thread 1-3) Stopped deployment main-test.ear in 14ms
      
      // from mvn test run logging
      
      -------------------------------------------------------
       T E S T S
      -------------------------------------------------------
      Running temp.tests.TestNewService
      log4j: reset attribute= "false".
      log4j: Threshold ="null".
      log4j: Class name: [org.apache.log4j.ConsoleAppender]
      log4j: Setting property [target] to [System.out].
      log4j: Setting property [threshold] to [ALL].
      log4j: Parsing layout of class: "org.apache.log4j.PatternLayout"
      log4j: Setting property [conversionPattern] to [%d{ABSOLUTE} %-5p [%c{1}] %m%n].
      log4j: Adding appender named [CONSOLE] to category [root].
      31-Aug-2011 22:43:34 org.jboss.arquillian.container.impl.client.container.ContainerRegistryCreator getActivatedConfiguration
      INFO: Could not read active container configuration: null
      inner-jar.jar:
      /temp/
      /temp/tests/
      /temp/tests/TestNewService.class
      /temp/tests/MyLittleService.class
      /META-INF/
      /META-INF/beans.xml
      main-test.ear:
      /lib/
      /lib/seam-persistence-3.0.0.Final.jar
      /lib/seam-solder-3.0.0.Final.jar
      /seam-persistence-3.0.0.Final.jar
      /inner-jar.jar
      /seam-solder-3.0.0.Final.jar
      22:43:34,817 DEBUG [JMXProtocolPackager] Generating: arquillian-service
      22:43:34,825 DEBUG [JMXProtocolPackager] Merging archive: arquillian-testenricher-cdi.jar: 13 assets
      22:43:34,826 DEBUG [JMXProtocolPackager] Merging archive: arquillian-testenricher-initialcontext.jar: 3 assets
      22:43:34,826 DEBUG [JMXProtocolPackager] Merging archive: arquillian-testenricher-osgi.jar: 9 assets
      22:43:34,827 DEBUG [JMXProtocolPackager] Merging archive: arquillian-junit.jar: 252 assets
      22:43:34,833 DEBUG [JMXProtocolPackager] Merging archive: arquillian-core.jar: 375 assets
      22:43:34,840 DEBUG [JMXProtocolPackager] Merging archive: arquillian-testenricher-ejb.jar: 8 assets
      22:43:34,840 DEBUG [JMXProtocolPackager] Merging archive: arquillian-testenricher-msc.jar: 7 assets
      22:43:34,841 DEBUG [JMXProtocolPackager] Merging archive: arquillian-testenricher-resource.jar: 8 assets
      22:43:34,844 DEBUG [JMXProtocolPackager] Loadable extensions: [org.jboss.arquillian.testenricher.ejb.container.EJBEnricherRemoteExtension, org.jboss.arquillian.testenricher.cdi.container.CDIEnricherRemoteExten
      .testenricher.resource.container.ResourceEnricherRemoteExtension, org.jboss.arquillian.testenricher.initialcontext.container.InitialContextRemoteExtension, org.jboss.as.arquillian.service.JMXProtocolEndpointEx
      ian.container.test.impl.ContainerTestRemoteExtension, org.jboss.arquillian.testenricher.msc.MSCEnricherRemoteExtension, org.jboss.arquillian.testenricher.osgi.OSGiEnricherRemoteExtension]
      22:43:34,849 DEBUG [JMXProtocolPackager] Add dependencies: org.jboss.modules,deployment.arquillian-service,org.jboss.msc
      22:43:34,857 INFO  [ArquillianServiceDeployer] Deploy arquillian service: arquillian-service: 699 assets
      22:43:35,099 INFO  [remoting] JBoss Remoting version 3.2.0.Beta2
      22:43:35,106 INFO  [xnio] XNIO Version 3.0.0.Beta2
      22:43:35,120 INFO  [nio] XNIO NIO Implementation Version 3.0.0.Beta2
      22:43:35,137 DEBUG [channel-thread] Started channel thread 'XNIO NIO Read 1', selector sun.nio.ch.WindowsSelectorImpl@72e5355f
      22:43:35,137 DEBUG [channel-thread] Started channel thread 'XNIO NIO Write 1', selector sun.nio.ch.WindowsSelectorImpl@802b249
      22:43:35,541 DEBUG [channel-thread] Started channel thread 'XNIO NIO Read 2', selector sun.nio.ch.WindowsSelectorImpl@558041e0
      22:43:35,542 DEBUG [channel-thread] Started channel thread 'XNIO NIO Write 2', selector sun.nio.ch.WindowsSelectorImpl@56278e83
      22:43:35,563 ERROR [remote] JBREM00200: Remote connection failed: java.io.IOException: Message data for non-existent channel
      22:43:35,565 DEBUG [channel-thread] Started channel thread 'XNIO NIO Read 3', selector sun.nio.ch.WindowsSelectorImpl@44739f3f
      22:43:35,566 DEBUG [channel-thread] Started channel thread 'XNIO NIO Write 3', selector sun.nio.ch.WindowsSelectorImpl@1e670479
      22:43:35,571 DEBUG [channel-thread] Started channel thread 'XNIO NIO Read 4', selector sun.nio.ch.WindowsSelectorImpl@4e1263db
      22:43:35,572 DEBUG [channel-thread] Started channel thread 'XNIO NIO Write 4', selector sun.nio.ch.WindowsSelectorImpl@3a0b53e
      22:43:36,187 ERROR [remote] JBREM00200: Remote connection failed: java.io.IOException: Window open for non-existent channel
      22:43:36,188 DEBUG [channel-thread] Started channel thread 'XNIO NIO Read 5', selector sun.nio.ch.WindowsSelectorImpl@74bfed5a
      22:43:36,189 DEBUG [channel-thread] Started channel thread 'XNIO NIO Write 5', selector sun.nio.ch.WindowsSelectorImpl@27bc4ec8
      22:43:36,273 DEBUG [JMXMethodExecutor] Invoke temp.tests.TestNewService.testServiceCreation
      22:44:06,293 DEBUG [JMXMethodExecutor] Result: TestResult[status=FAILED,time=0ms]
      22:44:06,294 ERROR [JMXMethodExecutor] Failed: temp.tests.TestNewService.testServiceCreation
      java.lang.IllegalStateException: Cannot obtain Arquillian config for: temp.tests.TestNewService
              at org.jboss.as.arquillian.service.ArquillianService.getArquillianConfig(ArquillianService.java:178)
              at org.jboss.as.arquillian.service.ArquillianService.getArquillianConfig(ArquillianService.java:188)
              at org.jboss.as.arquillian.service.ArquillianService.access$300(ArquillianService.java:64)
              at org.jboss.as.arquillian.service.ArquillianService$ExtendedJMXTestRunner.runTestMethod(ArquillianService.java:199)
              at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
              at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
              at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
              at java.lang.reflect.Method.invoke(Method.java:597)
              at com.sun.jmx.mbeanserver.StandardMBeanIntrospector.invokeM2(StandardMBeanIntrospector.java:93)
              at com.sun.jmx.mbeanserver.StandardMBeanIntrospector.invokeM2(StandardMBeanIntrospector.java:27)
              at com.sun.jmx.mbeanserver.MBeanIntrospector.invokeM(MBeanIntrospector.java:208)
              at com.sun.jmx.mbeanserver.PerInterface.invoke(PerInterface.java:120)
              at com.sun.jmx.mbeanserver.MBeanSupport.invoke(MBeanSupport.java:262)
              at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:836)
              at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:761)
              at org.jboss.as.jmx.tcl.TcclMBeanServer.invoke(TcclMBeanServer.java:214)
              at javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1426)
              at javax.management.remote.rmi.RMIConnectionImpl.access$200(RMIConnectionImpl.java:72)
              at javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1264)
              at javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1359)
              at javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:788)
              at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
              at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
              at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
              at java.lang.reflect.Method.invoke(Method.java:597)
              at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:305)
              at sun.rmi.transport.Transport$1.run(Transport.java:159)
              at java.security.AccessController.doPrivileged(Native Method)
              at sun.rmi.transport.Transport.serviceCall(Transport.java:155)
              at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:535)
              at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:790)
              at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:649)
              at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:885)
              at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:907)
              at java.lang.Thread.run(Thread.java:619)
      22:44:06,315 DEBUG [channel-thread] Started channel thread 'XNIO NIO Read 6', selector sun.nio.ch.WindowsSelectorImpl@19d03a4e
      22:44:06,316 DEBUG [channel-thread] Started channel thread 'XNIO NIO Write 6', selector sun.nio.ch.WindowsSelectorImpl@67cee792
      22:44:06,340 ERROR [remote] JBREM00200: Remote connection failed: java.io.IOException: Message data for non-existent channel
      Tests run: 1, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 31.998 sec <<< FAILURE!
      
      Results :
      
      Tests in error:
        testServiceCreation(temp.tests.TestNewService): Cannot obtain Arquillian config for: temp.tests.TestNewService
      

      I debugged ArquillianService on the server, when the EAR deploys, and, sure enough, the deployedTests set is empty. I'm not saying this test should pass - perhaps it's too simple, or the premise flawed - but I believe the test config should be found.

      Interestingly, MyLittleService is a near-empty POJO/Managed Bean. If I make it an EJB Singleton, then the test config is found and the test runs...

      Attachments

        Issue Links

          Activity

            People

              aslak@redhat.com Aslak Knutsen
              BenKirby Ben Kirby (Inactive)
              Votes:
              5 Vote for this issue
              Watchers:
              12 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: