gpt4 book ai didi

android - Emma 报告覆盖率为 0%

转载 作者:搜寻专家 更新时间:2023-11-01 09:13:46 26 4
gpt4 key购买 nike

我想在运行单元测试时获得代码覆盖率。我跑 ant coverage使用标准的 android build.xml 进行测试。

测试运行良好。来自 ant coverage 的最后一个字符串是

Tests run: 59,  Failures: 1,  Errors: 4

Generated code coverage data to /data/data/my.package/files/coverage.ec

但 coverage.ec 文件只有 37 个字节长,几乎是空的。

在其上运行 emma 报告

no collected coverage data found in any of the data files [all reports will be empty]

并在每个字段中生成带有零的漂亮报告。

我想 emma 应该会产生更大的 coverage.ec。

我做错了什么?

---更新---

做了一些深入挖掘。似乎除了覆​​盖结果生成之外,大多数事情都很好。

1) 它编译一切说

[javac] /blabla/android-sdk-linux_x86/tools/ant/main_rules.xml:384: warning: 'includeantruntime' was not set, defaulting to build.sysclasspath=last; set to false for repeatable builds
[javac] Compiling 88 source files to /blabla/project/tests/instrumented/classes
[javac] Note: Some input files use unchecked or unsafe operations.
[javac] Note: Recompile with -Xlint:unchecked for details.

2) 它正在做 <instr>mode="overwrite"对于正在测试的项目。路径没问题。

-艾玛-乐器: [echo] 从/blabla/project/tests/instrumented/classes 检测类...

因此,有一个包含 98 个类的元数据的 *.em 文件。

3) 一些标准的android转换为dex,打包为unaligned,zip align。结果是/blabla/project/tests/instrumented/project-debug.apk。

4) 将此项目-debug.apk 安装到模拟器上。

5) 编译测试项目。 编译: [javac]/blabla/android-sdk/android-sdk-linux_x86/tools/ant/main_rules.xml:384: 警告:'includeantruntime' 未设置,默认为 build.sysclasspath=last;为可重复build设置为 false [javac] 编译110个源文件到/blabla/project/tests/bin/classes

源文件包括所有以前的文件加上测试(110 = 88 + 测试),如 build.properties 中所述(多个 source.dir 以“;”分隔)。

6) Resources, Dex, signing, zip align... 结果是projectTest-debug.apk

7) 将 projectTest-debug.apk 安装到模拟器上。

8) 通过指定“覆盖率”的 am 运行测试。它告诉我们

[exec] Generated code coverage data to /data/data/blabla.project/files/coverage.ec

9) 此 coverage.ec 不包含相关数据。它有 37 个字节长。报道称

processing input file [/home/ubuntu/projects/ppf2/workspace/PPF2/tests/coverage.ec] ...
loaded 0 coverage data entries
...
no collected coverage data found in any of the data files [all reports will be empty]

除了最后一步,一切对我来说似乎都很好。

最佳答案

我遇到了同样的问题,我想我明白这里发生了什么。

我看起来被测包的源也在测试包的内部(或被引用为源)。

结果是如果你 opened them up 你的包 apks 看起来像下面这样:

PackageUnderTest/ClassFileUnderTest

TestPackage/TestClass
TestPackage/ClassFileUnderTest

被测类文件:

pluclic class ClassFileUnderTest{
public int foo(){
...
}
}

测试类:

pluclic class TestClass{
public void testFoo(){
int result = foo();
assert...
}
}

这里发生的事情是,每当您的 TestClass 从 testFoo() 调用 foo() 方法时,foo() 就会在 TestClass/ClassFileUnderTest 而不是 PackageUnderTest/ClassFileUnderTest 上被调用。

因此,仪表化的 PackageUnderTest/ClassFileUnderTest 从未运行,也没有在覆盖率报告中记录。

从 TestPackage 中删除引用 PackageUnderTest 代码强制 PackageUnderTest 代码从 PackageUnderTest 运行并计入覆盖率报告。

关于android - Emma 报告覆盖率为 0%,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6223572/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com