可通过配置phpunit.xml、使用注解或.gitattributes文件排除laravel测试覆盖率统计的文件。1、在phpunit.xml的<coverage>中添加<exclude>指定目录或文件;2、在类或方法上添加@codeCoverageIgnore注解跳过特定代码;3、在.gitattributes中为文件设置coverage=omit等属性实现CI环境下的自动排除。

如果您在生成 Laravel 项目的测试覆盖率报告时,希望排除某些不必要统计的文件或目录,以提高报告的准确性和可读性,则可以通过配置 PHPUnit 的过滤规则来实现。以下是具体操作方法:
本文运行环境:macBook Pro,macOS Sonoma
一、通过 phpunit.xml 配置排除文件
PHPUnit 支持在配置文件中定义哪些文件或目录不应被包含在代码覆盖率分析中。这种方法适用于全局排除指定路径。
1、打开项目根目录下的 phpunit.xml 文件。
2、在 <coverage> 节点内添加 <exclude> 标签,并列出要排除的文件或目录。
3、例如,排除 app/Models/Generated 目录和所有 Traits 文件:
<exclude>
<Directory suffix=”.php”>app/Models/Generated</directory>
<file>app/Traits/HelperTrait.php</file>
</exclude>
二、使用注解排除特定类或方法
对于某些不需要参与覆盖率统计的类或方法,可以在其 PHP 文档块中添加注解,指示代码覆盖率工具跳过这些部分。
1、在需要排除的类定义上方添加 @codeCoverageIgnore 注解。
/**
* @codeCoverageIgnore
*/
class DataTransferObject {
// …
}
3、也可针对单个方法使用该注解,仅忽略方法体的覆盖检测。
三、通过 .gitattributes 文件标记排除内容
某些 CI 环境支持利用 .gitattributes 文件中标记的属性来控制覆盖率采集行为。此方式适合与版本控制系统集成的自动化流程。
1、在项目根目录创建或编辑 .gitattributes 文件。
2、为希望排除的文件添加属性标记:
app/ThirdParty/*.php export-ignore
database/migrations/*.php coverage=omit
以上就是laravel怎么在测试覆盖率报告中排除某些文件_laravel测试覆盖率排除文件方法的详细内容,更多请关注php中文网其它相关文章!


