Go测试开发就用这三板斧

Testfan软件测试 · · 1748 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

一个古老的面试问题:“给你个XX,你怎么测试?

    时间穿越到9102,Go语言成为了新生代的代名词。老问题变成了“给你Golang程序,你怎么测试?”

    看完本文后,读者可以拍着胸脯回答,“一共三种方式,分别是:

• 功能测试

• 性能测试

• 覆盖率测试

具体怎么做,老司机带着大家撸一撸代码,速成一下!

准备活动:开一个Go project,创建一个目录,比如命名“gotest”。

里面放第一个go程序,计算一下圆面积,叫“CircleArea.go”比如看起来这样:

package gotest

import "math"

func GetCircleArea(radius float32) float32 {

    return math.Pi * radius * radius

}

首先,功能测试:

编写一个测试它的程序,用Go语言测试Go程序,原汤化原食,没问题吧?^_^

    命名有讲究:待测程序名后面加”_test”。原程序叫“CircleArea.go”,那么测试用例程序就叫“CircleArea_test.go”,看起来这样的:

package gotest

import "testing"  // 必须引入这个包

func TestGetCircleArea(t *testing.T) {

    area := GetCircleArea(4.0)

    if area != 50.265484 { // 预期结果

        t.Error("测试未通过!")

    } else {

        t.Log("测试通过")

    }

}

    执行很简单,在命令行执行:go test -v

    结果看起来一目了然:

    然后,压力测试:

    简单的“压力测试”其实是执行多轮测试。

    把刚才的测试用例,套个循环就完成了。

package gotest

import "testing"

const N = 3

func TestGetCircleArea(t *testing.T) {

    for i:=0;i<N;i++ {

        area := GetCircleArea(4.0)

        if area != 50.265484 {

            t.Error("测试未通过!")

        } else {

            t.Log("测试通过")

        }

    }

}

    按之前方式执行:

    或者使用”-bench”参数,结果更简洁:

    聪明的小伙伴们一定想清楚了,循环次数可以定制,测试用例和预期结果都可以参数化。

程序稍微一修改就可以了。

    比较讲究的小伙伴可以再进一步,保留原来的测试用例函数,增加一个用于benchmark测试的,比如:

func BenchmarkGetCircleArea(b *testing.B) {

    for i:=0;i<N;i++ {

        area := GetCircleArea(4.0)

        if area != 50.265484 {

            b.Error("测试未通过!")

        } else {

            b.Log("测试通过")

        }

    }

}

    最后,覆盖率测试

    命令行直接执行 go test -cover

    结果很通俗易懂:

    特别说明:写的代码是如果有用来接住panic跑出的“异常”的,那么测试覆盖率不会达到100%,因为走不到。小伙伴们自己写个例子就知道了。

作  者:Testfan Arthur

出  处:微信公众号:自动化软件测试平台

版权说明:欢迎转载,但必须注明出处,并在文章页面明显位置给出文章链接


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:Testfan软件测试

查看原文:Go测试开发就用这三板斧

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1748 次点击  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传