go stub打桩测试

什么是打桩?

打桩这个词可能是从建筑行业借用过来的,指在地面上用锤子或机器将木桩或钢桩打入土中,以作为建筑物的基础。

打桩简单地来说就是把一些代码段进行替代,这些代码段就是“桩”,而GoStub中主要可以做到的就是对一个全局变量进行打桩、对一个函数打桩和对一个过程打桩。

导包

go get github.com/prashantv/gostub

stub与mock的区别

Mock:是模拟的意思,指的是在测试包中创建一个结构体,满足某个外部依赖的接口 interface{}。

Stub: 是桩的意思,指的是在测试包中创建一个模拟方法,用于替换生成代码中的方法。

go stub示例

1.对变量打桩

var num int = 10

func JudgeNum() bool {
	return num >= 100
}

func TestStub(t *testing.T) {
	convey.Convey("start", t, func() {
			stub := gostub.Stub(&num, 150) //对num打桩,将num的值替代为150
			defer stub.Reset() //对所有桩上的变量进行重置
			convey.So(JudgeNum(), convey.ShouldBeTrue)
		
			stub.Stub(&num, 80)
			convey.So(JudgeNum(), convey.ShouldBeTrue) //报错,JudgeNum()返回了false
		})
}

2.对函数打桩

var num int = 10

func JudgeNum() bool {
	return num >= 100
}

var fc = JudgeNum

func TestStub(t *testing.T) {
	convey.Convey("start", t, func() {
		stub := gostub.StubFunc(&fc, true)//fc为桩,返回true
		defer stub.Reset()
		convey.So(fc(), convey.ShouldBeFalse) //报错
		
	})

可以看到convey.So报错,fc()在不打桩的情况下应当返回false,而现在返回值是true。

3.对过程打桩

过程指的就是没有返回值,执行一些工作(比如资源清理)的函数。

//清理函数
func Clear() {
	fmt.Println("do clear()")
}

var clear = Clear

func TestStub(t *testing.T) {
	convey.Convey("start", t, func() {
		stub := gostub.StubFunc(&clear) //对clear函数进行打桩,无返回值
		defer stub.Reset()
		clear()//调用clear()
	})

结果:clear()没有打印输出,说明clear已经被替换成一个没有返回值的过程(桩)。

参考:https://zhuanlan.zhihu.com/p/168539526

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于一个类内的静态函数,可以通过打桩stubbing)来模拟其行为。打桩是一种测试技术,用于模拟或替代某些函数或方法的行为,以便进行单元测试。 要使用打桩对类内的静态函数进行测试,可以按照以下步骤操作: 1. 创建一个模拟对象或桩对象来代替静态函数的实际调用。这个模拟对象可以是手动编写的伪造对象,也可以使用专门的测试框架提供的工具来创建。 2. 使用打桩工具将模拟对象与静态函数进行关联。这意味着当代码中调用该静态函数时,将执行模拟对象的代码而不是实际的静态函数。 3. 设置模拟对象的行为,以便在测试中模拟静态函数的各种场景和返回值。 4. 执行测试用例,验证代码在不同情况下对静态函数的调用是否按预期执行。 以下是一个示例代码,展示如何使用打桩对类内的静态函数进行测试: ```python class MyClass: @staticmethod def my_static_function(): # 静态函数的实现代码 return "Hello, world!" # 测试代码 def test_my_static_function(): # 创建模拟对象 mock_object = Mock() # 关联模拟对象和静态函数 MyClass.my_static_function = mock_object # 设置模拟对象的行为 mock_object.return_value = "Mocked response" # 调用静态函数 result = MyClass.my_static_function() # 验证返回值是否符合预期 assert result == "Mocked response" # 执行测试用例 test_my_static_function() ``` 在上面的示例中,我们使用了一个名为`Mock`的模拟对象来替代类的静态函数。我们将模拟对象与静态函数关联,并设置模拟对象的返回值为"Mocked response"。然后,我们调用静态函数并验证返回值是否与我们预期的一样。 请注意,上述示例是使用Python编写的,如果您使用的是其他编程语言,可能需要使用相应的工具或框架来进行打桩和模拟对象的创建。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值