代码覆盖率是单元测试的一个指标,通常覆盖率越高,单元测试就做得更完备。(然而,覆盖率是不是和软件质量成正比关系呢?)gcov是GNU工具链中的一个重要的工具,虽然gcov是覆盖率很好的工具,但是gcov的更重要的应用是性能的调优。gcov通过监视程序的执行,从而确定某行代码有没有执行,执行了多少次。gcov的报告是基于文本的格式的,看起来是比较难看点。但是,有个叫lcov的工具,将gcov的报告格式转换为html的直观形式,后面介绍。
gcov使用:
如有以下代码:
1: #include <stdio.h>
2:
3: void bubbleSort( int list[], int size )
4: {
5: int i, j, temp, swap = 1;
6:
7: while (swap) {
8:
9: swap = 0;
10:
11: for ( i = (size-1) ; i >= 0 ; i-- ) {
12:
13: for ( j = 1 ; j <= i ; j++ ) {
14:
15: if ( list[j-1] > list[j] ) {
16:
17: temp = list[j-1];
18: list[j-1] = list[j];
19: list[j] = temp;
20: swap = 1;
21:
22: }
23:
24: }
25:
26: }
27:
28: }
29:
30:
31: }
32:
33: int main()
34: {
35: int theList[10]={10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
36: int i;
37:
38: /* Invoke the bubble sort algorithm */
39: bubbleSort( theList, 10 );
40:
41: /* Print out the final list */
42: for (i = 0 ; i < 10 ; i++) {
43: printf("%d\n", theList[i]);
44: }
45: if(i == 0){
46: printf("i = 0\n");
47: }else{
48: printf("i != 0\n");
49: }
50:
51: }
1. 编译程序是增加 -ftest-coverage -fprofile-arcs 选项。
[heidong@HEIDONGVM gcov]$ gcc -o bbsort bbsort.c -ftest-coverage -fprofile-arcs
生成.gcno文件。
2. 执行程序,将生成.gcda文件,用gcov程序检查相应的源代码文件,将生成结果文件。
[heidong@HEIDONGVM gcov]$ ./bbsort
1
2
3
4
5
6
7
8
9
10
i != 0
[heidong@HEIDONGVM gcov]$ gcov bbsort.c
File‘bbsort.c’
已执行的行数:95.24% (共 21 行)
bbsort.c:正在创建‘bbsort.c.gcov
3. 检查相应的结果文件
[heidong@HEIDONGVM gcov]$ cat bbsort.c.gcov
-: 0:Source:bbsort.c
-: 0:Graph:bbsort.gcno
-: 0:Data:bbsort.gcda
-: 0:Runs:1
-: 0:Programs:1
-: 1:#include <stdio.h>
-: 2:
1: 3:void bubbleSort( int list[], int size )
-: 4:{
1: 5: int i, j, temp, swap = 1;
-: 6:
4: 7: while (swap) {
-: 8:
2: 9: swap = 0;
-: 10:
22: 11: for ( i = (size-1) ; i >= 0 ; i-- ) {
-: 12:
110: 13: for ( j = 1 ; j <= i ; j++ ) {
-: 14:
90: 15: if ( list[j-1] > list[j] ) {
-: 16:
45: 17: temp = list[j-1];
45: 18: list[j-1] = list[j];
45: 19: list[j] = temp;
45: 20: swap = 1;
-: 21:
-: 22: }
-: 23:
-: 24: }
-: 25:
-: 26: }
-: 27:
-: 28: }
-: 29:
-: 30:
1: 31:}
-: 32:
1: 33:int main()
-: 34:{
1: 35: int theList[10]={10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
-: 36: int i;
-: 37:
-: 38: /* Invoke the bubble sort algorithm */
1: 39: bubbleSort( theList, 10 );
-: 40:
-: 41: /* Print out the final list */
11: 42: for (i = 0 ; i < 10 ; i++) {
10: 43: printf("%d\n", theList[i]);
-: 44: }
1: 45: if(i == 0){
#####: 46: printf("i = 0\n");
-: 47: }else{
1: 48: printf("i != 0\n");
-: 49: }
-: 50:
1: 51:}
-: 52:
[heidong@HEIDONGVM gcov]$
可以看到某行执行了多少次,哪些行没有执行过(####标示)。gcov 还可以检查其他很多的信息,如分支,函数等,详细参考gcov的帮助文档,并测试之。
对于文本格式,相信很多人的觉得不是很直观,于是便有了lcov这个工具,它可以算是gcov的前端工具,这样生成html文件,可以很直观的看到代码覆盖情况。
lcov不是标准的unix/linux工具,需要下载,地址是:ltp.sourceforge.net/coverage/lcov.php 注意要×××才可以访问。
使用方式:
1. 执行完gcov的步骤后,执行下列命令:
[heidong@HEIDONGVM gcov]$ lcov --capture --directory ./ --output-file bbsort.info
Capturing coverage data from ./
Found gcov version: 4.4.6
Scanning ./ for .gcda files ...
Found 1 data files in ./
Processing bbsort.gcda
Finished .info-file creation
2. 生成html文件:
[heidong@HEIDONGVM gcov]$ genhtml bbsort.info --output-directory ./lcov/
Reading data file bbsort.info
Found 1 entries.
Found common filename prefix "/home/heidong/tmp"
Writing .css and .png files.
Generating output.
Processing file gcov/bbsort.c
Writing directory view page.
Overall coverage rate:
lines......: 95.2% (20 of 21 lines)
functions..: 100.0% (2 of 2 functions
看下生成的html文件:
完毕。
转载于:https://blog.51cto.com/buf1024/1213889