2013-07-28 19 views
1

我有一个项目,部署在jboss 7.1.3上,并使用arquillian进行测试,并且我试图向其添加代码覆盖率度量。arquillian jboss as7管理和jacoco - jacoco.exec文件为空

即时通讯使用托管容器选项(jboss-as-arquillian-container-managed),现在我刚刚尝试向jquery用于启动jboss的jvm参数添加-javaagent参数,所以我的arquillian。 XML看起来像这样:

<?xml version="1.0" encoding="UTF-8"?> 
<arquillian xmlns="http://jboss.org/schema/arquillian" 
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
      xsi:schemaLocation="http://jboss.org/schema/arquillian http://jboss.org/schema/arquillian/arquillian_1_0.xsd"> 
    <defaultProtocol type="Servlet 3.0"/> 

    <engine> 
     <property name="deploymentExportPath">/tmp</property> 
    </engine> 

    <container qualifier="jboss" default="true"> 
     <configuration> 
      <property name="outputToConsole">true</property> 
      <property name="jbossHome">[jboss home]</property> 
      <property name="javaHome">[java home]</property> 
      <property name="javaVmArguments">-Xmx2048m -XX:MaxPermSize=256m -XX:+HeapDumpOnOutOfMemoryError -Djboss.server.log.dir=logs -javaagent:[profile]\.m2\repository\org\jacoco\org.jacoco.agent\0.6.2.201302030002\org.jacoco.agent-0.6.2.201302030002-runtime.jar=destfile=C:\jacoco.exec,includes=*,excludes=,append=true,output=file,classdumpdir=classdumpdir,dumponexit=true</property> 
      <property name="startupTimeoutInSeconds">120</property> 
      <property name="allowConnectingToRunningServer">true</property> 
     </configuration> 
    </container> 
</arquillian> 

IM 100%肯定,这种说法是被拾起,因为两者的jacoco.exec文件和classdumpdir创建。

问题是jacoco.exec文件是空的。 jboss启动,测试运行并成功完成,jboss关闭,classdumpdir被填充(所以根据jacoco规范,它意味着它正确地找到我的类),但jacoco.exec保持完全空。

如果我提供确切的保存javaagent参数到完全相同的jboss,我手动开始自己一切工作正常。

我在做什么错?

+0

你配置了jacoco扩展吗?看到这里:https://github.com/arquillian/arquillian-extension-jacoco/blob/master/src/test/resources/arquillian.xml我至少会列出扩展名,不包括排除。 –

+0

@JohnAment - 尝试在我的arquillian xml中添加 - 没有任何区别 – radai

回答

1

好的,问题是jacoco只在jvm关闭时才转储文件内容(它为它注册了一个钩子),显然arquillian(至少是我使用的版本)并没有关闭jvm。

我结束了添加下面的方法来我的测试类:

@After 
public void writeOutJacocoData() { 
    try { 
     Class rtClass = Thread.currentThread().getContextClassLoader().getParent().loadClass("org.jacoco.agent.rt.RT"); 
     Object jacocoAgent = rtClass.getMethod("getAgent", null).invoke(null); 
     Method dumpMethod = jacocoAgent.getClass().getMethod("dump", boolean.class); 
     dumpMethod.invoke(jacocoAgent, false); 
    } catch(ClassNotFoundException e) { 
     logger.debug("no jacoco agent attached to this jvm"); 
    } catch (Exception e) { 
     logger.error("while trying to dump jacoco data",e); 
    } 
} 

其丑恶和野蛮(和使用他们不要在任何公开可用jacoco文物发布jacoco类,因此反射),但作品。

+0

您使用的是什么版本的arquillian? –

+0

即时通讯使用1.0.3.Final – radai

+0

似乎你的设置有其他问题。这不会发生在我身上。 –