我刚刚设法让突变测试第一次工作。我常用的测试框架是Codeception,但在撰写本文时,它与突变测试不兼容(尽管我相信正在对它进行工作并且离我不远了)。我正在使用PHPUnit和Infection,这两者似乎都不太容易弄清楚如何使用。
我的测试套件生成了十个突变体。九人被杀,一人逃脱。但是,我不知道代码或测试的哪一部分需要改进才能杀死最终的突变体。
您如何获得有关哪些代码允许突变体逃脱的信息?
我刚刚设法让突变测试第一次工作。我常用的测试框架是Codeception,但在撰写本文时,它与突变测试不兼容(尽管我相信正在对它进行工作并且离我不远了)。我正在使用PHPUnit和Infection,这两者似乎都不太容易弄清楚如何使用。
我的测试套件生成了十个突变体。九人被杀,一人逃脱。但是,我不知道代码或测试的哪一部分需要改进才能杀死最终的突变体。
您如何获得有关哪些代码允许突变体逃脱的信息?
我在这个博客中找到了在Infection 的文档中找不到的内容:结果保存在infection.log
.
日志文件如下所示:
Escaped mutants:
================
1) <full-path-to-source-file>.php:7 [M] ProtectedVisibility
--- Original
+++ New
@@ @@
use stdClass;
trait HiddenValue
{
- protected function hidden_value($name = null, $value = null)
+ private function hidden_value($name = null, $value = null)
{
static $data = [];
$keys = array_map(function ($item) {
Timed Out mutants:
==================
Not Covered mutants:
====================
它说突变改变了protected
可见性,private
并且没有测试因此而失败。如果这很重要,我现在可以更改代码或编写另一个测试来涵盖这种情况。
现在我找到了这个,我在 Infection 网站上搜索infection.log
并找到了--show-mutations
或者-s
在运行时将转义的突变体输出到控制台。