使用 Cobertura 从代码覆盖率中排除方法

发布于 2024-07-23 08:39:38 字数 120 浏览 10 评论 0原文

有没有办法将代码排除在 Cobertura 覆盖率报告之外? 我们有一些方法不应包含在覆盖率报告中,因此不会降低覆盖率数字。

我知道Clover有这样的功能,但我还没有找到Cobertura的类似功能。

Is there a way to exclude code from inclusion into Cobertura coverage reports? We have some methods that should not be included in the coverage report and therefore not drive down the coverage numbers.

I know that Clover has such a functionality, but I have not found anything similar for Cobertura.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

吃颗糖壮壮胆 2024-07-30 08:39:38

您可以从检测中排除类。 那么它们就不应该出现在报告中。 请参阅下面的排除语句。

您还可以忽略对某些方法的调用。 请参阅下面的忽略声明。

如果您使用的是 Maven,请参阅 maven 插件手册

    <configuration>
      <instrumentation>
        <ignores>
          <ignore>com.example.boringcode.*</ignore>
        </ignores>
        <excludes>
          <exclude>com/example/dullcode/**/*.class</exclude>
          <exclude>com/example/**/*Test.class</exclude>
        </excludes>
      </instrumentation>
    </configuration>

对于 ant,请参阅

<cobertura-instrument todir="${instrumented.dir}">
  <ignore regex="org.apache.log4j.*" />
  <fileset dir="${classes.dir}">
    <include name="**/*.class" />
    <exclude name="**/*Test.class" />
  </fileset>
  <fileset dir="${jars.dir}">
    <include name="my-simple-plugin.jar" />
  </fileset>
</cobertura-instrument>

You can exclude classes from instrumentation. Then they should not appear on reports. See exclude statements below.

You can also ignore calls to some methods. See ignore statement below.

If you are using maven, see maven plugin manual.

    <configuration>
      <instrumentation>
        <ignores>
          <ignore>com.example.boringcode.*</ignore>
        </ignores>
        <excludes>
          <exclude>com/example/dullcode/**/*.class</exclude>
          <exclude>com/example/**/*Test.class</exclude>
        </excludes>
      </instrumentation>
    </configuration>

And for ant see this.

<cobertura-instrument todir="${instrumented.dir}">
  <ignore regex="org.apache.log4j.*" />
  <fileset dir="${classes.dir}">
    <include name="**/*.class" />
    <exclude name="**/*Test.class" />
  </fileset>
  <fileset dir="${jars.dir}">
    <include name="my-simple-plugin.jar" />
  </fileset>
</cobertura-instrument>
千鲤 2024-07-30 08:39:38

这让我头疼有一段时间了。

我的问题是我在报告部分而不是构建部分设置了 cobertura maven 插件。

如果您未在构建部分进行设置,则不会应用检测设置,从而排除类或包,因此请注意这一点。

This has been breaking my head for some time now.

My problem was that I had the cobertura maven plugin setup in the reporting section instead of the build section.

The instrumentation settings, and hence the excluding of classes or packages, won't be applied if you don't set it up on build section, so watch out for this.

﹉夏雨初晴づ 2024-07-30 08:39:38

请记住也要排除内部类。

<exclude>path/to/class/MyClass*.class</exclude>

我花了很长时间才注意到我缺少一个星号!

Remember to exclude inner classes too.

<exclude>path/to/class/MyClass*.class</exclude>

It took me ages to notice I was missing an asterisk!

白况 2024-07-30 08:39:38

Cobertura 目前没有提供这样的功能,Emma(我们使用的)也没有提供这样的功能,尽管它被列为即将推出的增强功能 - 尽管我相信是以排除规则的扩展形式而不是作为注释。

将那些难以触及的角落干净地遮盖起来会很方便,这样你就可以争取 100% 的成绩,而不会显得可笑。

我认为注释可能是一种更友好的方法,但它们应该被相当明确地命名并基于可接受的场景列表,因为我担心否则像“@ExcludeFromCoverage”这样的东西会被慷慨地添加。

Cobertura doesn't currently provide such a feature, and neither does Emma (which we use) although it is listed as a forthcoming enhancement - although in the form of an extension to the exclusion rules I believe rather than as an annotation.

Would be handy to cover off those few inaccessible corners cleanly so that you can strive for 100% without being ridiculous.

I think annotations would probably be a friendlier way to do it, but they ought to be fairly explicitly named and based on a list of acceptable scenarios as I fear otherwise something like '@ExcludeFromCoverage' would get added over generously.

少钕鈤記 2024-07-30 08:39:38

从 2.0 开始,您可以编写自己的 @CoverageIgnore 注释。

它将被 Cobertura 识别,它将避免考虑带注释的方法(据我所知,不适用于类)。

  1. 创建一个空注释:
public @interface CoverageIgnore {}
  1. 然后注释要从报告中排除的方法:
public class SomeClass {
    @CoverageIgnore
    public void foo(String baz) {
        // useless stuff
    }
}

来源:https ://github.com/cobertura/cobertura/wiki/Coverage-Annotations

Since 2.0 you can write your own @CoverageIgnore annotation.

It will be recognized by Cobertura, which will avoid considering annotated methods (does not work on classes as far as I know).

  1. Create an empty annotation:
public @interface CoverageIgnore {}
  1. Then annotate the methods you want to exclude from the reports:
public class SomeClass {
    @CoverageIgnore
    public void foo(String baz) {
        // useless stuff
    }
}

Source: https://github.com/cobertura/cobertura/wiki/Coverage-Annotations

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文