代码质量的覆盖率分为三种,覆盖率、代码覆盖率、分支覆盖率,那每一种的计算方式是怎么样的呢?
举例:
上面最有疑惑的是覆盖率,不知道怎么算出了来的,后面再说。
通过sonarqube可以分析出:
指标 | 值 |
---|---|
可覆盖行(lines_to_cover) | 13242 |
未覆盖的代码(uncovered_lines) | 7943 |
可覆盖分支(conditions_to_cover) | 7943 |
未覆盖分支(uncovered_conditions) | 7943 |
代码覆盖率(line_coverage) = (可覆盖行 - 未覆盖的代码)/可覆盖行
或者
行覆盖率 ( line_coverage):在给定的代码行上,行覆盖率只是回答“这行代码是否在单元测试执行期间被执行过?”的问题。它是单元测试覆盖线的密度:
线路覆盖率 = LC / EL
其中:
LC = 覆盖线 ( lines_to_cover - uncovered_lines)
EL = 可执行行总数 ( lines_to_cover)
分支覆盖率(branch_coverage) = (可覆盖分支 -未覆盖分支 )/可覆盖分支
或者:
条件覆盖率 = (CT + CF) / (2*B)
其中:
CT = 至少一次被评估为“真”的条件
CF = 至少一次被评估为“假”的条件
B = 条件总数
它是Line coverage和Condition coveragecoverage的混合体
计算公式为:Coverage = (CT + CF + LC)/(2*B + EL)
CT = 至少一次被评估为“真”的条件
CF = 至少一次被评估为“假”的条件
LC = 已覆盖行 = lines_to_cover - uncovered_lines
B = 条件总数(conditions_to_cover)
EL = 可执行行总数 (lines_to_cover)
参考 https://docs.sonarqube.org/latest/user-guide/metric-definitions/
条件覆盖 ( branch_coverage):在包含一些布尔表达式的每一行代码中,条件覆盖回答了以下问题:“每个布尔表达式是否都被评估为true?false”。这是在单元测试执行期间遵循的流程控制结构中可能条件的密度。
条件覆盖率 = (CT + CF) / (2*B)
其中:
CT = 至少一次被评估为“真”的条件
CF = 至少一次被评估为“假”的条件
B = 条件总数
新代码的条件覆盖率 ( ):此定义与条件覆盖率new_branch_coverage相同,但仅限于新的/更新的源代码。
条件覆盖率命中 ( branch_coverage_hits_data):涵盖条件的列表。
Conditions by line ( conditions_by_line):按行的条件数。
按行覆盖的条件 (covered_conditions_by_line):按行覆盖的条件数。
Coverage : Line coverage和Condition coveragecoverage的混合体。它的目标是为“单元测试覆盖了多少源代码?”这个问题提供更准确的答案。
覆盖率 = (CT + CF + LC)/(2*B + EL)
其中:
CT = 至少一次被评估为“真”的条件
CF = 至少一次被评估为“假”的条件
LC = 覆盖线 = 覆盖线-未覆盖线
B = 条件总数
EL = 可执行行总数 ( lines_to_cover)
新代码的覆盖率 ( ):此定义与覆盖率new_coverage相同,但仅限于新的/更新的源代码。
行覆盖率 ( line_coverage):在给定的代码行上,行覆盖率只是回答“这行代码是否在单元测试执行期间被执行过?”的问题。它是单元测试覆盖线的密度:
线路覆盖率 = LC / EL
其中:
LC = 覆盖线 ( lines_to_cover - uncovered_lines)
EL = 可执行行总数 ( lines_to_cover)
新代码的线路覆盖率 ( ):此定义与线路覆盖率new_line_coverage相同,但仅限于新的/更新的源代码。
Line coverage hits ( coverage_line_hits_data): 覆盖线的列表。
要覆盖的行数 ( lines_to_cover):单元测试可以覆盖的代码行数(例如,空白行或完整注释行不被视为要覆盖的行数)。
新代码要覆盖的行数 ( ):此定义与要覆盖的行数new_lines_to_cover相同,但仅限于新的/更新的源代码。
跳过的单元测试 ( skipped_tests):跳过的单元测试数。
–
未覆盖条件 ( uncovered_conditions):单元测试未覆盖的条件数。
新代码的未覆盖条件 ( ):此定义与未覆盖条件new_uncovered_conditions相同,但仅限于新的/更新的源代码。
未覆盖行数 ( uncovered_lines):未被单元测试覆盖的代码行数。
新代码上的未覆盖行 ( ):此定义与未覆盖行new_uncovered_lines相同,但仅限于新的/更新的源代码。
单元测试 ( tests):单元测试的数量。
单元测试持续时间 (test_execution_time):执行所有单元测试所需的时间。
单元测试错误 ( test_errors):失败的单元测试数。
单元测试失败 ( test_failures):因意外异常而失败的单元测试数。
单元测试成功密度(%) (test_success_density):测试成功密度=(单元测试-(单元测试错误+单元测试失败))/(单元测试)*100