【GO】单元测试

单元测试案例

测试步骤

假如我说我们现在已经封装好了一个test.go的文件,代码如下

package main

import "fmt"

func main() {
	fmt.Println(GetFibonacci(6))
	sum := GetNum(10)
	fmt.Println(sum)
	getRecursion := GetRecursion(10)
	fmt.Println(getRecursion)
	fbNum := GetFbNum(10)
	fmt.Println(fbNum)
}

/**
递归就是自己调自己
递归一定要有终止条件,否则就会无限循环
*/
func GetFibonacci(n int) int {
	// 如果是第0项或者第2项直接返回1
	if n == 0 || n == 1 {
		return 1
	} else {
		return GetFibonacci(n-1) + GetFibonacci(n-2)
	}
}

/**
使用非递归实现斐波那契数列
*/
func GetFbNum(n int) int {
	a := 1
	b := 1
	c := a + b
	for i := 1; i <= n; i++ {
		a = b
		b = c
		c = a + b
	}
	return a
}

/**
使用循环来实现自然数之和
*/
func GetNum(n int) (sum int) {
	for i := 1; i <= n; i++ {
		sum += i
	}
	return
}

/**
使用递归来实现自然数求和
*/
func GetRecursion(n int) (sum int) {
	if n == 1 {
		return 1
	} else {
		return n + GetRecursion(n-1)
	}
}

然后我们需要在创建一个test_test.go的文件代码如下

package main

import "testing"

/**
测试斐波那契数列
*/
func TestGetFibonacci(t *testing.T) {
	fibonacci := GetFibonacci(6)
	if fibonacci != 13 {
		t.Errorf("测试失败")
		return
	}
	t.Logf("成功")
}

func TestGetRecursion(t *testing.T) {
	mMap := make(map[int]int)
	mMap[10] = 55
	mMap[100] = 5050
	for key, value := range mMap {
		if GetRecursion(key) != value {
			t.Errorf("测试失败")
			return
		}
	}
	t.Logf("测试成功  ")
}

文件目录结构

只需要把这俩个文件放在一个包里即可
在这里插入图片描述

用法

在上边我们可以看到在test_test.go的文件里,我们都用了Test开头,然后后边是Test.go里边的方法名。然后在调用Test.go的方法,用来做测试

测试

在这里插入图片描述
然后就会获得测试结果,对于go 的单元测试使用还是很简单的

博主微信欢迎交流

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

咔咔-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值